wp/wp-includes/class-json.php
author ymh <ymh.work@gmail.com>
Tue, 15 Oct 2019 15:48:13 +0200
changeset 13 d255fe9cd479
parent 9 177826044cd9
child 16 a86126ab1dd4
permissions -rw-r--r--
Upgrade wordpress again
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
9
177826044cd9 upgrade wordpress to 5.2.3
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
    18
 * is intended for use with client-side JavaScript applications that make
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
 * use of HTTPRequest to perform server communication functions - data can
9
177826044cd9 upgrade wordpress to 5.2.3
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
    20
 * be encoded into JSON notation for use in a client-side javaScript, or
177826044cd9 upgrade wordpress to 5.2.3
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
    21
 * decoded from incoming JavaScript requests. JSON format is native to
177826044cd9 upgrade wordpress to 5.2.3
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
    22
 * JavaScript, and can be directly eval()'ed with no further parsing
0
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 
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   139
    *                                   than the object itself, toJSON can return associative arrays, 
0
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
    */
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   143
    function __construct( $use = 0 )
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
    }
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   150
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   151
	/**
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   152
	 * PHP4 constructor.
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   153
	 */
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   154
	public function Services_JSON( $use = 0 ) {
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   155
		self::__construct( $use );
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   156
	}
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
    // private - cache the mbstring lookup results..
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
    var $_mb_strlen = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
    var $_mb_substr = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
    var $_mb_convert_encoding = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
    * convert a string from one UTF-16 char to one UTF-8 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
    * Normally should be handled by mb_convert_encoding, but
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
    * provides a slower PHP-only method for installations
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
    * that lack the multibye string extension.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
    * @param    string  $utf16  UTF-16 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
    * @return   string  UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
    function utf162utf8($utf16)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
        // oh please oh please oh please oh please oh please
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
        if($this->_mb_convert_encoding) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
            return mb_convert_encoding($utf16, 'UTF-8', 'UTF-16');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
        $bytes = (ord($utf16{0}) << 8) | ord($utf16{1});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
        switch(true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
            case ((0x7F & $bytes) == $bytes):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
                // this case should never be reached, because we are in ASCII range
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
                return chr(0x7F & $bytes);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
            case (0x07FF & $bytes) == $bytes:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
                // return a 2-byte UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
                return chr(0xC0 | (($bytes >> 6) & 0x1F))
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
            case (0xFFFF & $bytes) == $bytes:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
                // return a 3-byte UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
                return chr(0xE0 | (($bytes >> 12) & 0x0F))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
                     . chr(0x80 | (($bytes >> 6) & 0x3F))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
                     . chr(0x80 | ($bytes & 0x3F));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
        // ignoring UTF-32 for now, sorry
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
        return '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
    * convert a string from one UTF-8 char to one UTF-16 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
    * Normally should be handled by mb_convert_encoding, but
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
    * provides a slower PHP-only method for installations
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
    * that lack the multibye string extension.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
    * @param    string  $utf8   UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
    * @return   string  UTF-16 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
    function utf82utf16($utf8)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
        // oh please oh please oh please oh please oh please
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
        if($this->_mb_convert_encoding) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
            return mb_convert_encoding($utf8, 'UTF-16', 'UTF-8');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
        switch($this->strlen8($utf8)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
            case 1:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
                // this case should never be reached, because we are in ASCII range
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
                return $utf8;
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 2:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
                // return a UTF-16 character from a 2-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(0x07 & (ord($utf8{0}) >> 2))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
                     . chr((0xC0 & (ord($utf8{0}) << 6))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
                         | (0x3F & ord($utf8{1})));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
            case 3:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
                // return a UTF-16 character from a 3-byte UTF-8 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
                return chr((0xF0 & (ord($utf8{0}) << 4))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
                         | (0x0F & (ord($utf8{1}) >> 2)))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
                     . chr((0xC0 & (ord($utf8{1}) << 6))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
                         | (0x7F & ord($utf8{2})));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
        // ignoring UTF-32 for now, sorry
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
        return '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
    * encodes an arbitrary variable into JSON format (and sends JSON Header)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
    *                           see argument 1 to Services_JSON() above for array-parsing behavior.
9
177826044cd9 upgrade wordpress to 5.2.3
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
   255
    *                           if var is a string, note that encode() always expects it
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
    * @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
   259
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
    function encode($var)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
        header('Content-type: application/json');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
        return $this->encodeUnsafe($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
    * 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
   268
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
    *                           see argument 1 to Services_JSON() above for array-parsing behavior.
9
177826044cd9 upgrade wordpress to 5.2.3
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
   271
    *                           if var is a string, note that encode() always expects it
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
    * @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
   275
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
    function encodeUnsafe($var)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
        // see bug #16908 - regarding numeric locale printing
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
        $lc = setlocale(LC_NUMERIC, 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
        setlocale(LC_NUMERIC, 'C');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
        $ret = $this->_encode($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
        setlocale(LC_NUMERIC, $lc);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
        return $ret;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
        
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
    * 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
   289
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
    *                           see argument 1 to Services_JSON() above for array-parsing behavior.
9
177826044cd9 upgrade wordpress to 5.2.3
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
   292
    *                           if var is a string, note that encode() always expects it
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
    * @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
   296
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
    function _encode($var) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
         
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
        switch (gettype($var)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
            case 'boolean':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
                return $var ? 'true' : 'false';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
            case 'NULL':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
                return 'null';
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 'integer':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
                return (int) $var;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
            case 'double':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
            case 'float':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
                return  (float) $var;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
            case 'string':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
                // STRINGS ARE EXPECTED TO BE IN ASCII OR UTF-8 FORMAT
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
                $ascii = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
                $strlen_var = $this->strlen8($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
               /*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
                * Iterate over every character in the string,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
                * escaping with a slash or encoding to UTF-8 where necessary
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
                */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
                for ($c = 0; $c < $strlen_var; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
                    $ord_var_c = ord($var{$c});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
                    switch (true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
                        case $ord_var_c == 0x08:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
                            $ascii .= '\b';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
                        case $ord_var_c == 0x09:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
                            $ascii .= '\t';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
                        case $ord_var_c == 0x0A:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
                            $ascii .= '\n';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   337
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
                        case $ord_var_c == 0x0C:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
                            $ascii .= '\f';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
                        case $ord_var_c == 0x0D:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
                            $ascii .= '\r';
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 == 0x22:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
                        case $ord_var_c == 0x2F:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
                        case $ord_var_c == 0x5C:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
                            // double quote, slash, slosh
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
                            $ascii .= '\\'.$var{$c};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
                        case (($ord_var_c >= 0x20) && ($ord_var_c <= 0x7F)):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
                            // characters U-00000000 - U-0000007F (same as ASCII)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
                            $ascii .= $var{$c};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
                        case (($ord_var_c & 0xE0) == 0xC0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
                            // characters U-00000080 - U-000007FF, mask 110XXXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
                            if ($c+1 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
                                $c += 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
                                $ascii .= '?';
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
                            
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
                            $char = pack('C*', $ord_var_c, ord($var{$c + 1}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
                            $c += 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
                        case (($ord_var_c & 0xF0) == 0xE0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
                            if ($c+2 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
                                $c += 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
                            // characters U-00000800 - U-0000FFFF, mask 1110XXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
                            $char = pack('C*', $ord_var_c,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
                                         @ord($var{$c + 1}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
                                         @ord($var{$c + 2}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
                            $c += 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
                        case (($ord_var_c & 0xF8) == 0xF0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
                            if ($c+3 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
                                $c += 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   392
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   394
                            // characters U-00010000 - U-001FFFFF, mask 11110XXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
                            $char = pack('C*', $ord_var_c,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
                                         ord($var{$c + 1}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
                                         ord($var{$c + 2}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
                                         ord($var{$c + 3}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
                            $c += 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
                        case (($ord_var_c & 0xFC) == 0xF8):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
                            // characters U-00200000 - U-03FFFFFF, mask 111110XX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
                            if ($c+4 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
                                $c += 4;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
                            $char = pack('C*', $ord_var_c,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
                                         ord($var{$c + 1}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
                                         ord($var{$c + 2}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
                                         ord($var{$c + 3}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
                                         ord($var{$c + 4}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
                            $c += 4;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   419
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
                        case (($ord_var_c & 0xFE) == 0xFC):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
                        if ($c+5 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
                            // characters U-04000000 - U-7FFFFFFF, mask 1111110X
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
                            $char = pack('C*', $ord_var_c,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
                                         ord($var{$c + 1}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
                                         ord($var{$c + 2}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
                                         ord($var{$c + 3}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
                                         ord($var{$c + 4}),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
                                         ord($var{$c + 5}));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   437
                            $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   441
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
                return  '"'.$ascii.'"';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
            case 'array':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
               /*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
                * As per JSON spec if any array key is not an integer
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   448
                * we must treat the whole array as an object. We
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
                * also try to catch a sparsely populated associative
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
                * array with numeric keys here because some JS engines
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
                * will create an array with empty indexes up to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   452
                * max_index which can cause memory issues and because
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
                * the keys, which may be relevant, will be remapped
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   454
                * otherwise.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
                *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
                * As per the ECMA and JSON specification an object may
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
                * have any string as a property. Unfortunately due to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
                * a hole in the ECMA specification if the key is a
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
                * ECMA reserved word or starts with a digit the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
                * parameter is only accessible using ECMAScript's
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
                * bracket notation.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
                */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
                // treat as a JSON object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
                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
   466
                    $properties = array_map(array($this, 'name_value'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
                                            array_keys($var),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
                                            array_values($var));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
                    foreach($properties as $property) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
                        if(Services_JSON::isError($property)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
                            return $property;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
                    return '{' . join(',', $properties) . '}';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
                // treat it like a regular array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
                $elements = array_map(array($this, '_encode'), $var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
                foreach($elements as $element) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
                    if(Services_JSON::isError($element)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
                        return $element;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
                return '[' . join(',', $elements) . ']';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
            case 'object':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
            
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
                // support toJSON methods.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
                if (($this->use & SERVICES_JSON_USE_TO_JSON) && method_exists($var, 'toJSON')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
                    // this may end up allowing unlimited recursion
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
                    // 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
   496
                    $recode = $var->toJSON();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
                    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
                    if (method_exists($recode, 'toJSON')) {
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->use & SERVICES_JSON_SUPPRESS_ERRORS)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
                        ? 'null'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
                        : new Services_JSON_Error(get_class($var).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
                            " toJSON returned an object with a toJSON method.");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
                            
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
                    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
                    return $this->_encode( $recode );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
                } 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
                $vars = get_object_vars($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
                $properties = array_map(array($this, 'name_value'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
                                        array_keys($vars),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
                                        array_values($vars));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
                foreach($properties as $property) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
                    if(Services_JSON::isError($property)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
                        return $property;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
                return '{' . join(',', $properties) . '}';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
            default:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
                return ($this->use & SERVICES_JSON_SUPPRESS_ERRORS)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
                    ? 'null'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
                    : new Services_JSON_Error(gettype($var)." can not be encoded as JSON string");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
    * array-walking function for use in generating JSON-formatted name-value pairs
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
    * @param    string  $name   name of key to use
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
    * @param    mixed   $value  reference to an array element to be encoded
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
    * @return   string  JSON-formatted name-value pair, like '"name":value'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
    function name_value($name, $value)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
        $encoded_value = $this->_encode($value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
        if(Services_JSON::isError($encoded_value)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
            return $encoded_value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
        return $this->_encode(strval($name)) . ':' . $encoded_value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
    * reduce a string by removing leading and trailing comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
    * @param    $str    string      string value to strip of comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
    * @return   string  string value stripped of comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
    function reduce_string($str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
        $str = preg_replace(array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
                // eliminate single line comments in '// ...' form
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
                '#^\s*//(.+)$#m',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
                // eliminate multi-line comments in '/* ... */' form, at start of string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
                '#^\s*/\*(.+)\*/#Us',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
                // eliminate multi-line comments in '/* ... */' form, at end of string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
                '#/\*(.+)\*/\s*$#Us'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
            ), '', $str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
        // eliminate extraneous space
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
        return trim($str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
    * decodes a JSON string into appropriate variable
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
    * @param    string  $str    JSON-formatted string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
    * @return   mixed   number, boolean, string, array, or object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
    *                   corresponding to given JSON input string.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
    *                   See argument 1 to Services_JSON() above for object-output behavior.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
    *                   Note that decode() always returns strings
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
    *                   in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
    function decode($str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
        $str = $this->reduce_string($str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
        switch (strtolower($str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
            case 'true':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
                return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
            case 'false':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
            case 'null':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
                return null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
            default:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
                $m = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
                if (is_numeric($str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
                    // Lookie-loo, it's a number
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
                    // This would work on its own, but I'm trying to be
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
                    // good about returning integers where appropriate:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
                    // return (float)$str;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
                    // Return float or int, as appropriate
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
                    return ((float)$str == (integer)$str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
                        ? (integer)$str
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
                        : (float)$str;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
                } elseif (preg_match('/^("|\').*(\1)$/s', $str, $m) && $m[1] == $m[2]) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
                    // STRINGS RETURNED IN UTF-8 FORMAT
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
                    $delim = $this->substr8($str, 0, 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
                    $chrs = $this->substr8($str, 1, -1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
                    $utf8 = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
                    $strlen_chrs = $this->strlen8($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
                    for ($c = 0; $c < $strlen_chrs; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
                        $substr_chrs_c_2 = $this->substr8($chrs, $c, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
                        $ord_chrs_c = ord($chrs{$c});
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
                        switch (true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
                            case $substr_chrs_c_2 == '\b':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
                                $utf8 .= chr(0x08);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
                            case $substr_chrs_c_2 == '\t':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
                                $utf8 .= chr(0x09);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
                            case $substr_chrs_c_2 == '\n':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
                                $utf8 .= chr(0x0A);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
                            case $substr_chrs_c_2 == '\f':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
                                $utf8 .= chr(0x0C);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
                            case $substr_chrs_c_2 == '\r':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
                                $utf8 .= chr(0x0D);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
                            case $substr_chrs_c_2 == '\\"':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
                            case $substr_chrs_c_2 == '\\\'':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
                            case $substr_chrs_c_2 == '\\\\':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
                            case $substr_chrs_c_2 == '\\/':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
                                if (($delim == '"' && $substr_chrs_c_2 != '\\\'') ||
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
                                   ($delim == "'" && $substr_chrs_c_2 != '\\"')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
                                    $utf8 .= $chrs{++$c};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
                                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
                            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
   664
                                // single, escaped unicode character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
                                $utf16 = chr(hexdec($this->substr8($chrs, ($c + 2), 2)))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
                                       . chr(hexdec($this->substr8($chrs, ($c + 4), 2)));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
                                $utf8 .= $this->utf162utf8($utf16);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
                            case ($ord_chrs_c >= 0x20) && ($ord_chrs_c <= 0x7F):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
                                $utf8 .= $chrs{$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 & 0xE0) == 0xC0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
                                // characters U-00000080 - U-000007FF, mask 110XXXXX
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, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   679
                                ++$c;
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 & 0xF0) == 0xE0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
                                // characters U-00000800 - U-0000FFFF, mask 1110XXXX
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, 3);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
                                $c += 2;
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 & 0xF8) == 0xF0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   690
                                // characters U-00010000 - U-001FFFFF, mask 11110XXX
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, 4);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
                                $c += 3;
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 & 0xFC) == 0xF8:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
                                // characters U-00200000 - U-03FFFFFF, mask 111110XX
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, 5);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
                                $c += 4;
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
                            case ($ord_chrs_c & 0xFE) == 0xFC:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
                                // characters U-04000000 - U-7FFFFFFF, mask 1111110X
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
                                $utf8 .= $this->substr8($chrs, $c, 6);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   709
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   711
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   712
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   713
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
                    return $utf8;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
                } elseif (preg_match('/^\[.*\]$/s', $str) || preg_match('/^\{.*\}$/s', $str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
                    // array, or object notation
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
                    if ($str{0} == '[') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
                        $stk = array(SERVICES_JSON_IN_ARR);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
                        $arr = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   722
                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
                        if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
                            $stk = array(SERVICES_JSON_IN_OBJ);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
                            $obj = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
                        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
                            $stk = array(SERVICES_JSON_IN_OBJ);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
                            $obj = new stdClass();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
                    array_push($stk, array('what'  => SERVICES_JSON_SLICE,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
                                           'where' => 0,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
                                           'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
                    $chrs = $this->substr8($str, 1, -1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
                    $chrs = $this->reduce_string($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
                    if ($chrs == '') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
                        if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
                            return $arr;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
                        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
                            return $obj;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
                    //print("\nparsing {$chrs}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
                    $strlen_chrs = $this->strlen8($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
                    for ($c = 0; $c <= $strlen_chrs; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
                        $top = end($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
                        $substr_chrs_c_2 = $this->substr8($chrs, $c, 2);
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 (($c == $strlen_chrs) || (($chrs{$c} == ',') && ($top['what'] == SERVICES_JSON_SLICE))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
                            // found a comma that is not inside a string, array, etc.,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
                            // OR we've reached the end of the character list
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
                            $slice = $this->substr8($chrs, $top['where'], ($c - $top['where']));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
                            array_push($stk, array('what' => SERVICES_JSON_SLICE, 'where' => ($c + 1), 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
                            //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
   764
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
                            if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
                                // we are in an array, so just push an element onto the stack
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
                                array_push($arr, $this->decode($slice));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   769
                            } elseif (reset($stk) == SERVICES_JSON_IN_OBJ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
                                // we are in an object, so figure
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
                                // out the property name and set an
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
                                // element in an associative array,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
                                // for now
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
                                $parts = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
                                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
                               if (preg_match('/^\s*(["\'].*[^\\\]["\'])\s*:/Uis', $slice, $parts)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
 	                              // "name":value pair
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
                                    $key = $this->decode($parts[1]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
                                    $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
   780
                                    if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
                                        $obj[$key] = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
                                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
                                        $obj->$key = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
                                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
                                } elseif (preg_match('/^\s*(\w+)\s*:/Uis', $slice, $parts)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
                                    // name:value pair, where name is unquoted
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
                                    $key = $parts[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
                                    $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
   789
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
                                    if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
                                        $obj[$key] = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
                                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
                                        $obj->$key = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
                                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
                                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
                        } elseif ((($chrs{$c} == '"') || ($chrs{$c} == "'")) && ($top['what'] != SERVICES_JSON_IN_STR)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
                            // found a quote, and we are not inside a string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
                            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
   802
                            //print("Found start of string at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
                        } elseif (($chrs{$c} == $top['delim']) &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
                                 ($top['what'] == SERVICES_JSON_IN_STR) &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
                                 (($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
   807
                            // found a quote, we're in a string, and it's not escaped
9
177826044cd9 upgrade wordpress to 5.2.3
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
   808
                            // we know that it's not escaped because there is _not_ an
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
                            // odd number of backslashes at the end of the string so far
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
                            //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
   812
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
                        } elseif (($chrs{$c} == '[') &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   814
                                 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
   815
                            // found a left-bracket, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
                            array_push($stk, array('what' => SERVICES_JSON_IN_ARR, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
                            //print("Found start of array at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
                        } elseif (($chrs{$c} == ']') && ($top['what'] == SERVICES_JSON_IN_ARR)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
                            // found a right-bracket, and we're in an array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
                            //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
   823
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
                        } elseif (($chrs{$c} == '{') &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
                                 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
   826
                            // found a left-brace, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
                            array_push($stk, array('what' => SERVICES_JSON_IN_OBJ, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
                            //print("Found start of object at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
                        } elseif (($chrs{$c} == '}') && ($top['what'] == SERVICES_JSON_IN_OBJ)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
                            // found a right-brace, and we're in an object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   833
                            //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
   834
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
                        } elseif (($substr_chrs_c_2 == '/*') &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   836
                                 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
   837
                            // found a comment start, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
                            array_push($stk, array('what' => SERVICES_JSON_IN_CMT, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
                            $c++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
                            //print("Found start of comment at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
                        } elseif (($substr_chrs_c_2 == '*/') && ($top['what'] == SERVICES_JSON_IN_CMT)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
                            // found a comment end, and we're in one now
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
                            $c++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
                            for ($i = $top['where']; $i <= $c; ++$i)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
                                $chrs = substr_replace($chrs, ' ', $i, 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
                            //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
   851
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
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
                    if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   857
                        return $arr;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
                    } elseif (reset($stk) == SERVICES_JSON_IN_OBJ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
                        return $obj;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   869
     * @todo Ultimately, this should just call PEAR::isError()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
     */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
    function isError($data, $code = null)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
        if (class_exists('pear')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
            return PEAR::isError($data, $code);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
        } elseif (is_object($data) && (get_class($data) == 'services_json_error' ||
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   876
                                 is_subclass_of($data, 'services_json_error'))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
            return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
        return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
    * Calculates length of string in bytes
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
    * @param string 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
    * @return integer length
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   887
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
    function strlen8( $str ) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
        if ( $this->_mb_strlen ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
            return mb_strlen( $str, "8bit" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
        return strlen( $str );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
    * Returns part of a string, interpreting $start and $length as number of bytes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
    * @param string 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
    * @param integer start 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
    * @param integer length 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
    * @return integer length
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
    function substr8( $string, $start, $length=false ) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
        if ( $length === false ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
            $length = $this->strlen8( $string ) - $start;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
        if ( $this->_mb_substr ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
            return mb_substr( $string, $start, $length, "8bit" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
        return substr( $string, $start, $length );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
if (class_exists('PEAR_Error')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
    class Services_JSON_Error extends PEAR_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
    {
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   920
        function __construct($message = 'unknown error', $code = null,
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
                                     $mode = null, $options = null, $userinfo = null)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
            parent::PEAR_Error($message, $code, $mode, $options, $userinfo);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
        }
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   925
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   926
	public function Services_JSON_Error($message = 'unknown error', $code = null,
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   927
                                     $mode = null, $options = null, $userinfo = null) {
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   928
		self::__construct($message = 'unknown error', $code = null,
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   929
                                     $mode = null, $options = null, $userinfo = null);
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   930
	}
0
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
} else {
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
     * @todo Ultimately, this class shall be descended from PEAR_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
     */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   938
    class Services_JSON_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   939
    {
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   940
	    /**
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   941
	     * PHP5 constructor.
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   942
	     */
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   943
        function __construct( $message = 'unknown error', $code = null,
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   944
                                     $mode = null, $options = null, $userinfo = null )
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   947
        }
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   948
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   949
	    /**
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   950
	     * PHP4 constructor.
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   951
	     */
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   952
		public function Services_JSON_Error( $message = 'unknown error', $code = null,
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   953
	                                     $mode = null, $options = null, $userinfo = null ) {
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   954
			self::__construct( $message, $code, $mode, $options, $userinfo );
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   955
		}
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   956
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   957
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   958
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   959
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   960
endif;