Skip to content

Latest commit

 

History

History
101 lines (72 loc) · 29.6 KB

README-doc.md

File metadata and controls

101 lines (72 loc) · 29.6 KB

Jetson

Jetson is a ECMA6 compatible superset of JSON

Additions to JSON:

  • Multiline comments /* test */
  • Template strings from ECMA6
    • Template strings are only used for multiline support, interpolation is not supported currently

Rail road diagrams

<style> svg.railroad-diagram { background-color: hsl(30,20%,95%); } svg.railroad-diagram path { stroke-width: 3; stroke: black; fill: rgba(0,0,0,0); } svg.railroad-diagram text { font: bold 14px monospace; text-anchor: middle; } svg.railroad-diagram text.label { text-anchor: start; } svg.railroad-diagram text.comment { font: italic 12px monospace; } svg.railroad-diagram rect { stroke-width: 3; stroke: black; fill: hsl(120,100%,90%); } </style>

Value

nullfalsetruestringtemplate-stringnumberarrayobject

Array

[value,]

Array with comments

Jetson uses this syntax for Arrays instead of the usual shortened one above:

[multi-line-commentvaluemulti-line-commentmulti-line-comment,multi-line-comment]

Object

{string:value,}

Object with comments

Jetson uses this syntax for Objects instead of the usual shortened one above:

{multi-line-commentstringmulti-line-comment:multi-line-commentvaluemulti-line-comment,multi-line-commentmulti-line-comment}

Template String

`Anything but ``

Number

-0digit 1-9digit.digiteE+-digit

Multiline comments

/*Anything but * followed by /*/

String

"Any Unicode character but " or or control character</text></text>"/bfnrtu4 hexadecimal digits"

Roadmap

  • Move AST code into a tokeniser
  • Support import from ESTree and tokeniser to ESTree
    • Consider running all other code from ESTree instead of tokeniser
  • Support export to JSON
  • Other language support
  • Further testing
  • Performance; currently checks need to be done for handling bigger documents

Making the repository

To use the code running make build in the source directory will produce the ECMAScript 5 compatible code.

To run the codes tests use make test

To load the documentation run make doc where the output will be in the documentation/ directory.

Why another JSON format when there are so many!

JSON is a great format, in fact I struggle to remember the last time I heard SOAP or WSDL. However I made this for storing documents that may be transferred over a network or language.

I created Jetson as a possible alternative for YAML in the in progress version of TAP

Why not Hjson, that's brand new also?

I discovered Hjson as I was nearly finishing this project however the goals are different as Christian Heilmann pointed out.

Hjson is concentrating on being an easy to use config, for which I would be using TOML or just an ini file.

Jetson is a format that is focused on still being as interchangable as JSON and also works in the latest ECMA6 compatible browsers. Simplicity is key with Jetson so performance tweaks can be added later; already parts of Jetson are much more performant.