wp/wp-includes/class-json.php
author ymh <ymh.work@gmail.com>
Mon, 08 Sep 2025 19:44:41 +0200
changeset 23 417f20492bf7
parent 21 48c4eec2b7e6
permissions -rw-r--r--
Update Docker configuration and plugin versions - Upgrade MariaDB from 10.6 to 11 with auto-upgrade support - Add WordPress debug environment variable to FPM container - Update PHP-FPM Dockerfile base image - Update Include Mastodon Feed plugin with bug fixes and improvements - Update Portfolio plugin (v2.58) with latest translations and demo data enhancements - Remove old README.md from Mastodon Feed plugin 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
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 $
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
    57
 * @license     https://www.opensource.org/licenses/bsd-license.php
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
    58
 * @link        https://pear.php.net/pepr/pepr-proposal-show.php?id=198
0
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
   /**
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   125
    * Object behavior flags.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   126
    *
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   127
    * @var int
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   128
    */
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   129
    public $use;
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   130
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   131
    // private - cache the mbstring lookup results..
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   132
    var $_mb_strlen = false;
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   133
    var $_mb_substr = false;
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   134
    var $_mb_convert_encoding = false;
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   135
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   136
   /**
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
    * constructs a new JSON instance
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
    *
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   139
    * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   140
    *
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
    * @param    int     $use    object behavior flags; combine with boolean-OR
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
    *                           possible values:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
    *                           - SERVICES_JSON_LOOSE_TYPE:  loose typing.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
    *                                   "{...}" syntax creates associative arrays
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
    *                                   instead of objects in decode().
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
    *                           - SERVICES_JSON_SUPPRESS_ERRORS:  error suppression.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
    *                                   Values which can't be encoded (e.g. resources)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
    *                                   appear as NULL instead of throwing errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
    *                                   By default, a deeply-nested resource will
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
    *                                   bubble up with an error, so all return values
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
    *                                   from encode() should be checked with isError()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
    *                           - SERVICES_JSON_USE_TO_JSON:  call toJSON when serializing objects
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
    *                                   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
   155
    *                                   than the object itself, toJSON can return associative arrays, 
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
    *                                   strings or numbers, if you return an object, make sure it does
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
    *                                   not have a toJSON method, otherwise an error will occur.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
    */
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   159
    function __construct( $use = 0 )
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   161
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   162
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
        $this->use = $use;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
        $this->_mb_strlen            = function_exists('mb_strlen');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
        $this->_mb_convert_encoding  = function_exists('mb_convert_encoding');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
        $this->_mb_substr            = function_exists('mb_substr');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
    }
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   168
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   169
    /**
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   170
     * PHP4 constructor.
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   171
     *
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   172
     * @deprecated 5.3.0 Use __construct() instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   173
     *
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   174
     * @see Services_JSON::__construct()
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   175
     */
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   176
    public function Services_JSON( $use = 0 ) {
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   177
        _deprecated_constructor( 'Services_JSON', '5.3.0', get_class( $this ) );
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   178
        self::__construct( $use );
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   179
    }
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   180
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
    * convert a string from one UTF-16 char to one UTF-8 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
    * Normally should be handled by mb_convert_encoding, but
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
    * provides a slower PHP-only method for installations
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
    * that lack the multibye string extension.
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 5.3.0 Use the PHP native JSON extension instead.
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
    * @param    string  $utf16  UTF-16 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
    * @return   string  UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
    function utf162utf8($utf16)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   196
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   197
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
        // oh please oh please oh please oh please oh please
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
        if($this->_mb_convert_encoding) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
            return mb_convert_encoding($utf16, 'UTF-8', 'UTF-16');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   203
        $bytes = (ord($utf16[0]) << 8) | ord($utf16[1]);
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
        switch(true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
            case ((0x7F & $bytes) == $bytes):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
                // this case should never be reached, because we are in ASCII range
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
                return chr(0x7F & $bytes);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
            case (0x07FF & $bytes) == $bytes:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
                // return a 2-byte UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
                return chr(0xC0 | (($bytes >> 6) & 0x1F))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
                     . chr(0x80 | ($bytes & 0x3F));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
            case (0xFFFF & $bytes) == $bytes:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
                // return a 3-byte UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
                return chr(0xE0 | (($bytes >> 12) & 0x0F))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
                     . chr(0x80 | (($bytes >> 6) & 0x3F))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
                     . chr(0x80 | ($bytes & 0x3F));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
        // ignoring UTF-32 for now, sorry
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
        return '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
    * convert a string from one UTF-8 char to one UTF-16 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
    * Normally should be handled by mb_convert_encoding, but
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
    * provides a slower PHP-only method for installations
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   234
    * that lack the multibyte string extension.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   235
    *
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   236
    * @deprecated 5.3.0 Use the PHP native JSON extension instead.
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
    * @param    string  $utf8   UTF-8 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
    * @return   string  UTF-16 character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
    function utf82utf16($utf8)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   244
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   245
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
        // oh please oh please oh please oh please oh please
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
        if($this->_mb_convert_encoding) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
            return mb_convert_encoding($utf8, 'UTF-16', 'UTF-8');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
        switch($this->strlen8($utf8)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
            case 1:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
                // this case should never be reached, because we are in ASCII range
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
                // see: http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
                return $utf8;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
            case 2:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
                // return a UTF-16 character from a 2-byte UTF-8 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
                // 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
   260
                return chr(0x07 & (ord($utf8[0]) >> 2))
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   261
                     . chr((0xC0 & (ord($utf8[0]) << 6))
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   262
                         | (0x3F & ord($utf8[1])));
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
            case 3:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
                // return a UTF-16 character from a 3-byte UTF-8 char
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
                // 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
   267
                return chr((0xF0 & (ord($utf8[0]) << 4))
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   268
                         | (0x0F & (ord($utf8[1]) >> 2)))
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   269
                     . chr((0xC0 & (ord($utf8[1]) << 6))
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   270
                         | (0x7F & ord($utf8[2])));
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
        // ignoring UTF-32 for now, sorry
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
        return '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
    * encodes an arbitrary variable into JSON format (and sends JSON Header)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
    *
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   280
    * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   281
    *
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
    *                           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
   284
    *                           if var is a string, note that encode() always expects it
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
    * @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
   288
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
    function encode($var)
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_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   293
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   294
        header('Content-Type: application/json');
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
        return $this->encodeUnsafe($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
    * 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
   299
    *
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   300
    * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   301
    *
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
    *                           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
   304
    *                           if var is a string, note that encode() always expects it
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
    * @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
   308
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
    function encodeUnsafe($var)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   312
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   313
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
        // see bug #16908 - regarding numeric locale printing
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
        $lc = setlocale(LC_NUMERIC, 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
        setlocale(LC_NUMERIC, 'C');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
        $ret = $this->_encode($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
        setlocale(LC_NUMERIC, $lc);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
        return $ret;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
        
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
    * 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
   324
    *
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   325
    * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   326
    *
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
    * @param    mixed   $var    any number, boolean, string, array, or object to be encoded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
    *                           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
   329
    *                           if var is a string, note that encode() always expects it
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
    *                           to be in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
    * @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
   333
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
    function _encode($var) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   337
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   338
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
        switch (gettype($var)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
            case 'boolean':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
                return $var ? 'true' : 'false';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
            case 'NULL':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
                return 'null';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
            case 'integer':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
                return (int) $var;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
            case 'double':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
            case 'float':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
                return  (float) $var;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
            case 'string':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
                // STRINGS ARE EXPECTED TO BE IN ASCII OR UTF-8 FORMAT
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
                $ascii = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
                $strlen_var = $this->strlen8($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
               /*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
                * Iterate over every character in the string,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
                * escaping with a slash or encoding to UTF-8 where necessary
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
                */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
                for ($c = 0; $c < $strlen_var; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   364
                    $ord_var_c = ord($var[$c]);
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   365
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
                    switch (true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
                        case $ord_var_c == 0x08:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
                            $ascii .= '\b';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
                        case $ord_var_c == 0x09:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
                            $ascii .= '\t';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
                        case $ord_var_c == 0x0A:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
                            $ascii .= '\n';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
                        case $ord_var_c == 0x0C:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
                            $ascii .= '\f';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
                        case $ord_var_c == 0x0D:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
                            $ascii .= '\r';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
                        case $ord_var_c == 0x22:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
                        case $ord_var_c == 0x2F:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
                        case $ord_var_c == 0x5C:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
                            // double quote, slash, slosh
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   387
                            $ascii .= '\\'.$var[$c];
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
                        case (($ord_var_c >= 0x20) && ($ord_var_c <= 0x7F)):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
                            // characters U-00000000 - U-0000007F (same as ASCII)
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   392
                            $ascii .= $var[$c];
0
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
                        case (($ord_var_c & 0xE0) == 0xC0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
                            // characters U-00000080 - U-000007FF, mask 110XXXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
                            if ($c+1 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
                                $c += 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
                            
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   404
                            $char = pack('C*', $ord_var_c, ord($var[$c + 1]));
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
                            $c += 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
                        case (($ord_var_c & 0xF0) == 0xE0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
                            if ($c+2 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
                                $c += 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
                            // characters U-00000800 - U-0000FFFF, mask 1110XXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
                            $char = pack('C*', $ord_var_c,
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   419
                                         @ord($var[$c + 1]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   420
                                         @ord($var[$c + 2]));
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
                            $c += 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
                        case (($ord_var_c & 0xF8) == 0xF0):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
                            if ($c+3 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
                                $c += 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
                            // characters U-00010000 - U-001FFFFF, mask 11110XXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
                            $char = pack('C*', $ord_var_c,
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   435
                                         ord($var[$c + 1]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   436
                                         ord($var[$c + 2]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   437
                                         ord($var[$c + 3]));
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
                            $c += 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
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
                        case (($ord_var_c & 0xFC) == 0xF8):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
                            // characters U-00200000 - U-03FFFFFF, mask 111110XX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
                            if ($c+4 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
                                $c += 4;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
                            $char = pack('C*', $ord_var_c,
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   452
                                         ord($var[$c + 1]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   453
                                         ord($var[$c + 2]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   454
                                         ord($var[$c + 3]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   455
                                         ord($var[$c + 4]));
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
                            $c += 4;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
                        case (($ord_var_c & 0xFE) == 0xFC):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
                        if ($c+5 >= $strlen_var) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
                                $ascii .= '?';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
                            // characters U-04000000 - U-7FFFFFFF, mask 1111110X
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
                            // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
                            $char = pack('C*', $ord_var_c,
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   470
                                         ord($var[$c + 1]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   471
                                         ord($var[$c + 2]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   472
                                         ord($var[$c + 3]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   473
                                         ord($var[$c + 4]),
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   474
                                         ord($var[$c + 5]));
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
                            $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
                            $utf16 = $this->utf82utf16($char);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
                            $ascii .= sprintf('\u%04s', bin2hex($utf16));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
                            break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
                return  '"'.$ascii.'"';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
            case 'array':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
               /*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
                * 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
   486
                * we must treat the whole array as an object. We
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
                * also try to catch a sparsely populated associative
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
                * array with numeric keys here because some JS engines
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
                * will create an array with empty indexes up to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
                * max_index which can cause memory issues and because
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
                * the keys, which may be relevant, will be remapped
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
                * otherwise.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
                *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
                * As per the ECMA and JSON specification an object may
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
                * have any string as a property. Unfortunately due to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
                * a hole in the ECMA specification if the key is a
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
                * ECMA reserved word or starts with a digit the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
                * parameter is only accessible using ECMAScript's
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
                * bracket notation.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
                */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
                // treat as a JSON object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
                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
   504
                    $properties = array_map(array($this, 'name_value'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
                                            array_keys($var),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
                                            array_values($var));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
                    foreach($properties as $property) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
                        if(Services_JSON::isError($property)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
                            return $property;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
                    return '{' . join(',', $properties) . '}';
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
                // treat it like a regular array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
                $elements = array_map(array($this, '_encode'), $var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
                foreach($elements as $element) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
                    if(Services_JSON::isError($element)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
                        return $element;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
                return '[' . join(',', $elements) . ']';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
            case 'object':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
            
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
                // support toJSON methods.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
                if (($this->use & SERVICES_JSON_USE_TO_JSON) && method_exists($var, 'toJSON')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
                    // this may end up allowing unlimited recursion
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
                    // 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
   534
                    $recode = $var->toJSON();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
                    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
                    if (method_exists($recode, 'toJSON')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
                        
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
                        return ($this->use & SERVICES_JSON_SUPPRESS_ERRORS)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
                        ? 'null'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
                        : new Services_JSON_Error(get_class($var).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
                            " toJSON returned an object with a toJSON method.");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
                            
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
                    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
                    return $this->_encode( $recode );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
                } 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
                $vars = get_object_vars($var);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
                $properties = array_map(array($this, 'name_value'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
                                        array_keys($vars),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
                                        array_values($vars));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
                foreach($properties as $property) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
                    if(Services_JSON::isError($property)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
                        return $property;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
                    }
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
                return '{' . join(',', $properties) . '}';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
            default:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
                return ($this->use & SERVICES_JSON_SUPPRESS_ERRORS)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
                    ? 'null'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
                    : new Services_JSON_Error(gettype($var)." can not be encoded as JSON string");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
    * array-walking function for use in generating JSON-formatted name-value pairs
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
    *
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   572
    * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   573
    *
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
    * @param    string  $name   name of key to use
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
    * @param    mixed   $value  reference to an array element to be encoded
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
    * @return   string  JSON-formatted name-value pair, like '"name":value'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
    function name_value($name, $value)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   582
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   583
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
        $encoded_value = $this->_encode($value);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
        if(Services_JSON::isError($encoded_value)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
            return $encoded_value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
18
be944660c56a Site enmi version 09/2022
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
   590
        return $this->_encode((string) $name) . ':' . $encoded_value;
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
    * reduce a string by removing leading and trailing comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
    *
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   596
    * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   597
    *
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
    * @param    $str    string      string value to strip of comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
    * @return   string  string value stripped of comments and whitespace
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
    * @access   private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
    function reduce_string($str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   605
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   606
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
        $str = preg_replace(array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
                // eliminate single line comments in '// ...' form
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
                '#^\s*//(.+)$#m',
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 multi-line comments in '/* ... */' form, at start of string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
                '#^\s*/\*(.+)\*/#Us',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
                // eliminate multi-line comments in '/* ... */' form, at end of string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
                '#/\*(.+)\*/\s*$#Us'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
            ), '', $str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
        // eliminate extraneous space
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
        return trim($str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
   /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
    * decodes a JSON string into appropriate variable
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
    *
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   627
    * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   628
    *
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
    * @param    string  $str    JSON-formatted string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
    *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
    * @return   mixed   number, boolean, string, array, or object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
    *                   corresponding to given JSON input string.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
    *                   See argument 1 to Services_JSON() above for object-output behavior.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
    *                   Note that decode() always returns strings
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
    *                   in ASCII or UTF-8 format!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
    * @access   public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
    */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
    function decode($str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   640
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   641
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
        $str = $this->reduce_string($str);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
        switch (strtolower($str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
            case 'true':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
                return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
            case 'false':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
            case 'null':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
                return null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
            default:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
                $m = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
                if (is_numeric($str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
                    // Lookie-loo, it's a number
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
                    // This would work on its own, but I'm trying to be
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
                    // good about returning integers where appropriate:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
                    // return (float)$str;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
                    // Return float or int, as appropriate
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
                    return ((float)$str == (integer)$str)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
                        ? (integer)$str
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
                        : (float)$str;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
                } elseif (preg_match('/^("|\').*(\1)$/s', $str, $m) && $m[1] == $m[2]) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
                    // STRINGS RETURNED IN UTF-8 FORMAT
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
                    $delim = $this->substr8($str, 0, 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
                    $chrs = $this->substr8($str, 1, -1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
                    $utf8 = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   674
                    $strlen_chrs = $this->strlen8($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
                    for ($c = 0; $c < $strlen_chrs; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
                        $substr_chrs_c_2 = $this->substr8($chrs, $c, 2);
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   679
                        $ord_chrs_c = ord($chrs[$c]);
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
                        switch (true) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
                            case $substr_chrs_c_2 == '\b':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
                                $utf8 .= chr(0x08);
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 == '\t':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   687
                                $utf8 .= chr(0x09);
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 == '\n':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   691
                                $utf8 .= chr(0x0A);
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
                            case $substr_chrs_c_2 == '\f':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
                                $utf8 .= chr(0x0C);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
                            case $substr_chrs_c_2 == '\r':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
                                $utf8 .= chr(0x0D);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
                            case $substr_chrs_c_2 == '\\"':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
                            case $substr_chrs_c_2 == '\\\'':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
                            case $substr_chrs_c_2 == '\\\\':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
                            case $substr_chrs_c_2 == '\\/':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
                                if (($delim == '"' && $substr_chrs_c_2 != '\\\'') ||
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
                                   ($delim == "'" && $substr_chrs_c_2 != '\\"')) {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   709
                                    $utf8 .= $chrs[++$c];
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
                                }
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 preg_match('/\\\u[0-9A-F]{4}/i', $this->substr8($chrs, $c, 6)):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
                                // single, escaped unicode character
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
                                $utf16 = chr(hexdec($this->substr8($chrs, ($c + 2), 2)))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
                                       . chr(hexdec($this->substr8($chrs, ($c + 4), 2)));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
                                $utf8 .= $this->utf162utf8($utf16);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
                            case ($ord_chrs_c >= 0x20) && ($ord_chrs_c <= 0x7F):
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   722
                                $utf8 .= $chrs[$c];
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
                            case ($ord_chrs_c & 0xE0) == 0xC0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
                                // characters U-00000080 - U-000007FF, mask 110XXXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
                                //see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
                                $utf8 .= $this->substr8($chrs, $c, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
                                ++$c;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
                            case ($ord_chrs_c & 0xF0) == 0xE0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
                                // characters U-00000800 - U-0000FFFF, mask 1110XXXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
                                $utf8 .= $this->substr8($chrs, $c, 3);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
                                $c += 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
                            case ($ord_chrs_c & 0xF8) == 0xF0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
                                // characters U-00010000 - U-001FFFFF, mask 11110XXX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
                                $utf8 .= $this->substr8($chrs, $c, 4);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
                                $c += 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
                            case ($ord_chrs_c & 0xFC) == 0xF8:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
                                // characters U-00200000 - U-03FFFFFF, mask 111110XX
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
                                $utf8 .= $this->substr8($chrs, $c, 5);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
                                $c += 4;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
                            case ($ord_chrs_c & 0xFE) == 0xFC:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
                                // characters U-04000000 - U-7FFFFFFF, mask 1111110X
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
                                // see http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
                                $utf8 .= $this->substr8($chrs, $c, 6);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   757
                                $c += 5;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
                                break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
                    return $utf8;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
                } elseif (preg_match('/^\[.*\]$/s', $str) || preg_match('/^\{.*\}$/s', $str)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
                    // array, or object notation
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   769
                    if ($str[0] == '[') {
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
                        $stk = array(SERVICES_JSON_IN_ARR);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
                        $arr = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
                        if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
                            $stk = array(SERVICES_JSON_IN_OBJ);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
                            $obj = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
                        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
                            $stk = array(SERVICES_JSON_IN_OBJ);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
                            $obj = new stdClass();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   780
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
                    array_push($stk, array('what'  => SERVICES_JSON_SLICE,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
                                           'where' => 0,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
                                           'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
                    $chrs = $this->substr8($str, 1, -1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
                    $chrs = $this->reduce_string($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
                    if ($chrs == '') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
                        if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
                            return $arr;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
                        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
                            return $obj;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
                        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
                    //print("\nparsing {$chrs}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
                    $strlen_chrs = $this->strlen8($chrs);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
                    for ($c = 0; $c <= $strlen_chrs; ++$c) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
                        $top = end($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
                        $substr_chrs_c_2 = $this->substr8($chrs, $c, 2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   807
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   808
                        if (($c == $strlen_chrs) || (($chrs[$c] == ',') && ($top['what'] == SERVICES_JSON_SLICE))) {
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
                            // found a comma that is not inside a string, array, etc.,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
                            // OR we've reached the end of the character list
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
                            $slice = $this->substr8($chrs, $top['where'], ($c - $top['where']));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
                            array_push($stk, array('what' => SERVICES_JSON_SLICE, 'where' => ($c + 1), 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
                            //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
   814
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
                            if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
                                // we are in an array, so just push an element onto the stack
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
                                array_push($arr, $this->decode($slice));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
                            } elseif (reset($stk) == SERVICES_JSON_IN_OBJ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
                                // we are in an object, so figure
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
                                // out the property name and set an
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
                                // element in an associative array,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
                                // for now
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
                                $parts = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
                                
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
                               if (preg_match('/^\s*(["\'].*[^\\\]["\'])\s*:/Uis', $slice, $parts)) {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   827
                                    // "name":value pair
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
                                    $key = $this->decode($parts[1]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
                                    $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
   830
                                    if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
                                        $obj[$key] = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
                                    } else {
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
                                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
                                } elseif (preg_match('/^\s*(\w+)\s*:/Uis', $slice, $parts)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   836
                                    // name:value pair, where name is unquoted
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
                                    $key = $parts[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
                                    $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
   839
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
                                    if ($this->use & SERVICES_JSON_LOOSE_TYPE) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
                                        $obj[$key] = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
                                    } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
                                        $obj->$key = $val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
                                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
                                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
                            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   849
                        } elseif ((($chrs[$c] == '"') || ($chrs[$c] == "'")) && ($top['what'] != SERVICES_JSON_IN_STR)) {
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
                            // found a quote, and we are not inside a string
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   851
                            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
   852
                            //print("Found start of string at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   854
                        } elseif (($chrs[$c] == $top['delim']) &&
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
                                 ($top['what'] == SERVICES_JSON_IN_STR) &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   856
                                 (($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
   857
                            // 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
   858
                            // we know that it's not escaped because there is _not_ an
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
                            // odd number of backslashes at the end of the string so far
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
                            //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
   862
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   863
                        } elseif (($chrs[$c] == '[') &&
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
                                 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
   865
                            // found a left-bracket, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
                            array_push($stk, array('what' => SERVICES_JSON_IN_ARR, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
                            //print("Found start of array at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   869
                        } elseif (($chrs[$c] == ']') && ($top['what'] == SERVICES_JSON_IN_ARR)) {
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
                            // found a right-bracket, and we're in an array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
                            //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
   873
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   874
                        } elseif (($chrs[$c] == '{') &&
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
                                 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
   876
                            // found a left-brace, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
                            array_push($stk, array('what' => SERVICES_JSON_IN_OBJ, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
                            //print("Found start of object at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   880
                        } elseif (($chrs[$c] == '}') && ($top['what'] == SERVICES_JSON_IN_OBJ)) {
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
                            // found a right-brace, and we're in an object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
                            //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
   884
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
                        } elseif (($substr_chrs_c_2 == '/*') &&
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
                                 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
   887
                            // found a comment start, and we are in an array, object, or slice
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
                            array_push($stk, array('what' => SERVICES_JSON_IN_CMT, 'where' => $c, 'delim' => false));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
                            $c++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
                            //print("Found start of comment at {$c}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
                        } elseif (($substr_chrs_c_2 == '*/') && ($top['what'] == SERVICES_JSON_IN_CMT)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
                            // found a comment end, and we're in one now
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
                            array_pop($stk);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
                            $c++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
                            for ($i = $top['where']; $i <= $c; ++$i)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
                                $chrs = substr_replace($chrs, ' ', $i, 1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
                            //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
   901
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
                        }
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
                    if (reset($stk) == SERVICES_JSON_IN_ARR) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
                        return $arr;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
                    } elseif (reset($stk) == SERVICES_JSON_IN_OBJ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
                        return $obj;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
                    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
    /**
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   919
     * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   920
     *
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
     * @todo Ultimately, this should just call PEAR::isError()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
     */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
    function isError($data, $code = null)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   925
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   926
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
        if (class_exists('pear')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
            return PEAR::isError($data, $code);
18
be944660c56a Site enmi version 09/2022
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
   929
        } elseif (is_object($data) && ($data instanceof services_json_error ||
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
                                 is_subclass_of($data, 'services_json_error'))) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
            return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   932
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   933
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   934
        return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   935
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
    /**
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   938
     * Calculates length of string in bytes
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   939
     *
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   940
     * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   941
     *
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   942
     * @param string
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   943
     * @return integer length
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   944
     */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
    function strlen8( $str ) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   947
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   948
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   949
        if ( $this->_mb_strlen ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   950
            return mb_strlen( $str, "8bit" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   951
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   952
        return strlen( $str );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   953
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   954
    
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   955
    /**
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   956
     * 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
   957
     *
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   958
     * @deprecated 5.3.0 Use the PHP native JSON extension instead.
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   959
     *
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   960
     * @param string
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   961
     * @param integer start
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   962
     * @param integer length
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   963
     * @return integer length
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   964
     */
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   965
    function substr8( $string, $start, $length=false ) 
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   966
    {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   967
        _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   968
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   969
        if ( $length === false ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   970
            $length = $this->strlen8( $string ) - $start;
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 ( $this->_mb_substr ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   973
            return mb_substr( $string, $start, $length, "8bit" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   974
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   975
        return substr( $string, $start, $length );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   976
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   977
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   978
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   979
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   980
if (class_exists('PEAR_Error')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   981
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   982
    class Services_JSON_Error extends PEAR_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   983
    {
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   984
        /**
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   985
         * PHP5 constructor.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   986
         *
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   987
         * @deprecated 5.3.0 Use the PHP native JSON extension instead.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   988
         */
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   989
        function __construct($message = 'unknown error', $code = null,
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   990
                                     $mode = null, $options = null, $userinfo = null)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   991
        {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   992
            _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
   993
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   994
            parent::PEAR_Error($message, $code, $mode, $options, $userinfo);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   995
        }
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   996
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   997
        /**
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   998
         * PHP4 constructor.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
   999
         *
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1000
         * @deprecated 5.3.0 Use __construct() instead.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1001
         *
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1002
         * @see Services_JSON_Error::__construct()
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1003
         */
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1004
        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
  1005
                                     $mode = null, $options = null, $userinfo = null) {
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1006
            _deprecated_constructor( 'Services_JSON_Error', '5.3.0', get_class( $this ) );
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1007
            self::__construct($message, $code, $mode, $options, $userinfo);
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1008
        }
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1009
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1010
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1011
} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1012
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1013
    /**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1014
     * @todo Ultimately, this class shall be descended from PEAR_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1015
     */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1016
    class Services_JSON_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1017
    {
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1018
        /**
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1019
         * PHP5 constructor.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1020
         *
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1021
         * @deprecated 5.3.0 Use the PHP native JSON extension instead.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1022
         */
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
  1023
        function __construct( $message = 'unknown error', $code = null,
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
  1024
                                     $mode = null, $options = null, $userinfo = null )
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1025
        {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
  1026
            _deprecated_function( __METHOD__, '5.3.0', 'The PHP native JSON extension' );
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1027
        }
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
  1028
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1029
        /**
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1030
         * PHP4 constructor.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1031
         *
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1032
         * @deprecated 5.3.0 Use __construct() instead.
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1033
         *
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1034
         * @see Services_JSON_Error::__construct()
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1035
         */
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1036
        public function Services_JSON_Error( $message = 'unknown error', $code = null,
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1037
                                         $mode = null, $options = null, $userinfo = null ) {
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1038
            _deprecated_constructor( 'Services_JSON_Error', '5.3.0', get_class( $this ) );
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1039
            self::__construct( $message, $code, $mode, $options, $userinfo );
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 18
diff changeset
  1040
        }
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1041
    }
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 9
diff changeset
  1042
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1043
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1044
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1045
endif;