Sublime Forum

Preferences json not yaml?

#1

I noticed that the preferences are written in json which is nice and easy to edit. However I think yaml would be a better choice because it relies on indentation which makes it easy to read like python syntax. I see json more of a transport protocol and yaml for human readable markup.

Thanks

3 Likes

#2

To change it now would be a big change.

There is also nothing wrong with JSON and itā€™s regarded as the most popular format for such things :smile:

0 Likes

#3

json is good but yaml is better (in this case). Isnā€™t your goal to be sublime?

I would like you to take a look at it because many times a big change ends up being not that bad after itā€™s done.

0 Likes

#4

[quote=ā€œdeluciaā€]json is good but yaml is better (in this case). Isnā€™t your goal to be sublime?

I would like you to take a look at it because many times a big change ends up being not that bad after itā€™s done.[/quote]

I know how YAML works, itā€™s not bad, but to me, and Iā€™m sure others JSON makes it far easier to understand what is going on.

0 Likes

#5

Can we see sublime-keymap in json and yaml and compare?

0 Likes

#6

If youā€™d like to convert it then ok.

0 Likes

#7

Aye, I agree YAML would have been a much better choice. Off the top of my end I think there would be a lot less escaping needs and itā€™d be much more readable and easier to maintain, which is good for config files. Right now with JSON itā€™s rather curly brace hell and itā€™s very easy to get lost in all the nested brackets and braces.

Perhaps there was a technical limitation of some sort?

0 Likes

#8

Ok here is segment of the keymap file and the equivalent in yaml. I think the yaml is leaner and easier to read.

JSON:

{ "keys": "backspace"], "command": "left_delete" },
{ "keys": "shift+backspace"], "command": "left_delete" },
{ "keys": "ctrl+shift+backspace"], "command": "left_delete" },
{ "keys": "delete"], "command": "right_delete" },
{ "keys": "enter"], "command": "insert", "args": {"characters": "\n"} },
{ "keys": "shift+enter"], "command": "insert", "args": {"characters": "\n"} }

]

YAML:

  • keys: [backspace]
    command: left_delete
  • keys: [shift+backspace]
    command: left_delete
  • keys: [ctrl+shift+backspace]
    command: left_delete
  • keys: [delete]
    command: right_delete
  • keys: [enter]
    command: insert
    args: {characters : ā€œ\nā€}
  • keys: [shift+enter]
    command: insert
    args: {characters : ā€œ\nā€}
0 Likes

#9

As a programmer, I can appreciate the convenience of JSON as a portable and well-supported format.

As an end-user, I struggle to imagine a more unreadable mess for dealing with a large configuration system such as Sublimeā€™s. I never thought Iā€™d find myself missing XML (for the keymaps).

To me this is brace/bracket/quoted literal/string escaping-hell. Definitely a step backwards from the previous ā€œcustom directiveā€ syntax (or whatever it was in ST1) in terms of usability, IMO.

YAML is slightly better.

Anything that uses symbols rather than quoted string literals for keys would be a slight improvement. Like Ruby hashes, or even Javascript associative arrays, all of which are painlessly converted to JSON or other associative array structures.

Maybe Iā€™m missing something, but I think this is a case where thereā€™s a benefit to eating the pain of conversion on the backend (from a proprietary syntax) for the sake of the user.

0 Likes

#10

Is the debate over already ?

Iā€™d also like to throw in some support for YaML. After all, the resulting data type are the same, and not only do we avoid the { } hell, we also avoid the " " hell for property names.

Maybe would it be possible to at least give us the choice ? Like an option that says ā€œRead .yml config files, then .jsonā€ or the inverse or so ?

1 Like

#11

Holy necro, Batman!

Iā€™d like to throw in support for JSON. As ironcladlou mentioned, itā€™s extremely portable and widely supported. I canā€™t think of any user experience needs trumping these two programming requirements. Admittedly, YAML does share some formatting structure with Python but itā€™s not difficult to format JSON for readability.

1 Like

#12

My 2cents:

YAML IS AWESOME. As a configuration language, It is fast, flexible, metaprogrammable.

It would NOT be a big change, In-Fact it would be a dropin replacement because JSON is a valid subset of YAML.
All current JSON config files would work perfectly when being parsed by the YAML, making this the perfect time to switch over.
People wonā€™t even have to know that PyYaml is actually parsing their Json file.

In additon to this, YAML has some really cool features such as anchors which allow us to reduce repetition in config files (define once, use many times.)

From the wiki definition:

[quote]YAML syntax was designed to be easily mapped to data types common to most high-level languages: list, associative array, and scalar.[4] Its familiar indented outline and lean appearance make it especially suited for tasks where humans are likely to view or edit data structures, such as configuration files, dumping during debugging, and document headers (e.g. the headers found on most e-mails are very close to YAML). Although well-suited for hierarchical data representation, it also has a compact syntax for relational data as well.[5] Its line and whitespace delimiters make it friendly to ad hoc grep/Python/Perl/Ruby operations. A major part of its accessibility comes from eschewing the use of enclosures like quotation marks, brackets, braces, and open/close-tags which can be hard for the human eye to balance in nested hierarchies.
[/quote]

So please, reconsider YAML. Itā€™s awesome, Itā€™s powerful, Itā€™s a drop-in replacement.

1 Like

#13

JSON is verbose, bloated and ugly ā€“ YAML or CSON would be a great improvement.

1 Like

#14

Cson disqualifies as a configuration format because it is badly specified and requires coffeescript to be parsed (since it is essentially coffeescript). My 2ct.

I think my love for yaml is quite clear nowadays, so I doubt I have to say anything else regarding this thread.

3 Likes

#15

Hi!

Yaml would be great for the following reasons:

  • easy to read
  • super fast to type (not {, alomost no quotes, no comma)

And, it would stop those problems with Json:

  • comments (sometimes yes, sometimes no)
  • trailing comma (same as comments)

So, please @jps or @wbond, consider swapping on YAML.

Matt

PS: if youā€™re for this swap too, please leave a comment, so we can see how many people would enjoy it, and so maybe it will accelerate the process.

0 Likes

#16

@math2001 Jon and I have discussed the idea of using YAML. There are some definitely pluses to it, but some downsides also. One of the bigger issues is that significant whitespace isnā€™t intuitive to many users unless theyā€™ve worked with a language like Python before. Using it for .sublime-syntax was a big win over XML or JSON. The additional complexity of understanding YAML was justified there since writing a syntax definition isnā€™t the sort of thing most users do.

We havenā€™t made a definitive call on it yet, but as with most other things, Iā€™ll try to chime in and answer questions as people ask them. IMO, all of the XML files that are supported due to compatibility with TextMate would ideally be superseded by a format that is easier to modify. Solving this issue isnā€™t next on my list of things to do, but is definitely not low priority.

As with most parts of the implementation of Sublime Text, the implementation details required to maintain performance arenā€™t always obvious. Changing file formats requires that the parser we are using is extremely efficient, especially since there are thousands of .sublime-syntax, .tmPreferences, .sublime-settings and .sublime-snippet files that are loaded whenever Sublime Text is started.

6 Likes

Will there be a .sublime-something replacement for the .tmPreferences file format?
Allow multiple snippets in same sublime-snippet file
#17

You should take a look at Hjson. It does not suffer from JSONs trailing commas, allows comments and is easier to use than YAML.

2 Likes

#18

Hi evrbd,
in some projects, e.g. nodeJS, a ā€˜package.jsonā€™-cfg-file gets changed by the NPM-/Yarn-tool and the User, too. Thus it cannot contain comment-lines, which would be helpful. The ordering of keys cannot be maintained ā€˜by-handā€™, too.
In my workflow, i convert -by hand/script- from JSON to YAML and back. I have comments and key-order preserved and the benefit of a cleaner view for editing the YAML.
Iā€™m working on a script that merges/diffs newly added keys from the JSON- into the YAML-file while preserving comment-lines in YAML. I used pythons ruamel.yaml-lib.
Later iā€™d like to make a ST-plugin, that automatically converts a JSON-config-file into a YAML-representation, opening the YAML in a editible-view, whereas the JSON-file opens in read-only view, if it opens at all.
Iā€™m new to Sublime, so if there already exists a plugin that already does smth. similar, please tell me. Iā€™d like to lern the sublime-API by example.

While i consider this scenario to be a special-case and i donā€™t expect this to become integrated into ST, i wonder if maybe such a situation is somehow ā€˜typicalā€™ for others, too ?
In general-terms, having two files with identical contents but in different formats, that need to be kept in-sync and the file-formats can be (automatically)-transformed in both directions ?
Maybe this is already too much of IDE ? iā€™m not sure - i find such scenarios more often in my workflows and i need a supportive-editor to handle such stuff.
regards, andreas

0 Likes

#19

@math2001 and @laktak STā€™s config files allow trailing commas and comments. The userā€™s Preferences.sublime-settings file is the only one that doesnā€™t keep them when changing something e.g. via command palette. I use trailing commas and comments in keymaps, projects and plugin configs.

@delucia your keymap doesnā€™t have to look so bad if you format it better, e.g.:

[
    {
        "keys": ["backspace"],
        "command": "left_delete",
    },
    {
        "keys": ["shift+backspace"],
        "command": "left_delete",
    },
    {
        "keys": ["ctrl+shift+backspace"],
        "command": "left_delete",
    },
    {
        "keys": ["delete"],
        "command": "right_delete",
    },
    {
        "keys": ["enter"],
        "command": "insert",
        "args": { "characters": "\n" },
    },
    {
        "keys": ["shift+enter"],
        "command": "insert",
        "args": { "characters": "\n" },
    },
]

@twoolie people will know that PyYaml is actually parsing their config because ST will probably get slower on startup. Here is a Ruby benchmark and Python benchmark. Maybe somebody could do a benchmark of ST startup time with YAML vs JSON parser. I love ST for its speedy startup and actually I also love JSON for its unambiguity (though no comments and no trailing commas sucks, which ST ā€œfixedā€).

@bosinski your plugin could keep YAML configs in a folder, which get converted to JSON on save (e.g. Preferences.yaml becomes Preferences.sublime-settings). That way you keep the original YAML with comments and also have the performance benefit of JSON. Youā€™d need to hook into the Preferences menu somehow.

0 Likes

#20

Choosing a niche format over an established standard, like JSON and YAML, is hardly ever a good option (mostly due to the lack of an eco-system supporting it). It also doesnā€™t solve any of JSONā€™s shortcomings, as mentioned by the thread starter.

Apart from that ā€“ Iā€™ve seen other JSON-like formats which set the same goal, and of all of them JSON5 appears to the closest of ever becoming standard. Until itā€™s not, I wouldnā€™t even consider it.

2 Likes