|Tim Schuster 954cd7d5b3 Updated readme||5 months ago|
|exec||7 months ago|
|helper||1 year ago|
|lexer||7 months ago|
|parser||7 months ago|
|plugins/vscode/secl-highlight||1 year ago|
|query||5 months ago|
|tests/must-parse||7 months ago|
|types||7 months ago|
|.gitignore||1 year ago|
|BREAKING_CHANGES.md||5 months ago|
|INTRODUCTION.md||7 months ago|
|README.md||5 months ago|
|SPECS.md||1 year ago|
|bugs_test.go||7 months ago|
|secl.go||7 months ago|
|secl_test.go||7 months ago|
SECL is a S-Expression based configuration language, drawing inspiration and syntax from JSON and YAML.
It’s main goal is to provide a configuration format that is easy to read and write with little overhead while being simple and understandable in it’s syntax and parsing.
list-entry key: ( another-list-entry key: "Hello World!" explicit: "UTF-8 support: 💩" other-features: ( "arbitrary precision decimals": 29312345320423531230497123416079652.234234234 "and integers": 343287640123745610476123012734613047236402374620376234023746 "scientific notation": 9.1*10^22 "multi-line strings": " SELECT * FROM table WHERE a = \"b\" " "omit quotation around simple strings": Hello-Again "load other files from subfolders": !(loadd "folder" ".conf") "empty maps": empty "random values": ( randstr128 maybe ) "mix lists and maps, they are the same in SECL" ) )
SECL is in Version “0.9.6”.
A non-formal specification can be found at in this repository under SPECS.md
SECL is primarly focused on configuration files, it may not be useful in other contexts but it can be.
As configuration files are typically not loaded repeatedly and performance is a secondary problem, SECL development does not focus on beating JSON and XML parsers in performance. Instead, they are beaten in feature sets.
Features that make SECL subjectively better than JSON or XML include;
To read up on how to write SECL, visit INTRODUCTION.md. This file will contain detailed documentation and introduction into the SECL language.
SECL is licensed under the MPL 2.0, in essence, it’s GPL2 but it will not “infect” any applications you write using SECL. By contributing you accept that your code is licensed under MPL2.0. A CLA is not necessary.
Until Version 1.0.0 SECL will not be considered stable, however, even in the current phase of the project, all breaking changes are noted in BREAKING_CHANGES. Note that we cannot possible know any and all ways a change may affect code. Certain edgecases may not be included at the discretion of the project leadership.
Once Version 1.0.0 is reached we will not break any dependent code using existing functions of the primary package (
go.rls.moe/secl) and packages that are to be consumed by external packages. Internal breaking changes may be recorded but no stability is guaranteed.