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