Merge branch 'master' of https://code.grnet.gr/git/pithos-ios
[pithos-ios] / Classes / NSString+SBJSON.h
1 /*
2  Copyright (C) 2009 Stig Brautaset. All rights reserved.
3  
4  Redistribution and use in source and binary forms, with or without
5  modification, are permitted provided that the following conditions are met:
6  
7  * Redistributions of source code must retain the above copyright notice, this
8    list of conditions and the following disclaimer.
9  
10  * Redistributions in binary form must reproduce the above copyright notice,
11    this list of conditions and the following disclaimer in the documentation
12    and/or other materials provided with the distribution.
13  
14  * Neither the name of the author nor the names of its contributors may be used
15    to endorse or promote products derived from this software without specific
16    prior written permission.
17  
18  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
21  DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
22  FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23  DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
24  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
25  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
26  OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28  */
29
30 #import <Foundation/Foundation.h>
31
32 /**
33  @brief Adds JSON parsing methods to NSString
34  
35 This is a category on NSString that adds methods for parsing the target string.
36 */
37 @interface NSString (NSString_SBJSON)
38
39
40 /**
41  @brief Returns the object represented in the receiver, or nil on error. 
42  
43  Returns a a scalar object represented by the string's JSON fragment representation.
44  
45  @deprecated Given we bill ourselves as a "strict" JSON library, this method should be removed.
46  */
47 - (id)JSONFragmentValue;
48
49 /**
50  @brief Returns the NSDictionary or NSArray represented by the current string's JSON representation.
51  
52  Returns the dictionary or array represented in the receiver, or nil on error.
53
54  Returns the NSDictionary or NSArray represented by the current string's JSON representation.
55  */
56 - (id)JSONValue;
57
58 @end