/
CPValue.j
113 lines (95 loc) · 2.75 KB
/
CPValue.j
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*
* CPValue.j
* Foundation
*
* Created by Francisco Tolmasky.
* Copyright 2008, 280 North, Inc.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
@import "CPCoder.j"
@import "CPObject.j"
/*!
@class CPValue
@ingroup foundation
@brief A generic "value". Can be subclassed to hold specific data types.
The class can be subclassed to hold different types of scalar values.
*/
@implementation CPValue : CPObject
{
JSObject _JSObject;
}
/*!
Creates a value from the specified JavaScript object
@param aJSObject a JavaScript object containing a value
@return the converted CPValue
*/
+ (id)valueWithJSObject:(JSObject)aJSObject
{
return [[self alloc] initWithJSObject:aJSObject];
}
/*!
Initializes the value from a JavaScript object
@param aJSObject the object to get data from
@return the initialized CPValue
*/
- (id)initWithJSObject:(JSObject)aJSObject
{
self = [super init];
if (self)
_JSObject = aJSObject;
return self;
}
/*!
Returns the JavaScript object backing this value.
*/
- (JSObject)JSObject
{
return _JSObject;
}
@end
var CPValueValueKey = @"CPValueValueKey";
@implementation CPValue (CPCoding)
/*!
Initializes the value from a coder.
@param aCoder the coder from which to initialize
@return the initialized CPValue
*/
- (id)initWithCoder:(CPCoder)aCoder
{
self = [super init];
if (self)
_JSObject = JSON.parse([aCoder decodeObjectForKey:CPValueValueKey]);
return self;
}
/*!
Encodes the data into the specified coder.
@param the coder into which the data will be written.
*/
- (void)encodeWithCoder:(CPCoder)aCoder
{
[aCoder encodeObject:JSON.stringify(_JSObject) forKey:CPValueValueKey];
}
@end
function CPJSObjectCreateJSON(aJSObject)
{
CPLog.warn("CPJSObjectCreateJSON deprecated, use JSON.stringify() or CPString's objectFromJSON");
return JSON.stringify(aJSObject);
}
function CPJSObjectCreateWithJSON(aString)
{
CPLog.warn("CPJSObjectCreateWithJSON deprecated, use JSON.parse() or CPString's JSONFromObject");
return JSON.parse(aString);
}