#PLEASE DO NOT EDIT THIS CODE
#This code was generated using the UMPLE 1.35.0.7523.c616a4dce 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 https://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.35.0.7523.c616a4dce 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")