root / docs / www / colonyscout / internal / includes / uploadify / com / adobe / serialization / json / JSON.as @ f59acf11
History | View | Annotate | Download (2.7 KB)
1 |
/* |
---|---|
2 |
Copyright (c) 2008, Adobe Systems Incorporated |
3 |
All rights reserved. |
4 |
|
5 |
Redistribution and use in source and binary forms, with or without |
6 |
modification, are permitted provided that the following conditions are |
7 |
met: |
8 |
|
9 |
* Redistributions of source code must retain the above copyright notice, |
10 |
this list of conditions and the following disclaimer. |
11 |
|
12 |
* Redistributions in binary form must reproduce the above copyright |
13 |
notice, this list of conditions and the following disclaimer in the |
14 |
documentation and/or other materials provided with the distribution. |
15 |
|
16 |
* Neither the name of Adobe Systems Incorporated nor the names of its |
17 |
contributors may be used to endorse or promote products derived from |
18 |
this software without specific prior written permission. |
19 |
|
20 |
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS |
21 |
IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, |
22 |
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
23 |
PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR |
24 |
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
25 |
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
26 |
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
27 |
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF |
28 |
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |
29 |
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
30 |
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
31 |
*/ |
32 |
|
33 |
package com.adobe.serialization.json { |
34 |
|
35 |
/** |
36 |
* This class provides encoding and decoding of the JSON format. |
37 |
* |
38 |
* Example usage: |
39 |
* <code> |
40 |
* // create a JSON string from an internal object |
41 |
* JSON.encode( myObject ); |
42 |
* |
43 |
* // read a JSON string into an internal object |
44 |
* var myObject:Object = JSON.decode( jsonString ); |
45 |
* </code> |
46 |
*/ |
47 |
public class JSON { |
48 |
|
49 |
|
50 |
/** |
51 |
* Encodes a object into a JSON string. |
52 |
* |
53 |
* @param o The object to create a JSON string for |
54 |
* @return the JSON string representing o |
55 |
* @langversion ActionScript 3.0 |
56 |
* @playerversion Flash 9.0 |
57 |
* @tiptext |
58 |
*/ |
59 |
public static function encode( o:Object ):String { |
60 |
|
61 |
var encoder:JSONEncoder = new JSONEncoder( o ); |
62 |
return encoder.getString(); |
63 |
|
64 |
} |
65 |
|
66 |
/** |
67 |
* Decodes a JSON string into a native object. |
68 |
* |
69 |
* @param s The JSON string representing the object |
70 |
* @return A native object as specified by s |
71 |
* @throw JSONParseError |
72 |
* @langversion ActionScript 3.0 |
73 |
* @playerversion Flash 9.0 |
74 |
* @tiptext |
75 |
*/ |
76 |
public static function decode( s:String ):* { |
77 |
|
78 |
var decoder:JSONDecoder = new JSONDecoder( s ) |
79 |
return decoder.getValue(); |
80 |
|
81 |
} |
82 |
|
83 |
} |
84 |
|
85 |
} |