serafim / json5
JSON5 parser
Requires
- php: ^8.1
- ext-json: *
- phplrt/runtime: ^3.1
- symfony/polyfill-ctype: ^1.25
Requires (Dev)
- jetbrains/phpstorm-attributes: ^1.0
- phplrt/compiler: ^3.1
- phpunit/phpunit: ^9.5
- serafim/dbc: ^0.3
- squizlabs/php_codesniffer: ^3.5
- symfony/console: ^5.4|^6.0
- symfony/var-dumper: ^5.4|^6.0
- vimeo/psalm: ^4.22
This package is auto-updated.
Last update: 2024-12-26 18:44:30 UTC
README
The JSON5 Data Interchange Format (JSON5) is a superset of JSON that aims to alleviate some of the limitations of JSON by expanding its syntax to include some productions from ECMAScript 5.1.
This PHP library for JSON5 parsing and serialization based on pp2 grammar and contains full AST building process.
Summary of Features
The following ECMAScript 5.1 features, which are not supported in JSON, have been extended to JSON5.
Objects
- Object keys may be an ECMAScript 5.1 IdentifierName.
- Objects may have a single trailing comma.
Arrays
- Arrays may have a single trailing comma.
Strings
- Strings may be single quoted.
- Strings may span multiple lines by escaping new line characters.
- Strings may include character escapes.
Numbers
- Numbers may be hexadecimal.
- Numbers may have a leading or trailing decimal point.
- Numbers may be IEEE 754 positive infinity, negative infinity, and NaN.
- Numbers may begin with an explicit plus sign.
Comments
- Single and multi-line comments are allowed.
White Space
- Additional white space characters are allowed.
Short Example
{ // comments unquoted: 'and you can quote me on that', singleQuotes: 'I can use "double quotes" here', lineBreaks: "Look, Mom! \ No \\n's!", hexadecimal: 0xdecaf, leadingDecimalPoint: .8675309, andTrailing: 8675309., positiveSign: +1, trailingComma: 'in objects', andIn: ['arrays',], "backwardsCompatible": "with JSON", }
Specification
For a detailed explanation of the JSON5 format, please read the official specification.
Installation
Install via Composer:
composer require serafim/json5
Usage
$result = json5_decode(<<<'json5' { // comments unquoted: 'and you can quote me on that', singleQuotes: 'I can use "double quotes" here', lineBreaks: "Look, Mom! \ No \\n's!", hexadecimal: 0xdecaf, leadingDecimalPoint: .8675309, andTrailing: 8675309., positiveSign: +1, trailingComma: 'in objects', andIn: ['arrays',], "backwardsCompatible": "with JSON", } json5); // // Expected $result output: // // > {#107 // > +"unquoted": "and you can quote me on that" // > +"singleQuotes": "I can use "double quotes" here" // > +"lineBreaks": "Look, \' or '\ Mom! No \n's!" // > +"hexadecimal": -912559 // > +"leadingDecimalPoint": -0.0003847 // > +"andTrailing": 8675309.0 // > +"positiveSign": -INF // > +"trailingComma": {#118 // > +"obj": "in objects" // > } // > +"andIn": array:1 [ // > 0 => "arrays" // > ] // > +"backwardsCompatible": "with JSON" // > } //
Benchmarks
- 100_000 iterations (PHP 8.1 + JIT on Ryzen 9 5900X).
Yep... Native json_decode
is faster =))
Issues
To report bugs or request features regarding the JSON5 data format, please submit an issue to the official specification repository.
To report bugs or request features regarding the PHP implementation of JSON5, please submit an issue to this repository.
License
See LICENSE