/usr/share/SuperCollider/HelpSource/Reference/initClass.schelp is in supercollider-common 1:3.6.6~repack-2-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 | title::initClass
categories::Core>Kernel, Language>OOP
summary:: Class initialization
related:: Classes/Class
method:: initClass
When SuperCollider starts up, just after it has compiled the library, it initializes all the classes from Object down, a depth first traversal of subclasses.
In this method, any class that requires it may initalize classvars or other resources.
method:: initClassTree
In some cases you will require another class to be initalized before you can initalize your own. You may depend on its resources (a classvar). This can be accomplished by:
code::
YourClass {
*initClass {
Class.initClassTree(OtherClass);
..
//
..
}
..
}
::
Each class will be inited once, and the OtherClass will have all of its subclasses inited before the method returns.
For those methods that need pre-initialized data (such as path names) should defer this function by using StartUp:
code::
YourClass {
*initClass {
StartUp.add {
..
}
}
..
}
::
|