This file is indexed.

/usr/share/SuperCollider/HelpSource/Reference/initClass.schelp is in supercollider-common 1:3.8.0~repack-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 initialize classvars or other resources.

method:: initClassTree

In some cases you will require another class to be initialized before you can initialize 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 initialized once, and the OtherClass will have all of its subclasses initialized 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 {
            ..
        }
    }

    ..

}
::