]> git.donarmstrong.com Git - bamtools.git/blob - src/third_party/jsoncpp/json_tool.h
Merge branch 'master' of git://github.com/pezmaster31/bamtools
[bamtools.git] / src / third_party / jsoncpp / json_tool.h
1 // Copyright 2007-2010 Baptiste Lepilleur
2 // Distributed under MIT license, or public domain if desired and
3 // recognized in your jurisdiction.
4 // See file LICENSE for detail or copy at http://jsoncpp.sourceforge.net/LICENSE
5
6 #ifndef LIB_JSONCPP_JSON_TOOL_H_INCLUDED
7 # define LIB_JSONCPP_JSON_TOOL_H_INCLUDED
8
9 /* This header provides common string manipulation support, such as UTF-8,
10  * portable conversion from/to string...
11  *
12  * It is an internal header that must not be exposed.
13  */
14
15 namespace Json {
16
17 /// Converts a unicode code-point to UTF-8.
18 static inline std::string 
19 codePointToUTF8(unsigned int cp)
20 {
21    std::string result;
22    
23    // based on description from http://en.wikipedia.org/wiki/UTF-8
24
25    if (cp <= 0x7f) 
26    {
27       result.resize(1);
28       result[0] = static_cast<char>(cp);
29    } 
30    else if (cp <= 0x7FF) 
31    {
32       result.resize(2);
33       result[1] = static_cast<char>(0x80 | (0x3f & cp));
34       result[0] = static_cast<char>(0xC0 | (0x1f & (cp >> 6)));
35    } 
36    else if (cp <= 0xFFFF) 
37    {
38       result.resize(3);
39       result[2] = static_cast<char>(0x80 | (0x3f & cp));
40       result[1] = 0x80 | static_cast<char>((0x3f & (cp >> 6)));
41       result[0] = 0xE0 | static_cast<char>((0xf & (cp >> 12)));
42    }
43    else if (cp <= 0x10FFFF) 
44    {
45       result.resize(4);
46       result[3] = static_cast<char>(0x80 | (0x3f & cp));
47       result[2] = static_cast<char>(0x80 | (0x3f & (cp >> 6)));
48       result[1] = static_cast<char>(0x80 | (0x3f & (cp >> 12)));
49       result[0] = static_cast<char>(0xF0 | (0x7 & (cp >> 18)));
50    }
51
52    return result;
53 }
54
55
56 /// Returns true if ch is a control character (in range [0,32[).
57 static inline bool 
58 isControlCharacter(char ch)
59 {
60    return ch > 0 && ch <= 0x1F;
61 }
62
63
64 enum { 
65    /// Constant that specify the size of the buffer that must be passed to uintToString.
66    uintToStringBufferSize = 3*sizeof(UInt)+1 
67 };
68
69 // Defines a char buffer for use with uintToString().
70 typedef char UIntToStringBuffer[uintToStringBufferSize];
71
72
73 /** Converts an unsigned integer to string.
74  * @param value Unsigned interger to convert to string
75  * @param current Input/Output string buffer. 
76  *        Must have at least uintToStringBufferSize chars free.
77  */
78 static inline void 
79 uintToString( UInt value, 
80               char *&current )
81 {
82    *--current = 0;
83    do
84    {
85       *--current = char(value % 10) + '0';
86       value /= 10;
87    }
88    while ( value != 0 );
89 }
90
91 } // namespace Json {
92
93 #endif // LIB_JSONCPP_JSON_TOOL_H_INCLUDED