#PLEASE DO NOT EDIT THIS CODE #This code was generated using the UMPLE 1.33.0.6934.a386b0a58 modeling language! # line 5 "AssociationBothSidesSorted.ump" import os import pickle class Mentor(): #------------------------ # MEMBER VARIABLES #------------------------ #Mentor Attributes #Mentor Associations #------------------------ # CONSTRUCTOR #------------------------ def __init__(self, aName, aStudentsPriority): self._students = None self._studentsPriority = None self._name = None self._name = aName self._studentsPriority = aStudentsPriority self._students = [] #------------------------ # INTERFACE #------------------------ def setName(self, aName): wasSet = False self._name = aName wasSet = True return wasSet def setStudentsPriority(self, aStudentsPriority): wasSet = False self._studentsPriority = aStudentsPriority wasSet = True return wasSet def getName(self): return self._name def getStudentsPriority(self): return self._studentsPriority # 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 0 # Code from template association_AddManyToManyMethod def addStudent(self, aStudent): wasAdded = False if (aStudent) in self._students : return False self._students.append(aStudent) if aStudent.indexOfMentor(self) != -1 : wasAdded = True else : wasAdded = aStudent.addMentor(self) if not wasAdded : self._students.remove(aStudent) return wasAdded # Code from template association_RemoveMany def removeStudent(self, aStudent): wasRemoved = False if not (aStudent) in self._students : return wasRemoved oldIndex = (-1 if not aStudent in self._students else self._students.index(aStudent)) self._students.remove(oldIndex) if aStudent.indexOfMentor(self) == -1 : wasRemoved = True else : wasRemoved = aStudent.removeMentor(self) if not wasRemoved : self._students.insert(oldIndex, aStudent) return wasRemoved # Code from template association_sorted_serializable_readObject def readObject(self, input): self.__dict__.clear() self.__dict__.update(pickle.load(input).__dict__) self._studentsPriority = None def delete(self): copyOfStudents = self._students.copy() self._students.clear() for aStudent in copyOfStudents: aStudent.removeMentor(self) def __str__(self): return str(super().__str__()) + "[" + "name" + ":" + str(self.getName()) + "]" + str(os.linesep) + " " + "studentsPriority" + "=" + (((self.getStudentsPriority().__str__().replaceAll(" ", " ")) if not self.getStudentsPriority() == self else "this") if not (self.getStudentsPriority() is None) else "null") def __getstate__(self): state = dict(self.__dict__) state.pop("_studentsPriority") return state #PLEASE DO NOT EDIT THIS CODE #This code was generated using the UMPLE 1.33.0.6934.a386b0a58 modeling language! # line 1 "AssociationBothSidesSorted.ump" import os import pickle class Student(): #------------------------ # MEMBER VARIABLES #------------------------ #Student Attributes #Student Associations #------------------------ # CONSTRUCTOR #------------------------ def __init__(self, aId, aMentorsPriority): self._mentors = None self._mentorsPriority = None self._id = None self._id = aId self._mentorsPriority = aMentorsPriority self._mentors = [] #------------------------ # INTERFACE #------------------------ def setId(self, aId): wasSet = False self._id = aId wasSet = True return wasSet def setMentorsPriority(self, aMentorsPriority): wasSet = False self._mentorsPriority = aMentorsPriority wasSet = True return wasSet def getId(self): return self._id def getMentorsPriority(self): return self._mentorsPriority # Code from template association_GetMany def getMentor(self, index): aMentor = self._mentors[index] return aMentor def getMentors(self): newMentors = tuple(self._mentors) return newMentors def numberOfMentors(self): number = len(self._mentors) return number def hasMentors(self): has = len(self._mentors) > 0 return has def indexOfMentor(self, aMentor): index = (-1 if not aMentor in self._mentors else self._mentors.index(aMentor)) return index # Code from template association_MinimumNumberOfMethod @staticmethod def minimumNumberOfMentors(): return 0 # Code from template association_AddManyToManyMethod def addMentor(self, aMentor): wasAdded = False if (aMentor) in self._mentors : return False self._mentors.append(aMentor) if aMentor.indexOfStudent(self) != -1 : wasAdded = True else : wasAdded = aMentor.addStudent(self) if not wasAdded : self._mentors.remove(aMentor) return wasAdded # Code from template association_RemoveMany def removeMentor(self, aMentor): wasRemoved = False if not (aMentor) in self._mentors : return wasRemoved oldIndex = (-1 if not aMentor in self._mentors else self._mentors.index(aMentor)) self._mentors.remove(oldIndex) if aMentor.indexOfStudent(self) == -1 : wasRemoved = True else : wasRemoved = aMentor.removeStudent(self) if not wasRemoved : self._mentors.insert(oldIndex, aMentor) return wasRemoved # Code from template association_sorted_serializable_readObject def readObject(self, input): self.__dict__.clear() self.__dict__.update(pickle.load(input).__dict__) self._mentorsPriority = None def delete(self): copyOfMentors = self._mentors.copy() self._mentors.clear() for aMentor in copyOfMentors: aMentor.removeStudent(self) def __str__(self): return str(super().__str__()) + "[" + "id" + ":" + str(self.getId()) + "]" + str(os.linesep) + " " + "mentorsPriority" + "=" + (((self.getMentorsPriority().__str__().replaceAll(" ", " ")) if not self.getMentorsPriority() == self else "this") if not (self.getMentorsPriority() is None) else "null") def __getstate__(self): state = dict(self.__dict__) state.pop("_mentorsPriority") return state