SCDoc: Use proper static string constants instead of comparing string literals.
[supercollider.git] / HelpSource / Reference / default_group.schelp
bloba17693238431fa6f584f0a8836f45b6dcc908b47
1 title:: default_group
2 summary:: The default Group
3 categories:: Server>Nodes
4 related:: Classes/Group, Classes/RootNode, Classes/Node, Guides/NodeMessaging, Guides/Order-of-execution
6 tree::
7 ## root node (id:0)
8 tree::
9 ## default group (id:1)
13 When a Server is booted there is a top level group with an ID of 0 that defines the root of the node tree. (This is represented by a subclass of Group: link::Classes/RootNode::.)
14 If the Server was booted from within SCLang (as opposed to from the command line) a default group with an ID of 1 will be automatically created. footnote::
15 When booting the server from the command line, you can create the default group manually with:
16 code::
17 s.initTree;
20 This is the default target for all Nodes when using object style and is what you will get if you supply a link::Classes/Server:: as a target. If you don't specify a target or pass in nil, you will get the default group of the default Server.
21 code::
22 Server.default.boot;
23 a = Synth.new(\default); // creates a synth in the default group of the default Server
24 a.group; // note the Group ID
26 The default group serves an important purpose: It provides a predictable basic Node tree so that methods such as Server-scope, Server-record, etc. can function without running into order of execution problems. In the example below the scoping node will come after the default group.
27 code::
28 Server.internal.boot;
30 { SinOsc.ar(mul: 0.2) }.scope(1);
32 // watch the post window;
33 Server.internal.queryAllNodes;
35 // our SinOsc synth is within the default group (ID 1)
36 // the scope node comes after the default group, so no problems
38 Server.internal.quit;
40 Note that the default group is persistent: It is created in Server's code::initTree:: method (executed along with any code stored in its tree instance variable; see Server for more detail) and is recreated upon reboot, after pressing Cmd-., and after all nodes are freed. When using osc messages this means that a target node of id 1 can always be used:
41 code::
42 s.sendMsg("/s_new", "snd", 1832,0,1); // add to head of group 1
44 The default group can be specifically freed, but there is generally no reason that one would want to do so.
46 In general one should add nodes to the default group rather than the RootNode unless one has a specific reason to do so (i.e. adding some new functionality such as recording and scoping which is dependent upon a predictable basic node order). When using object style the default group is the default target for all new nodes, so nodes will normally not be added to the RootNode unless that is explicitly specified. It is of course possible to do so, but it should only be done with a proper understanding of the issues involved.
48 For instance, if one were to place an 'effects' synth after the default group and call Server-record or Server-scope, the resulting recording or scope synths may not be correctly ordered:
49 tree::
50 ## default group
51 tree::
52 ## source synth1
53 ## source synth2
55 ## recording synth
56 ## effects synth
58 In the above example the recording synth might not capture the output of the effects synth since it comes later in the node order.
60 A better method in this case is to create a group within the default group and place the effects synth after that.
61 tree::
62 ## default group
63 tree::
64 ## source group
65 tree::
66 ## source synth1
67 ## source synth2
69 ## effects synth
71 ## recording synth