scel: install files to site-lisp/SuperCollider
[supercollider.git] / HelpSource / Classes / OSCdef.schelp
blobb744212bfb36810ed3cb5971b44e3123742acf26
1 CLASS:: OSCdef
2 summary:: OSC response reference definition
3 categories:: External Control>OSC>Dispatchers
4 related:: Guides/OSC_communication, Classes/OSCFunc, Classes/OSCresponderNode, Classes/NetAddr
6 DESCRIPTION::
7 OSCdef provides a global reference to the functionality of its superclass link::Classes/OSCFunc::. Essentially it stores itself at a key within a global dictionary, allowing replacement at any time. Most methods are inherited from its superclass.
9 note:: Use of the older classes OSCresponder, OSCresponderNode, and OSCpathResponder can be unsafe, since responders in user and class code can override each other unintentionally. link::Classes/OSCFunc:: and OSCdef are faster, safer, have more logical argument order, and support pattern matching. Thus they are the recommended way of registering for incoming OSC messages as of SC 3.5. (See below for an example demonstrating OSCpathResponder-type arg matching.)::
12 CLASSMETHODS::
13 private:: initClass
15 METHOD:: all
16 Get the global dictionary of all OSCdefs.
18 returns:: An link::Classes/IdentityDictionary::.
20 METHOD:: new
21 Create a new, enabled OSCdef. If an OSCdef already exists at this key, its parameters will be replaced with the ones provided (args for which nil is passed will use the old values).
23 argument:: key
24 The key at which to store this OSCdef in the global collection. Generally this will be a link::Classes/Symbol::.
26 argument:: func
27 A link::Classes/Function:: or similar object which will respond to the incoming message. When evaluated it will be passed the arguments msg, time, addr, and recvPort, corresponding to the message as an link::Classes/Array:: in the form code::[OSCAddress, other args]::, the time that the message was sent, a link::Classes/NetAddr:: corresponding to the IP address of the sender, and an link::Classes/Integer:: corresponding to the port on which the message was received.
29 argument:: path
30 A link::Classes/Symbol:: indicating the path of the OSC address of this object. Note that OSCdef demands OSC compliant addresses. If the path does not begin with a / one will be added automatically.
32 argument:: srcID
33 An optional instance of link::Classes/NetAddr:: indicating the IP address of the sender. If set this object will only respond to messages from that source.
35 argument:: recvPort
36 An optional link::Classes/Integer:: indicating the port on which messages will be received. If set this object will only respond to message received on that port. This method calls link::Classes/Main#-openUDPPort:: to ensure that the port is opened.
38 argument:: argTemplate
39 An optional link::Classes/Array:: composed of instances of link::Classes/Integer:: or link::Classes/Function:: (or objects which respond to the method link::Overviews/Methods#matchItem::) used to match the arguments of an incoming OSC message. If a Function, it will be evaluated with the corresponding message arg as an argument, and should return a link::Classes/Boolean:: indicating whether the argument matches and this OSCdef should respond (providing all other arguments match). Template values of nil will match any incoming argument value.
41 argument:: dispatcher
42 An optional instance of an appropriate subclass of link::Classes/AbstractDispatcher::. This can be used to allow for customised dispatching. Normally this should not be needed.
44 returns:: An instance of OSCdef.
46 METHOD:: newMatching
47 A convenience method to create a new, enabled OSCdef whose dispatcher will perform pattern matching on incoming OSC messages to see if their address patterns match this object's path.
49 argument:: key
50 The key at which to store this OSCdef in the global collection. Generally this will be a link::Classes/Symbol::.
52 argument:: func
53 A link::Classes/Function:: or similar object which will respond to the incoming message. When evaluated it will be passed the arguments msg, time, addr, and recvPort, corresponding to the message as an link::Classes/Array:: [OSCAddress, other args], the time that the message was sent, a link::Classes/NetAddr:: corresponding to the IP address of the sender, and an link::Classes/Integer:: corresponding to the port on which the message was received.
55 argument:: path
56 A link::Classes/Symbol:: indicating the path of the OSC address of this object. Note that OSCdef demands OSC compliant addresses. If the path does not begin with a / one will be added automatically. Pattern matching will be applied to any incoming messages to see if they match this address. Note that according to the OSC spec, regular expression wildcards are only permitted in the incoming message's address pattern. Thus path should not contain wildcards. For more details on OSC pattern matching, see http://opensoundcontrol.org/spec-1_0
58 argument:: srcID
59 An optional instance of link::Classes/NetAddr:: indicating the IP address of the sender. If set this object will only respond to messages from that source.
61 argument:: recvPort
62 An optional link::Classes/Integer:: indicating the port on which messages will be received.
64 argument:: argTemplate
65 An optional link::Classes/Array:: composed of instances of link::Classes/Integer:: or link::Classes/Function:: (or objects which respond to the method link::Overviews/Methods#matchItem::) used to match the arguments of an incoming OSC message. If a Function, it will be evaluated with the corresponding message arg as an argument, and should return a link::Classes/Boolean:: indicating whether the argument matches and this OSCFunc should respond (providing all other arguments match). Template values of nil will match any incoming argument value.
67 returns:: An instance of OSCdef.
69 METHOD:: freeAll
70 Clears and deactivates all OSCdefs from the global collection.
72 INSTANCEMETHODS::
73 private:: addToAll, printOn
75 METHOD:: key
76 Get this OSCdef's key.
78 returns:: Usually a link::Classes/Symbol::.
80 METHOD:: free
81 Clears this OSCdef from the global collection and deactivates it.
84 EXAMPLES::
86 code::
87 n = NetAddr("127.0.0.1", 57120); // local machine
89 OSCdef(\test, {|time, msg, addr| \unmatching.postln}, '/chat', n); // def style
90 OSCdef.newMatching(\test2, {|time, msg, addr| \matching.postln}, '/chat', n); // path matching
91 OSCdef(\test3, {|time, msg, addr| \oneShot.postln}, '/chat', n).oneShot; // once only
94 m = NetAddr("127.0.0.1", 57120); // loopback
96 m.sendMsg("/chat", "Hello App 1");
97 m.sendMsg("/chat", "Hello App 1"); // oneshot gone
98 m.sendMsg("/ch?t", "Hello App 1");
99 m.sendMsg("/*", "Hello App 1");
100 m.sendMsg("/chit", "Hello App 1"); // nothing
102 // Introspection
104 AbstractResponderFunc.allFuncProxies
105 AbstractResponderFunc.allEnabled
106 OSCdef(\test).disable;
107 AbstractResponderFunc.allDisabled
109 // change funcs
110 OSCdef(\test).enable;
111 OSCdef(\test, {|time, msg, addr| 'Changed Unmatching'.postln}, '/chat', n); // replace at key \test
112 m.sendMsg("/chat", "Hello App 1");
113 OSCdef(\test).add(f = {\foo.postln}); // add another func
114 m.sendMsg("/chat", "Hello App 1");
115 OSCdef(\test).clear; // remove all functions
116 m.sendMsg("/chat", "Hello App 1");
117 OSCdef(\test).free;  // unregister OSCdef
120 //////// Use an argTemplate for finer grained matching
122 s.boot;
123 x = Synth(\default);
124 OSCdef(\watchForXEnd, { 'ended!'.postln }, '/n_end', s.addr, nil, [x.nodeID]).oneShot;
125 x.release(3);