wp/wp-includes/class-json.php
author ymh <ymh.work@gmail.com>
Wed, 06 Nov 2013 03:21:17 +0000
changeset 0 d970ebf37754
child 7 cf61fcea0001
permissions -rw-r--r--
first import
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
if ( ! class_exists( 'Services_JSON' ) ) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * Converts to and from JSON format.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 * JSON (JavaScript Object Notation) is a lightweight data-interchange
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
 * format. It is easy for humans to read and write. It is easy for machines
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
 * to parse and generate. It is based on a subset of the JavaScript
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
 * Programming Language, Standard ECMA-262 3rd Edition - December 1999.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
 * This feature can also be found in  Python. JSON is a text format that is
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
 * completely language independent but uses conventions that are familiar
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
 * to programmers of the C-family of languages, including C, C++, C#, Java,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
 * JavaScript, Perl, TCL, and many others. These properties make JSON an
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
 * ideal data-interchange language.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
 * This package provides a simple encoder and decoder for JSON notation. It
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
 * is intended for use with client-side Javascript applications that make
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
 * use of HTTPRequest to perform server communication functions - data can
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
 * be encoded into JSON notation for use in a client-side javascript, or
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
 * decoded from incoming Javascript requests. JSON format is native to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
 * Javascript, and can be directly eval()'ed with no further parsing
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
 * overhead
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
 * All strings should be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
 * LICENSE: Redistribution and use in source and binary forms, with or
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
 * without modification, are permitted provided that the following
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
 * conditions are met: Redistributions of source code must retain the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
 * above copyright notice, this list of conditions and the following
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
 * disclaimer. Redistributions in binary form must reproduce the above
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
 * copyright notice, this list of conditions and the following disclaimer
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
 * in the documentation and/or other materials provided with the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
 * distribution.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
 * NO EVENT SHALL CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
 * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
 * DAMAGE.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
 * @category
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
 * @package     Services_JSON
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
 * @author      Michal Migurski <mike-json@teczno.com>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
 * @author      Matt Knapp <mdknapp[at]gmail[dot]com>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
 * @author      Brett Stimmerman <brettstimmerman[at]gmail[dot]com>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
 * @copyright   2005 Michal Migurski
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
 * @version     CVS: $Id: JSON.php 305040 2010-11-02 23:19:03Z alan_k $
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
 * @license     http://www.opensource.org/licenses/bsd-license.php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
 * @link        http://pear.php.net/pepr/pepr-proposal-show.php?id=198
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
 * Marker constant for Services_JSON::decode(), used to flag stack state
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
define('SERVICES_JSON_SLICE',   1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
 * Marker constant for Services_JSON::decode(), used to flag stack state
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
define('SERVICES_JSON_IN_STR',  2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
 * Marker constant for Services_JSON::decode(), used to flag stack state
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
define('SERVICES_JSON_IN_ARR',  3);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
 * Marker constant for Services_JSON::decode(), used to flag stack state
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
define('SERVICES_JSON_IN_OBJ',  4);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
 * Marker constant for Services_JSON::decode(), used to flag stack state
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
define('SERVICES_JSON_IN_CMT', 5);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
 * Behavior switch for Services_JSON::decode()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
define('SERVICES_JSON_LOOSE_TYPE', 16);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
 * Behavior switch for Services_JSON::decode()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
define('SERVICES_JSON_SUPPRESS_ERRORS', 32);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
 * Behavior switch for Services_JSON::decode()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
define('SERVICES_JSON_USE_TO_JSON', 64);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
 * Converts to and from JSON format.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
 * Brief example of use:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
 * <code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
 * // create a new instance of Services_JSON
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
 * $json = new Services_JSON();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
 * // convert a complexe value to JSON notation, and send it to the browser
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
 * $value = array('foo', 'bar', array(1, 2, 'baz'), array(3, array(4)));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
 * $output = $json->encode($value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
 * print($output);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
 * // prints: ["foo","bar",[1,2,"baz"],[3,[4]]]
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
 * // accept incoming POST data, assumed to be in JSON notation
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
 * $input = file_get_contents('php://input', 1000000);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
 * $value = $json->decode($input);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
 * </code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
class Services_JSON
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
{
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
    * constructs a new JSON instance
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
    * @param    int     $use    object behavior flags; combine with boolean-OR
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
    *                           possible values:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
    *                           - SERVICES_JSON_LOOSE_TYPE:  loose typing.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
    *                                   "{...}" syntax creates associative arrays
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
    *                                   instead of objects in decode().
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
    *                           - SERVICES_JSON_SUPPRESS_ERRORS:  error suppression.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
    *                                   Values which can't be encoded (e.g. resources)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
    *                                   appear as NULL instead of throwing errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
    *                                   By default, a deeply-nested resource will
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
    *                                   bubble up with an error, so all return values
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
    *                                   from encode() should be checked with isError()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
    *                           - SERVICES_JSON_USE_TO_JSON:  call toJSON when serializing objects
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
    *                                   It serializes the return value from the toJSON call rather 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
    *                                   than the object it'self,  toJSON can return associative arrays, 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
    *                                   strings or numbers, if you return an object, make sure it does
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
    *                                   not have a toJSON method, otherwise an error will occur.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
    function Services_JSON($use = 0)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
        $this->use = $use;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
        $this->_mb_strlen            = function_exists('mb_strlen');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
        $this->_mb_convert_encoding  = function_exists('mb_convert_encoding');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
        $this->_mb_substr            = function_exists('mb_substr');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
    // private - cache the mbstring lookup results..
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
    var $_mb_strlen = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
    var $_mb_substr = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
    var $_mb_convert_encoding = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
    * convert a string from one UTF-16 char to one UTF-8 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
    * Normally should be handled by mb_convert_encoding, but
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
    * provides a slower PHP-only method for installations
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
    * that lack the multibye string extension.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
    * @param    string  $utf16  UTF-16 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
    * @return   string  UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
    function utf162utf8($utf16)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
        // oh please oh please oh please oh please oh please
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
        if($this->_mb_convert_encoding) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
            return mb_convert_encoding($utf16, 'UTF-8', 'UTF-16');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
        $bytes = (ord($utf16{0}) << 8) | ord($utf16{1});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
        switch(true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
            case ((0x7F & $bytes) == $bytes):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
                // this case should never be reached, because we are in ASCII range
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
                return chr(0x7F & $bytes);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
            case (0x07FF & $bytes) == $bytes:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
                // return a 2-byte UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
                return chr(0xC0 | (($bytes >> 6) & 0x1F))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
                     . chr(0x80 | ($bytes & 0x3F));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
            case (0xFFFF & $bytes) == $bytes:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
                // return a 3-byte UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
                return chr(0xE0 | (($bytes >> 12) & 0x0F))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
                     . chr(0x80 | (($bytes >> 6) & 0x3F))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
                     . chr(0x80 | ($bytes & 0x3F));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
        // ignoring UTF-32 for now, sorry
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
        return '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
    * convert a string from one UTF-8 char to one UTF-16 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
    * Normally should be handled by mb_convert_encoding, but
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
    * provides a slower PHP-only method for installations
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
    * that lack the multibye string extension.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
    * @param    string  $utf8   UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
    * @return   string  UTF-16 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
    function utf82utf16($utf8)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
        // oh please oh please oh please oh please oh please
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
        if($this->_mb_convert_encoding) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
            return mb_convert_encoding($utf8, 'UTF-16', 'UTF-8');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
        switch($this->strlen8($utf8)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
            case 1:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
                // this case should never be reached, because we are in ASCII range
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
                return $utf8;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
            case 2:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
                // return a UTF-16 character from a 2-byte UTF-8 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
                return chr(0x07 & (ord($utf8{0}) >> 2))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
                     . chr((0xC0 & (ord($utf8{0}) << 6))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
                         | (0x3F & ord($utf8{1})));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
            case 3:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
                // return a UTF-16 character from a 3-byte UTF-8 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
                return chr((0xF0 & (ord($utf8{0}) << 4))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
                         | (0x0F & (ord($utf8{1}) >> 2)))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
                     . chr((0xC0 & (ord($utf8{1}) << 6))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
                         | (0x7F & ord($utf8{2})));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
        // ignoring UTF-32 for now, sorry
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
        return '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
    * encodes an arbitrary variable into JSON format (and sends JSON Header)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
    *                           see argument 1 to Services_JSON() above for array-parsing behavior.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
    *                           if var is a strng, note that encode() always expects it
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
    * @return   mixed   JSON string representation of input var or an error if a problem occurs
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
    function encode($var)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
        header('Content-type: application/json');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
        return $this->encodeUnsafe($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
    * encodes an arbitrary variable into JSON format without JSON Header - warning - may allow XSS!!!!)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
    *                           see argument 1 to Services_JSON() above for array-parsing behavior.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
    *                           if var is a strng, note that encode() always expects it
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
    * @return   mixed   JSON string representation of input var or an error if a problem occurs
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
    function encodeUnsafe($var)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
        // see bug #16908 - regarding numeric locale printing
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
        $lc = setlocale(LC_NUMERIC, 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
        setlocale(LC_NUMERIC, 'C');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
        $ret = $this->_encode($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
        setlocale(LC_NUMERIC, $lc);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
        return $ret;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
        
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
    * PRIVATE CODE that does the work of encodes an arbitrary variable into JSON format 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
    *                           see argument 1 to Services_JSON() above for array-parsing behavior.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
    *                           if var is a strng, note that encode() always expects it
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
    * @return   mixed   JSON string representation of input var or an error if a problem occurs
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
    function _encode($var) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
         
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
        switch (gettype($var)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
            case 'boolean':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
                return $var ? 'true' : 'false';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
            case 'NULL':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
                return 'null';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
            case 'integer':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
                return (int) $var;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
            case 'double':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
            case 'float':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
                return  (float) $var;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
            case 'string':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
                // STRINGS ARE EXPECTED TO BE IN ASCII OR UTF-8 FORMAT
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
                $ascii = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
                $strlen_var = $this->strlen8($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
               /*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
                * Iterate over every character in the string,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
                * escaping with a slash or encoding to UTF-8 where necessary
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
                */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
                for ($c = 0; $c < $strlen_var; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
                    $ord_var_c = ord($var{$c});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
                    switch (true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
                        case $ord_var_c == 0x08:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
                            $ascii .= '\b';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
                        case $ord_var_c == 0x09:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
                            $ascii .= '\t';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
                        case $ord_var_c == 0x0A:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
                            $ascii .= '\n';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
                        case $ord_var_c == 0x0C:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
                            $ascii .= '\f';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
                        case $ord_var_c == 0x0D:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
                            $ascii .= '\r';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   337
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
                        case $ord_var_c == 0x22:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
                        case $ord_var_c == 0x2F:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
                        case $ord_var_c == 0x5C:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
                            // double quote, slash, slosh
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
                            $ascii .= '\\'.$var{$c};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
                        case (($ord_var_c >= 0x20) && ($ord_var_c <= 0x7F)):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
                            // characters U-00000000 - U-0000007F (same as ASCII)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
                            $ascii .= $var{$c};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
                        case (($ord_var_c & 0xE0) == 0xC0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
                            // characters U-00000080 - U-000007FF, mask 110XXXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
                            if ($c+1 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
                                $c += 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
                            
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
                            $char = pack('C*', $ord_var_c, ord($var{$c + 1}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
                            $c += 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   364
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   365
                        case (($ord_var_c & 0xF0) == 0xE0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
                            if ($c+2 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
                                $c += 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
                            // characters U-00000800 - U-0000FFFF, mask 1110XXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
                            $char = pack('C*', $ord_var_c,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
                                         @ord($var{$c + 1}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
                                         @ord($var{$c + 2}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
                            $c += 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
                        case (($ord_var_c & 0xF8) == 0xF0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
                            if ($c+3 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
                                $c += 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
                            // characters U-00010000 - U-001FFFFF, mask 11110XXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
                            $char = pack('C*', $ord_var_c,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
                                         ord($var{$c + 1}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
                                         ord($var{$c + 2}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   392
                                         ord($var{$c + 3}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
                            $c += 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   394
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
                        case (($ord_var_c & 0xFC) == 0xF8):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
                            // characters U-00200000 - U-03FFFFFF, mask 111110XX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
                            if ($c+4 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
                                $c += 4;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
                            $char = pack('C*', $ord_var_c,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
                                         ord($var{$c + 1}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
                                         ord($var{$c + 2}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
                                         ord($var{$c + 3}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
                                         ord($var{$c + 4}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
                            $c += 4;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
                        case (($ord_var_c & 0xFE) == 0xFC):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
                        if ($c+5 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   419
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
                            // characters U-04000000 - U-7FFFFFFF, mask 1111110X
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
                            $char = pack('C*', $ord_var_c,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
                                         ord($var{$c + 1}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
                                         ord($var{$c + 2}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
                                         ord($var{$c + 3}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
                                         ord($var{$c + 4}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
                                         ord($var{$c + 5}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
                            $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
                return  '"'.$ascii.'"';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   437
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
            case 'array':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
               /*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
                * As per JSON spec if any array key is not an integer
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   441
                * we must treat the the whole array as an object. We
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
                * also try to catch a sparsely populated associative
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
                * array with numeric keys here because some JS engines
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
                * will create an array with empty indexes up to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
                * max_index which can cause memory issues and because
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
                * the keys, which may be relevant, will be remapped
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
                * otherwise.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
                *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
                * As per the ECMA and JSON specification an object may
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
                * have any string as a property. Unfortunately due to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
                * a hole in the ECMA specification if the key is a
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   452
                * ECMA reserved word or starts with a digit the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
                * parameter is only accessible using ECMAScript's
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   454
                * bracket notation.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
                */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
                // treat as a JSON object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
                if (is_array($var) && count($var) && (array_keys($var) !== range(0, sizeof($var) - 1))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
                    $properties = array_map(array($this, 'name_value'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
                                            array_keys($var),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
                                            array_values($var));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
                    foreach($properties as $property) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
                        if(Services_JSON::isError($property)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
                            return $property;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
                    return '{' . join(',', $properties) . '}';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
                // treat it like a regular array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
                $elements = array_map(array($this, '_encode'), $var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
                foreach($elements as $element) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
                    if(Services_JSON::isError($element)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
                        return $element;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
                return '[' . join(',', $elements) . ']';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
            case 'object':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
            
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
                // support toJSON methods.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
                if (($this->use & SERVICES_JSON_USE_TO_JSON) && method_exists($var, 'toJSON')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
                    // this may end up allowing unlimited recursion
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
                    // so we check the return value to make sure it's not got the same method.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
                    $recode = $var->toJSON();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
                    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
                    if (method_exists($recode, 'toJSON')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
                        
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
                        return ($this->use & SERVICES_JSON_SUPPRESS_ERRORS)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
                        ? 'null'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
                        : new Services_JSON_Error(get_class($var).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
                            " toJSON returned an object with a toJSON method.");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
                            
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
                    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
                    return $this->_encode( $recode );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
                } 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
                $vars = get_object_vars($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
                $properties = array_map(array($this, 'name_value'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
                                        array_keys($vars),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
                                        array_values($vars));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
                foreach($properties as $property) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
                    if(Services_JSON::isError($property)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
                        return $property;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
                return '{' . join(',', $properties) . '}';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
            default:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
                return ($this->use & SERVICES_JSON_SUPPRESS_ERRORS)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
                    ? 'null'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
                    : new Services_JSON_Error(gettype($var)." can not be encoded as JSON string");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
    * array-walking function for use in generating JSON-formatted name-value pairs
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
    * @param    string  $name   name of key to use
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
    * @param    mixed   $value  reference to an array element to be encoded
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
    * @return   string  JSON-formatted name-value pair, like '"name":value'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
    function name_value($name, $value)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
        $encoded_value = $this->_encode($value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
        if(Services_JSON::isError($encoded_value)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
            return $encoded_value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
        return $this->_encode(strval($name)) . ':' . $encoded_value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
    * reduce a string by removing leading and trailing comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
    * @param    $str    string      string value to strip of comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
    * @return   string  string value stripped of comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
    function reduce_string($str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
        $str = preg_replace(array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
                // eliminate single line comments in '// ...' form
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
                '#^\s*//(.+)$#m',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
                // eliminate multi-line comments in '/* ... */' form, at start of string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
                '#^\s*/\*(.+)\*/#Us',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
                // eliminate multi-line comments in '/* ... */' form, at end of string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
                '#/\*(.+)\*/\s*$#Us'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
            ), '', $str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
        // eliminate extraneous space
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
        return trim($str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
    * decodes a JSON string into appropriate variable
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
    * @param    string  $str    JSON-formatted string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
    * @return   mixed   number, boolean, string, array, or object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
    *                   corresponding to given JSON input string.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
    *                   See argument 1 to Services_JSON() above for object-output behavior.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
    *                   Note that decode() always returns strings
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
    *                   in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
    function decode($str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
        $str = $this->reduce_string($str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
        switch (strtolower($str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
            case 'true':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
                return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
            case 'false':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
            case 'null':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
                return null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
            default:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
                $m = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
                if (is_numeric($str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
                    // Lookie-loo, it's a number
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
                    // This would work on its own, but I'm trying to be
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
                    // good about returning integers where appropriate:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
                    // return (float)$str;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
                    // Return float or int, as appropriate
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
                    return ((float)$str == (integer)$str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
                        ? (integer)$str
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
                        : (float)$str;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
                } elseif (preg_match('/^("|\').*(\1)$/s', $str, $m) && $m[1] == $m[2]) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
                    // STRINGS RETURNED IN UTF-8 FORMAT
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
                    $delim = $this->substr8($str, 0, 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
                    $chrs = $this->substr8($str, 1, -1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
                    $utf8 = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
                    $strlen_chrs = $this->strlen8($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
                    for ($c = 0; $c < $strlen_chrs; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
                        $substr_chrs_c_2 = $this->substr8($chrs, $c, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
                        $ord_chrs_c = ord($chrs{$c});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
                        switch (true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
                            case $substr_chrs_c_2 == '\b':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
                                $utf8 .= chr(0x08);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
                            case $substr_chrs_c_2 == '\t':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
                                $utf8 .= chr(0x09);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
                            case $substr_chrs_c_2 == '\n':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
                                $utf8 .= chr(0x0A);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
                            case $substr_chrs_c_2 == '\f':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
                                $utf8 .= chr(0x0C);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
                            case $substr_chrs_c_2 == '\r':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
                                $utf8 .= chr(0x0D);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
                            case $substr_chrs_c_2 == '\\"':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
                            case $substr_chrs_c_2 == '\\\'':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
                            case $substr_chrs_c_2 == '\\\\':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
                            case $substr_chrs_c_2 == '\\/':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
                                if (($delim == '"' && $substr_chrs_c_2 != '\\\'') ||
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
                                   ($delim == "'" && $substr_chrs_c_2 != '\\"')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
                                    $utf8 .= $chrs{++$c};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
                                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
                            case preg_match('/\\\u[0-9A-F]{4}/i', $this->substr8($chrs, $c, 6)):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
                                // single, escaped unicode character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
                                $utf16 = chr(hexdec($this->substr8($chrs, ($c + 2), 2)))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
                                       . chr(hexdec($this->substr8($chrs, ($c + 4), 2)));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
                                $utf8 .= $this->utf162utf8($utf16);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
                            case ($ord_chrs_c >= 0x20) && ($ord_chrs_c <= 0x7F):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
                                $utf8 .= $chrs{$c};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
                            case ($ord_chrs_c & 0xE0) == 0xC0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
                                // characters U-00000080 - U-000007FF, mask 110XXXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
                                //see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
                                $utf8 .= $this->substr8($chrs, $c, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   674
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
                            case ($ord_chrs_c & 0xF0) == 0xE0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
                                // characters U-00000800 - U-0000FFFF, mask 1110XXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
                                $utf8 .= $this->substr8($chrs, $c, 3);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   679
                                $c += 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
                            case ($ord_chrs_c & 0xF8) == 0xF0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
                                // characters U-00010000 - U-001FFFFF, mask 11110XXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   684
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   685
                                $utf8 .= $this->substr8($chrs, $c, 4);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
                                $c += 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   687
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   688
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   689
                            case ($ord_chrs_c & 0xFC) == 0xF8:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   690
                                // characters U-00200000 - U-03FFFFFF, mask 111110XX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   691
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   692
                                $utf8 .= $this->substr8($chrs, $c, 5);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
                                $c += 4;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   694
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
                            case ($ord_chrs_c & 0xFE) == 0xFC:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
                                // characters U-04000000 - U-7FFFFFFF, mask 1111110X
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
                                $utf8 .= $this->substr8($chrs, $c, 6);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
                    return $utf8;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   709
                } elseif (preg_match('/^\[.*\]$/s', $str) || preg_match('/^\{.*\}$/s', $str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
                    // array, or object notation
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   711
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   712
                    if ($str{0} == '[') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   713
                        $stk = array(SERVICES_JSON_IN_ARR);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
                        $arr = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
                        if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
                            $stk = array(SERVICES_JSON_IN_OBJ);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
                            $obj = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
                        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
                            $stk = array(SERVICES_JSON_IN_OBJ);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
                            $obj = new stdClass();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   722
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
                    array_push($stk, array('what'  => SERVICES_JSON_SLICE,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
                                           'where' => 0,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
                                           'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
                    $chrs = $this->substr8($str, 1, -1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
                    $chrs = $this->reduce_string($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
                    if ($chrs == '') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
                        if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
                            return $arr;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
                        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
                            return $obj;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
                    //print("\nparsing {$chrs}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
                    $strlen_chrs = $this->strlen8($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
                    for ($c = 0; $c <= $strlen_chrs; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
                        $top = end($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
                        $substr_chrs_c_2 = $this->substr8($chrs, $c, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
                        if (($c == $strlen_chrs) || (($chrs{$c} == ',') && ($top['what'] == SERVICES_JSON_SLICE))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
                            // found a comma that is not inside a string, array, etc.,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
                            // OR we've reached the end of the character list
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
                            $slice = $this->substr8($chrs, $top['where'], ($c - $top['where']));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
                            array_push($stk, array('what' => SERVICES_JSON_SLICE, 'where' => ($c + 1), 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
                            //print("Found split at {$c}: ".$this->substr8($chrs, $top['where'], (1 + $c - $top['where']))."\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   757
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
                            if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
                                // we are in an array, so just push an element onto the stack
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
                                array_push($arr, $this->decode($slice));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
                            } elseif (reset($stk) == SERVICES_JSON_IN_OBJ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
                                // we are in an object, so figure
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
                                // out the property name and set an
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
                                // element in an associative array,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
                                // for now
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
                                $parts = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
                                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   769
                               if (preg_match('/^\s*(["\'].*[^\\\]["\'])\s*:/Uis', $slice, $parts)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
 	                              // "name":value pair
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
                                    $key = $this->decode($parts[1]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
                                    $val = $this->decode(trim(substr($slice, strlen($parts[0])), ", \t\n\r\0\x0B"));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
                                    if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
                                        $obj[$key] = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
                                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
                                        $obj->$key = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
                                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
                                } elseif (preg_match('/^\s*(\w+)\s*:/Uis', $slice, $parts)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
                                    // name:value pair, where name is unquoted
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   780
                                    $key = $parts[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
                                    $val = $this->decode(trim(substr($slice, strlen($parts[0])), ", \t\n\r\0\x0B"));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
                                    if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
                                        $obj[$key] = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
                                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
                                        $obj->$key = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
                                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
                                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
                        } elseif ((($chrs{$c} == '"') || ($chrs{$c} == "'")) && ($top['what'] != SERVICES_JSON_IN_STR)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
                            // found a quote, and we are not inside a string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
                            array_push($stk, array('what' => SERVICES_JSON_IN_STR, 'where' => $c, 'delim' => $chrs{$c}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
                            //print("Found start of string at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
                        } elseif (($chrs{$c} == $top['delim']) &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
                                 ($top['what'] == SERVICES_JSON_IN_STR) &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
                                 (($this->strlen8($this->substr8($chrs, 0, $c)) - $this->strlen8(rtrim($this->substr8($chrs, 0, $c), '\\'))) % 2 != 1)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
                            // found a quote, we're in a string, and it's not escaped
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
                            // we know that it's not escaped becase there is _not_ an
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
                            // odd number of backslashes at the end of the string so far
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
                            //print("Found end of string at {$c}: ".$this->substr8($chrs, $top['where'], (1 + 1 + $c - $top['where']))."\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
                        } elseif (($chrs{$c} == '[') &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   807
                                 in_array($top['what'], array(SERVICES_JSON_SLICE, SERVICES_JSON_IN_ARR, SERVICES_JSON_IN_OBJ))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   808
                            // found a left-bracket, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
                            array_push($stk, array('what' => SERVICES_JSON_IN_ARR, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
                            //print("Found start of array at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
                        } elseif (($chrs{$c} == ']') && ($top['what'] == SERVICES_JSON_IN_ARR)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
                            // found a right-bracket, and we're in an array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   814
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
                            //print("Found end of array at {$c}: ".$this->substr8($chrs, $top['where'], (1 + $c - $top['where']))."\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
                        } elseif (($chrs{$c} == '{') &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
                                 in_array($top['what'], array(SERVICES_JSON_SLICE, SERVICES_JSON_IN_ARR, SERVICES_JSON_IN_OBJ))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
                            // found a left-brace, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
                            array_push($stk, array('what' => SERVICES_JSON_IN_OBJ, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
                            //print("Found start of object at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
                        } elseif (($chrs{$c} == '}') && ($top['what'] == SERVICES_JSON_IN_OBJ)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
                            // found a right-brace, and we're in an object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
                            //print("Found end of object at {$c}: ".$this->substr8($chrs, $top['where'], (1 + $c - $top['where']))."\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
                        } elseif (($substr_chrs_c_2 == '/*') &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
                                 in_array($top['what'], array(SERVICES_JSON_SLICE, SERVICES_JSON_IN_ARR, SERVICES_JSON_IN_OBJ))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
                            // found a comment start, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
                            array_push($stk, array('what' => SERVICES_JSON_IN_CMT, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
                            $c++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   833
                            //print("Found start of comment at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   834
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
                        } elseif (($substr_chrs_c_2 == '*/') && ($top['what'] == SERVICES_JSON_IN_CMT)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   836
                            // found a comment end, and we're in one now
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
                            $c++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
                            for ($i = $top['where']; $i <= $c; ++$i)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
                                $chrs = substr_replace($chrs, ' ', $i, 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
                            //print("Found end of comment at {$c}: ".$this->substr8($chrs, $top['where'], (1 + $c - $top['where']))."\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
                    if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
                        return $arr;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   851
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
                    } elseif (reset($stk) == SERVICES_JSON_IN_OBJ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
                        return $obj;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   854
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   856
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   857
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
     * @todo Ultimately, this should just call PEAR::isError()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
     */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
    function isError($data, $code = null)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
        if (class_exists('pear')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
            return PEAR::isError($data, $code);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
        } elseif (is_object($data) && (get_class($data) == 'services_json_error' ||
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   869
                                 is_subclass_of($data, 'services_json_error'))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
            return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
        return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   876
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
    * Calculates length of string in bytes
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
    * @param string 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
    * @return integer length
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
    function strlen8( $str ) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
        if ( $this->_mb_strlen ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
            return mb_strlen( $str, "8bit" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
        return strlen( $str );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   887
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
    * Returns part of a string, interpreting $start and $length as number of bytes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
    * @param string 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
    * @param integer start 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
    * @param integer length 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
    * @return integer length
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
    function substr8( $string, $start, $length=false ) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
        if ( $length === false ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
            $length = $this->strlen8( $string ) - $start;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
        if ( $this->_mb_substr ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
            return mb_substr( $string, $start, $length, "8bit" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
        return substr( $string, $start, $length );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
if (class_exists('PEAR_Error')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
    class Services_JSON_Error extends PEAR_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
        function Services_JSON_Error($message = 'unknown error', $code = null,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
                                     $mode = null, $options = null, $userinfo = null)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
            parent::PEAR_Error($message, $code, $mode, $options, $userinfo);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   920
} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
     * @todo Ultimately, this class shall be descended from PEAR_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
     */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   925
    class Services_JSON_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   926
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
        function Services_JSON_Error($message = 'unknown error', $code = null,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
                                     $mode = null, $options = null, $userinfo = null)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   929
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   932
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   933
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   934
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   935
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
endif;