forked from Figure53/F53OSC
-
Notifications
You must be signed in to change notification settings - Fork 7
/
F53OSCMessage.h
executable file
·67 lines (59 loc) · 2.99 KB
/
F53OSCMessage.h
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
//
// F53OSCMessage.h
//
// Created by Sean Dougall on 1/17/11.
//
// Copyright (c) 2011-2013 Figure 53 LLC, http://figure53.com
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
//
#import <Foundation/Foundation.h>
#import "F53OSCPacket.h"
///
/// Example usage:
///
/// F53OSCMessage *msg = [F53OSCMessage messageWithAddressPattern:@"/address/of/thing"
/// arguments:[NSArray arrayWithObjects:
/// [NSNumber numberWithInteger:x],
/// [NSNumber numberWithFloat:y],
/// @"z",
/// nil]];
///
@interface F53OSCMessage : F53OSCPacket <NSCoding, NSCopying>
{
NSString *_addressPattern;
NSString *_typeTagString;
NSArray *_arguments;
id _userData;
}
+ (BOOL) legalAddressComponent:(NSString *)addressComponent;
+ (BOOL) legalAddress:(NSString *)address;
+ (BOOL) legalMethod:(NSString *)method;
+ (F53OSCMessage *) messageWithString:(NSString *)string;
+ (F53OSCMessage *) messageWithAddressPattern:(NSString *)addressPattern
arguments:(NSArray *)arguments;
+ (F53OSCMessage *) messageWithAddressPattern:(NSString *)addressPattern
arguments:(NSArray *)arguments
replySocket:(F53OSCSocket *)replySocket;
@property (nonatomic, copy) NSString *addressPattern;
@property (nonatomic, retain) NSString *typeTagString; ///< This is normally constructed from the incoming arguments array.
@property (nonatomic, retain) NSArray *arguments; ///< May contain NSString, NSData, or NSNumber objects. This could be extended in the future, but those three cover the four mandatory OSC types.
@property (nonatomic, retain) id userData;
- (NSArray *) addressParts;
@end