| Real Time Open Sound Control librtosc
    | 
Functions handling messages and arguments. More...
#include <stdarg.h>#include <stdint.h>#include <stddef.h>#include <stdbool.h>Go to the source code of this file.
| Classes | |
| struct | rtosc_blob_t | 
| struct | array_start_t | 
| arg val element indicating an array, or a block of "nothing" blocks of "nothing" are just for internal use and indicate that the following array_start_t::len blocks must be ignored (they can contain rubbish)  More... | |
| struct | repeater_t | 
| a repeater is being followed by a delta argument (unless has_delta is 0)  More... | |
| struct | nothing_t | 
| indicates that the next nothing_t::len blocks count as if nonexistant they might contain rubbish  More... | |
| union | rtosc_arg_t | 
| struct | rtosc_arg_val_t | 
| struct | rtosc_arg_itr_t | 
| struct | rtosc_cmp_options | 
| struct | rtosc_arg_val_itr | 
| Iterator over arg values.  More... | |
| struct | rtosc_va_list_t | 
| va_list container, required for passing va_list as pointers to functions  More... | |
| struct | ring_t | 
| Functions | |
| size_t | rtosc_message (char *buffer, size_t len, const char *address, const char *arguments,...) | 
| Write OSC message to fixed length buffer. | |
| size_t | rtosc_vmessage (char *buffer, size_t len, const char *address, const char *arguments, va_list va) | 
| size_t | rtosc_avmessage (char *buffer, size_t len, const char *address, size_t nargs, const rtosc_arg_val_t *args) | 
| size_t | rtosc_amessage (char *buffer, size_t len, const char *address, const char *arguments, const rtosc_arg_t *args) | 
| unsigned | rtosc_narguments (const char *msg) | 
| Returns the number of arguments found in a given message. | |
| char | rtosc_type (const char *msg, unsigned i) | 
| void | rtosc_arg_val_itr_init (rtosc_arg_val_itr *itr, const rtosc_arg_val_t *av) | 
| const rtosc_arg_val_t * | rtosc_arg_val_itr_get (const rtosc_arg_val_itr *itr, rtosc_arg_val_t *buffer) | 
| this usually just returns the value from operand, except for range operands, where the value is being interpolated | |
| void | rtosc_arg_val_itr_next (rtosc_arg_val_itr *itr) | 
| void | rtosc_v2args (rtosc_arg_t *args, size_t nargs, const char *arg_str, rtosc_va_list_t *ap) | 
| Pack arguments into pre-allocated rtosc_arg_t array. | |
| void | rtosc_v2argvals (rtosc_arg_val_t *args, size_t nargs, const char *arg_str, va_list ap) | 
| Pack parameters into pre-allocated rtosc_arg_val-t array. | |
| void | rtosc_2argvals (rtosc_arg_val_t *args, size_t nargs, const char *arg_str,...) | 
| Pack parameters into pre-allocated rtosc_arg_val-t array. | |
| rtosc_arg_itr_t | rtosc_itr_begin (const char *msg) | 
| Create an argument iterator for a message. | |
| rtosc_arg_val_t | rtosc_itr_next (rtosc_arg_itr_t *itr) | 
| Gets the next argument in a message. | |
| int | rtosc_itr_end (rtosc_arg_itr_t itr) | 
| Determines if the iterator is at the end of the argument list. | |
| rtosc_arg_t | rtosc_argument (const char *msg, unsigned i) | 
| Blob data may be safely written to. | |
| size_t | rtosc_message_length (const char *msg, size_t len) | 
| size_t | rtosc_message_ring_length (ring_t *ring) | 
| Finds the length of the next message inside a ringbuffer structure. | |
| bool | rtosc_valid_message_p (const char *msg, size_t len) | 
| Validate if an arbitrary byte sequence is an OSC message. | |
| const char * | rtosc_argument_string (const char *msg) | 
| size_t | rtosc_bundle (char *buffer, size_t len, uint64_t tt, int elms,...) | 
| Generate a bundle from sub-messages. | |
| size_t | rtosc_bundle_elements (const char *msg, size_t len) | 
| Find the elements in a bundle. | |
| const char * | rtosc_bundle_fetch (const char *msg, unsigned i) | 
| Fetch a message within the bundle. | |
| size_t | rtosc_bundle_size (const char *msg, unsigned i) | 
| Get the size of a particular bundle element. | |
| int | rtosc_bundle_p (const char *msg) | 
| Test if the buffer contains a bundle. | |
| uint64_t | rtosc_bundle_timetag (const char *msg) | 
| bool | rtosc_match (const char *pattern, const char *msg, const char **path_end) | 
| This is a non-compliant pattern matcher for dispatching OSC messages. | |
| const char * | rtosc_match_path (const char *pattern, const char *msg, const char **path_end) | 
| Attempt to match a rtosc style path while ignoring arguments. | |
Functions handling messages and arguments.
| void rtosc_2argvals | ( | rtosc_arg_val_t * | args, | 
| size_t | nargs, | ||
| const char * | arg_str, | ||
| ... ) | 
Pack parameters into pre-allocated rtosc_arg_val-t array.
| size_t rtosc_amessage | ( | char * | buffer, | 
| size_t | len, | ||
| const char * | address, | ||
| const char * | arguments, | ||
| const rtosc_arg_t * | args ) | 
| const rtosc_arg_val_t * rtosc_arg_val_itr_get | ( | const rtosc_arg_val_itr * | itr, | 
| rtosc_arg_val_t * | buffer ) | 
this usually just returns the value from operand, except for range operands, where the value is being interpolated
| buffer | Temporary. Don't access it afterwards. | 
| void rtosc_arg_val_itr_next | ( | rtosc_arg_val_itr * | itr | ) | 
| rtosc_arg_t rtosc_argument | ( | const char * | msg, | 
| unsigned | i ) | 
Blob data may be safely written to.
| msg | OSC message | 
| i | index of argument | 
| const char * rtosc_argument_string | ( | const char * | msg | ) | 
| msg | OSC message | 
| size_t rtosc_avmessage | ( | char * | buffer, | 
| size_t | len, | ||
| const char * | address, | ||
| size_t | nargs, | ||
| const rtosc_arg_val_t * | args ) | 
| size_t rtosc_bundle | ( | char * | buffer, | 
| size_t | len, | ||
| uint64_t | tt, | ||
| int | elms, | ||
| ... ) | 
Generate a bundle from sub-messages.
| buffer | Destination buffer | 
| len | Length of buffer | 
| tt | OSC time tag | 
| elms | Number of sub messages | 
| ... | Messages | 
| size_t rtosc_bundle_elements | ( | const char * | msg, | 
| size_t | len ) | 
Find the elements in a bundle.
| msg | OSC bundle | 
| len | Upper bound on the length of the bundle | 
| const char * rtosc_bundle_fetch | ( | const char * | msg, | 
| unsigned | i ) | 
Fetch a message within the bundle.
| msg | OSC bundle | 
| i | index of sub-message | 
| int rtosc_bundle_p | ( | const char * | msg | ) | 
Test if the buffer contains a bundle.
| msg | OSC message | 
| size_t rtosc_bundle_size | ( | const char * | msg, | 
| unsigned | i ) | 
Get the size of a particular bundle element.
| msg | OSC bundle | 
| i | Index of sub-message | 
| uint64_t rtosc_bundle_timetag | ( | const char * | msg | ) | 
| rtosc_arg_itr_t rtosc_itr_begin | ( | const char * | msg | ) | 
Create an argument iterator for a message.
| msg | OSC message | 
| int rtosc_itr_end | ( | rtosc_arg_itr_t | itr | ) | 
Determines if the iterator is at the end of the argument list.
| itr | OSC message iterator | 
| rtosc_arg_val_t rtosc_itr_next | ( | rtosc_arg_itr_t * | itr | ) | 
Gets the next argument in a message.
| itr | OSC message iterator | 
| bool rtosc_match | ( | const char * | pattern, | 
| const char * | msg, | ||
| const char ** | path_end ) | 
This is a non-compliant pattern matcher for dispatching OSC messages.
Overall the pattern specification is (normal-path)(#digit-specifier)?(/)?(:argument-restrictor)*
| pattern | The pattern string stored in the Port | 
| msg | The OSC message to be matched | 
| path_end | if non-NULL, will point to where parsing stopped in the path (in case of a match, *path_end is always '/' or '\0') | 
| const char * rtosc_match_path | ( | const char * | pattern, | 
| const char * | msg, | ||
| const char ** | path_end ) | 
Attempt to match a rtosc style path while ignoring arguments.
| pattern | rtosc pattern | 
| msg | a normal C string or a rtosc message | 
| path_end | if non-NULL, will point to where parsing stopped in the path (in case of a match, *path_end is always '/' or '\0') | 
| size_t rtosc_message | ( | char * | buffer, | 
| size_t | len, | ||
| const char * | address, | ||
| const char * | arguments, | ||
| ... ) | 
Write OSC message to fixed length buffer.
On error, buffer will be zeroed. When buffer is NULL, the function returns the size of the buffer required to store the message
| buffer | Memory to write to | 
| len | Length of buffer | 
| address | OSC pattern to send message to | 
| arguments | String consisting of the types of the following arguments | 
| ... | OSC arguments to pass forward | 
| size_t rtosc_message_length | ( | const char * | msg, | 
| size_t | len ) | 
| msg | OSC message | 
| len | Message length upper bound | 
| size_t rtosc_message_ring_length | ( | ring_t * | ring | ) | 
Finds the length of the next message inside a ringbuffer structure.
| ring | The addresses and lengths of the split buffer, in a compatible format to jack's ringbuffer | 
| unsigned rtosc_narguments | ( | const char * | msg | ) | 
Returns the number of arguments found in a given message.
| msg | well formed OSC message | 
| char rtosc_type | ( | const char * | msg, | 
| unsigned | i ) | 
| msg | well formed OSC message | 
| i | index of argument | 
| void rtosc_v2args | ( | rtosc_arg_t * | args, | 
| size_t | nargs, | ||
| const char * | arg_str, | ||
| rtosc_va_list_t * | ap ) | 
Pack arguments into pre-allocated rtosc_arg_t array.
| args | Pre-allocated array; size must be greater or equal nargs | 
| nargs | Size of elements to pack | 
| arg_str | Rtosc string specifying the arguments' types | 
| ap | The parameters that shall be packed | 
| void rtosc_v2argvals | ( | rtosc_arg_val_t * | args, | 
| size_t | nargs, | ||
| const char * | arg_str, | ||
| va_list | ap ) | 
Pack parameters into pre-allocated rtosc_arg_val-t array.
| bool rtosc_valid_message_p | ( | const char * | msg, | 
| size_t | len ) | 
Validate if an arbitrary byte sequence is an OSC message.
| msg | pointer to memory buffer | 
| len | length of buffer | 
| size_t rtosc_vmessage | ( | char * | buffer, | 
| size_t | len, | ||
| const char * | address, | ||
| const char * | arguments, | ||
| va_list | va ) |