Changeset 5978 for main/waeup.sirp/trunk/src/waeup/sirp/university
- Timestamp:
- 26 Apr 2011, 10:44:43 (14 years ago)
- Location:
- main/waeup.sirp/trunk/src/waeup/sirp/university
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
main/waeup.sirp/trunk/src/waeup/sirp/university/api.txt
r4975 r5978 22 22 facultycontainer.txt 23 23 24 Additional infos about the refer ences tocourses and how they are24 Additional infos about the referrers of courses and how they are 25 25 handled can be found in: 26 26 -
main/waeup.sirp/trunk/src/waeup/sirp/university/certificate.txt
r5949 r5978 98 98 .. method:: addCourseRef(course[, level=100,[ core_or_elective=True]]) 99 99 100 Add a refer ence toa course. A course is an object implementing100 Add a referrer of a course. A course is an object implementing 101 101 :class:`waeup.sirp.interfaces.ICourse`. 102 102 103 Please don't be confused by the term 'reference'. This just 104 means an ordinary :class:`waeup.sirp.university.course.Course` object 105 in almost all cases. As this object will normaly be one stored 106 in a department, the course here will simply become a reference 107 to the 'real' one in the department container. 103 Please don't be confused by the term 'referrer'. As course objects 104 will normaly be stored 105 in a department, the course referrer refers to 106 the 'real' course in the department container. 108 107 109 108 .. method:: delCourseRef(code) 110 109 111 Remove a course from a certificate.112 113 The coursemust be given by its code number.110 Remove a course referrer from a certificate. 111 112 The referrer must be given by its code number. 114 113 115 114 :class:`CertificateCourse` … … 118 117 .. class:: CertificateCourse(course[, level=100[, core_or_elective=True]]) 119 118 120 Create a certificate course. 121 122 A certificate-course is a course (:class:`Course`) which is part of 123 a certificate. Normally, certificate-courses are held in 119 Create a course referrer. 120 121 A certificate course (old term) or course referrer are held in 124 122 certificates and refer to an existing :class:`Course` instance held 125 123 elsewhere. 126 124 127 A certificate can require several course s and one128 course can be required by several certificates.125 A certificate can require several course referrers and one 126 course referrer can be required by several certificates. 129 127 130 128 .. attribute:: course … … 223 221 instance is removed from a container. 224 222 225 Tries to remove all refer encing :class:`CertificateCourse`226 instances that refer ence theremoved course.223 Tries to remove all referring :class:`CertificateCourse` 224 instances that refer to a removed course. 227 225 228 226 To accomplish that, the parents of the removed course are looked up 229 for a certifcate container which contains a c ertificate-coursethat230 contains a referenceto the deleted course.227 for a certifcate container which contains a course referrer that 228 refers to the deleted course. 231 229 232 230 .. seealso:: :ref:`removecertificatecourses` … … 290 288 291 289 If a certificate course requires a certain course and this is course 292 is deleted, also the refer encing certificate course is deleted.290 is deleted, also the referring certificate course is deleted. 293 291 294 292 We setup a data structure that reflects typical usage. It looks like … … 356 354 ['mydept'] 357 355 358 The c ertificate-coursewe stored in the certificate is indeed a359 refer ence tothe course, not a copy of it:356 The course referrer we stored in the certificate is indeed a 357 referrer of the course, not a copy of it: 360 358 361 359 >>> course = newdbroot['mydept'].courses['MYCOURSE'] -
main/waeup.sirp/trunk/src/waeup/sirp/university/courserefs.txt
r4921 r5978 1 Course refer ences2 **************** *1 Course referrers 2 **************** 3 3 4 Courses are refer encedby certificate courses.4 Courses are referred to by certificate courses. 5 5 6 6 :Test-Layer: functional 7 7 8 We can be sure, that when removing courses or refer ences tothem,8 We can be sure, that when removing courses or referrers of them, 9 9 other data will be handled in a way we expect. That is, 10 10 11 * when we remove a course, we want all refer ences to it be removed as11 * when we remove a course, we want all referrers to it be removed as 12 12 well 13 13 14 * when we remove a refer ence toa course, nothing else should be15 touched but only this very refer ence.14 * when we remove a referrer of a course, nothing else should be 15 touched but only this very referrer. 16 16 17 17 18 As correct deletion of refer encesneeds support of catalogs (we lookup19 catalogs to find refer ences), we need a fully blown ZODB here,18 As correct deletion of referrer needs support of catalogs (we lookup 19 catalogs to find referrers), we need a fully blown ZODB here, 20 20 including an instance of :class:`waeup.sirp.app.University`, as this is our 21 21 `ISite` object where the catalogs are stored. … … 59 59 >>> fac['DEPT2'].courses.addCourse(course) 60 60 61 Finally, we add a certificate with refer ences (certificate courses) to61 Finally, we add a certificate with referrers (certificate courses) to 62 62 the created courses: 63 63 … … 77 77 ... fac['DEPT2'].courses['CRS2'], level=200) 78 78 79 So, we have three refer ences in our certificate totwo different79 So, we have three referrers in our certificate of two different 80 80 courses stored somewhere in the application: 81 81 … … 83 83 [u'CRS1_100', u'CRS2_100', u'CRS2_200'] 84 84 85 Both, the courses themselves and the refer ences tothem, are the same85 Both, the courses themselves and the referrers of them, are the same 86 86 (not only equal): 87 87 … … 92 92 True 93 93 94 If we remove the course, also the reference to it in the certcourse94 If we remove the course, also the select item in the certificate course 95 95 will be gone: 96 96 … … 108 108 [] 109 109 110 If we remove a refer ence, this will not touch the referencedcourse111 nor other refer ences:110 If we remove a referrer of a course, this will not touch the course 111 nor other referrers: 112 112 113 113 >>> del fac['DEPT'].certificates['CERT']['CRS2_200']
Note: See TracChangeset for help on using the changeset viewer.