#PLEASE DO NOT EDIT THIS CODE #This code was generated using the UMPLE 1.33.0.6934.a386b0a58 modeling language! # line 3 "../OptionalOneToMStarTest.ump" class Mentor(): #------------------------ # MEMBER VARIABLES #------------------------ #Mentor Attributes #Mentor Associations #------------------------ # CONSTRUCTOR #------------------------ def __init__(self, aName, *allStudents): allStudents = list(allStudents) self._students = None self._name = None self._name = aName self._students = [] didAddStudents = self.setStudents(*allStudents) if not didAddStudents : raise RuntimeError ("Unable to create Mentor, must have at least 5 students. See http://manual.umple.org?RE002ViolationofAssociationMultiplicity.html") #------------------------ # INTERFACE #------------------------ def setName(self, aName): wasSet = False self._name = aName wasSet = True return wasSet def getName(self): return self._name # Code from template association_GetMany def getStudent(self, index): aStudent = self._students[index] return aStudent def getStudents(self): newStudents = tuple(self._students) return newStudents def numberOfStudents(self): number = len(self._students) return number def hasStudents(self): has = len(self._students) > 0 return has def indexOfStudent(self, aStudent): index = (-1 if not aStudent in self._students else self._students.index(aStudent)) return index # Code from template association_MinimumNumberOfMethod @staticmethod def minimumNumberOfStudents(): return 5 # Code from template association_AddMNToOptionalOne def addStudent(self, aStudent): wasAdded = False if (aStudent) in self._students : return False existingMentor = aStudent.getMentor() if not (existingMentor is None) and existingMentor.numberOfStudents() <= Mentor.minimumNumberOfStudents() : return wasAdded elif not (existingMentor is None) : existingMentor.students.remove(aStudent) self._students.append(aStudent) self.setMentor(aStudent, self) wasAdded = True return wasAdded def removeStudent(self, aStudent): wasRemoved = False if (aStudent) in self._students and self.numberOfStudents() > Mentor.minimumNumberOfStudents() : self._students.remove(aStudent) self.setMentor(aStudent, None) wasRemoved = True return wasRemoved # Code from template association_SetMNToOptionalOne def setStudents(self, *newStudents): newStudents = list(newStudents) wasSet = False if len(newStudents) < Mentor.minimumNumberOfStudents() : return wasSet checkNewStudents = [] mentorToNewStudents = dict() for aStudent in newStudents: if (aStudent) in checkNewStudents : return wasSet elif not (aStudent.getMentor() is None) and not self == aStudent.getMentor() : existingMentor = aStudent.getMentor() if not (existingMentor) in mentorToNewStudents : mentorToNewStudents[existingMentor] = int(existingMentor.numberOfStudents()) currentCount = mentorToNewStudents.get(existingMentor) nextCount = currentCount - 1 if nextCount < 5 : return wasSet mentorToNewStudents[existingMentor] = int(nextCount) checkNewStudents.append(aStudent) self._students = list(filter(lambda a : not a in checkNewStudents, self._students)) for orphan in self._students: self.setMentor(orphan, None) self._students.clear() for aStudent in newStudents: if not (aStudent.getMentor() is None) : aStudent.getMentor().students.remove(aStudent) self.setMentor(aStudent, self) self._students.append(aStudent) wasSet = True return wasSet # Code from template association_GetPrivate def setMentor(self, aStudent, aMentor): try : aStudent._mentor = aMentor except : raise RuntimeError ("Issue internally setting aMentor to aStudent") # Code from template association_AddIndexControlFunctions def addStudentAt(self, aStudent, index): wasAdded = False if self.addStudent(aStudent) : if index < 0 : index = 0 if index > self.numberOfStudents() : index = self.numberOfStudents() - 1 self._students.remove(aStudent) self._students.insert(index, aStudent) wasAdded = True return wasAdded def addOrMoveStudentAt(self, aStudent, index): wasAdded = False if (aStudent) in self._students : if index < 0 : index = 0 if index > self.numberOfStudents() : index = self.numberOfStudents() - 1 self._students.remove(aStudent) self._students.insert(index, aStudent) wasAdded = True else : wasAdded = self.addStudentAt(aStudent, index) return wasAdded def delete(self): for aStudent in self._students: self.setMentor(aStudent, None) self._students.clear() def __str__(self): return str(super().__str__()) + "[" + "name" + ":" + str(self.getName()) + "]" #PLEASE DO NOT EDIT THIS CODE #This code was generated using the UMPLE 1.33.0.6934.a386b0a58 modeling language! # line 9 "../OptionalOneToMStarTest.ump" import os class Student(): #------------------------ # MEMBER VARIABLES #------------------------ #Student Attributes #Student Associations #------------------------ # CONSTRUCTOR #------------------------ def __init__(self, aNumber): self._mentor = None self._number = None self._number = aNumber #------------------------ # INTERFACE #------------------------ def setNumber(self, aNumber): wasSet = False self._number = aNumber wasSet = True return wasSet def getNumber(self): return self._number # Code from template association_GetOne def getMentor(self): return self._mentor def hasMentor(self): has = not (self._mentor is None) return has # Code from template association_SetOptionalOneToMandatoryMany def setMentor(self, aMentor): # # This source of this source generation is association_SetOptionalOneToMandatoryMany.jet # This set file assumes the generation of a maximumNumberOfXXX method does not exist because # it's not required (No upper bound) # wasSet = False existingMentor = self._mentor if existingMentor is None : if not (aMentor is None) : if aMentor.addStudent(self) : existingMentor = aMentor wasSet = True elif not (existingMentor is None) : if aMentor is None : if existingMentor.minimumNumberOfStudents() < existingMentor.numberOfStudents() : existingMentor.removeStudent(self) existingMentor = aMentor # aMentor == null wasSet = True else : if existingMentor.minimumNumberOfStudents() < existingMentor.numberOfStudents() : existingMentor.removeStudent(self) aMentor.addStudent(self) existingMentor = aMentor wasSet = True if wasSet : self._mentor = existingMentor return wasSet def delete(self): if not (self._mentor is None) : if self._mentor.numberOfStudents() <= 5 : self._mentor.delete() else : placeholderMentor = self._mentor self._mentor = None placeholderMentor.removeStudent(self) def __str__(self): return str(super().__str__()) + "[" + "number" + ":" + str(self.getNumber()) + "]" + str(os.linesep) + " " + "mentor = " + ((format(id(self.getMentor()), "x")) if not (self.getMentor() is None) else "null")