Skip to content

Latest commit

 

History

History

lexpr

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

lexpr: S-expressions for Rust Latest Version Rustc Version 1.56+

You may be looking for:

S-expressions are the human-readable, textual representation of code and data in the Lisp family of languages. lexpr aims to provide the tools to:

  • Embed S-expression data into Rust programs using the sexp macro:

    use lexpr::sexp;
    
    let address = sexp!(((name . "Jane Doe") (street . "4026 Poe Lane")));

    As the sexp macro is implemented as a proc-macro, and may not be needed in all cases, it is needs to be enabled explicitly using the sexp-macro feature flag since lexpr version 0.3.0:

    [dependencies]
    lexpr = { version = "0.3", features = ["sexp-macro"] }

    Note that many of the documentation examples make use of the sexp macro, without hinting that the feature needs to be enabled explicitly.

  • Construct and destructure S-expression data using a full-featured API:

    use lexpr::Value;
    
    let names = Value::list(vec!["Alice", "Bob", "Mallory"]);
    println!("The bad guy is {}", names[2].as_str().unwrap());
  • Parse and serialize S-expression data from and to its textual representation.

  • Use S-expressions as surface syntax for a configuration file format or other domain-specific language (DSL). lexpr allows obtaining source location information for the parsed data, so you can give error messages that point to the exact place a problem was detected, in case the source was parsed successfully as S-expression data, but the parsed data does not meet the requirements of your DSL.

To get a better idea of the direction lexpr is headed, you may want to take at the TODO or the "why" document.

Rust version requirements

lexpr is CI-tested on current stable, beta and nightly channels of Rust. Additionally, it is made sure that the code still compiles on Rust 1.56.0. However, no tests are run for that build.

Supported Lisp dialects

Currently, lexpr focuses on Scheme, mostly based on R6RS and R7RS syntax, with some extensions, and Emacs Lisp.

Dialect-specific omissions, both ones that are planned to be fixed in the future, and deliberate ones, are listed below. If you are missing a feature that is not yet listed here, please [file an issue]!.

Scheme

  • Support for number syntax is currently quite limited, compared to Scheme's numeric tower. Integers (including hexadecimal, octal and binary notation) as well as floating point values should work though.
  • For strings, continuation line syntax (using a trailing slash) is not yet implemented.
  • Block comments.
  • Directives, such as #!fold-case and #!no-fold-case are not implemented. It's not clear if these will be implemented at all.

Emacs Lisp

  • A main area where lexpr only supports a subset of Emacs Lisp are strings and characters. You can have a look at the gory details.
  • Integer literals with an arbitrary base (radix), are not yet supported.

KiCad

  • Since version 0.3.0, reading and writing S-expression files produced by recent versions of KiCad should be supported given the new with_leading_digit_symbols parser option.

Licensing

The code and documentation in the lexpr crate is free software, dual-licensed under the MIT or Apache-2.0 license, at your choosing.

The lexpr repository contains code and documentation adapted from the following projects:

  • serde_json, also dual-licensed under MIT/Apache-2.0 licenses.
  • sexpr, Copyright 2017 Zephyr Pellerin, dual-licensed under the same licenses.