~antti-silvast/lives/opengl-fx

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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/*
Copyright © 1998. The Regents of the University of California (Regents). 
All Rights Reserved.

Written by Matt Wright, The Center for New Music and Audio Technologies,
University of California, Berkeley.

Permission to use, copy, modify, distribute, and distribute modified versions
of this software and its documentation without fee and without a signed
licensing agreement, is hereby granted, provided that the above copyright
notice, this paragraph and the following two paragraphs appear in all copies,
modifications, and distributions.

IN NO EVENT SHALL REGENTS BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT,
SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, ARISING
OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF REGENTS HAS
BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

REGENTS SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE. THE SOFTWARE AND ACCOMPANYING DOCUMENTATION, IF ANY, PROVIDED
HEREUNDER IS PROVIDED "AS IS". REGENTS HAS NO OBLIGATION TO PROVIDE
MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.

The OpenSound Control WWW page is 
    http://www.cnmat.berkeley.edu/OpenSoundControl
*/


/* OSC-internal-messages.h

   Interface for having an application send OSC messages to itself
   internally.

   All these procedures return FALSE if unable to deliver the message.

   Matt Wright, 3/17/98

*/

/* Send a message immediately, with no return address.  This procedure
   returns after the message has been sent (or has failed to be sent),
   so the memory for address and args can be on the stack.  Returns FALSE
   if there's a problem; TRUE otherwise. */
Boolean OSCSendInternalMessage(char *address, int arglen, void *args);


/* Same thing, but with a return address supplied. */
Boolean OSCSendInternalMessageWithRSVP(char *address, int arglen,  void *args, 
				       NetworkReturnAddressPtr returnAddr);


/* Schedule some messages to occur at a given time.  This allocates one of the
   OSCPacketBuffer structures (see OSC-receive.h) to hold the addresses and argument
   data until the messages take effect, so if you're going to call this, you
   should take this use of packets into account in setting the
   numReceiveBuffers argument to OSCInitReceive().

   This provides an less general interface than OSC's bundle mechanism, because
   the bundle of messages you provide cannot include subbundles. 

   The addresses, arglens, and args arguments are arrays of size numMessages.

   There's no return address argument because you're not allowed to save a network
   return address for later use.
*/

Boolean OSCScheduleInternalMessages(OSCTimeTag when, int numMessages, 
				    char **addresses, int *arglens,
				    void **args);