RON is a simple readable data serialization format that looks similar to Rust syntax. It's designed to support all of Serde's data model, so structs, enums, tuples, arrays, generic maps, and primitive values.
```rust GameConfig( // optional struct name windowsize: (800, 600), windowtitle: "PAC-MAN", fullscreen: false,
mouse_sensitivity: 1.4,
key_bindings: {
"up": Up,
"down": Down,
"left": Left,
"right": Right,
// Uncomment to enable WASD controls
/*
"W": Up,
"A": Down,
"S": Left,
"D": Right,
*/
},
difficulty_options: (
start_difficulty: Easy,
adaptive: false,
),
) ```
json
{
"materials": {
"metal": {
"reflectivity": 1.0
},
"plastic": {
"reflectivity": 0.5
}
},
"entities": [
{
"name": "hero",
"material": "metal"
},
{
"name": "monster",
"material": "plastic"
}
]
}
rust
Scene( // class name is optional
materials: { // this is a map
"metal": (
reflectivity: 1.0,
),
"plastic": (
reflectivity: 0.5,
),
},
entities: [ // this is an array
(
name: "hero",
material: "metal",
),
(
name: "monster",
material: "plastic",
),
],
)
Note the following advantages of RON over JSON:
42
, 3.14
, 0xFF
, 0b0110
"Hello"
, "with\\escapes\n"
, r#"raw string, great for regex\."#
true
, false
Some("string")
, Some(Some(1.34))
, None
("abc", 1.23, true)
, ()
["abc", "def"]
( foo: 1.0, bar: ( baz: "I'm nested" ) )
{ "arbitrary": "keys", "are": "allowed" }
Note: Serde's data model represents fixed-size Rust arrays as tuple (instead of as list)
| Editor | Plugin | |--------------|-------------------------------------------------------------| | IntelliJ | intellij-ron | | VS Code | a5huynh/vscode-ron | | Sublime Text | RON | | Atom | language-ron | | Vim | ron-rs/ron.vim | | EMACS | [emacs-ron] |
There is a very basic, work in progress specification available on the wiki page. A more formal and complete grammar is available here.
RON is dual-licensed under Apache-2.0 and MIT.
Any contribution intentionally submitted for inclusion in the work must be provided under the same dual-license terms.