显示 crate…
1 个不稳定版本
0.1.0 | 2019年5月24日 |
---|
#47 in #s-expr
12KB
123 行
sonata
抽象无约束的 s-expr Sonata。
缺点
将 Sonata 序列化为 cons 运算。
#[test]
fn test_cons() {
let stream = b"(: hello)";
assert_eq!(b": hello", stream.car());
assert_eq!(b"", stream.cdr());
assert_eq!(b":", stream.car().car());
assert_eq!(b"hello", stream.car().cdr());
assert_eq!(b"", stream.cdr().car());
assert_eq!(b"", stream.cdr().cdr());
}
#[test]
fn test_list() {
let stream = b"(: > !)";
assert_eq!(b": > !", stream.car()); // [0]
assert_eq!(b":", stream.car().car()); // [0, 0]
assert_eq!(b"> !", stream.car().cdr()); // [0, 1]
assert_eq!(b">", stream.car().cdr().car()); // [0, 1, 0]
assert_eq!(b"!", stream.car().cdr().cdr()); // [0, 1, 1]
}
原子
/// ;expression
/// b'(symbol expr*) ::= Eval("s-expr"),
/// b'((symbol) expr*)' ::= Lambda("s-expr"),
/// b'((symbol-true) expr*) ::= Condition("s-expr")
///
/// ;number
/// b'd+_i8' => Number("i8"), //::= Expr(i8) ~> itlr | item | number
/// b'd+_u8' => Number("u8"), //::= Expr(u8) ~> itlr | item | number
/// b'd+_i32' => Number("i32"), //::= Expr(i32) ~> itlr | item | number
/// b'd+_u32' => Number("u32"), //::= Expr(u32) ~> itlr | item | number
/// b'd+_f32' => Number("f32"), //::= Expr(f32) ~> itlr | item | number
/// b'd+_i64' => Number("i64"), //::= Expr(i64) ~> itlr | item | number
/// b'd+_u64' => Number("u64"), //::= Expr(u64) ~> itlr | item | number
/// b'd+_i128' => Number("i128"), //::= Expr(i128) ~> itlr | item | number
/// b'd+_u128' => Number("u128"), //::= Expr(u128) ~> itlr | item | number
///
/// ;ident
/// b';' => Ident(";"), //::= Expr(commnet) ~> ident
/// b'#' => Ident("#"), //::= Expr(super) ~> itlr | ident
/// br#"'"# => Ident("'"), //::= Expr(itrl) ~> itlr | ident
///
/// ;punct
/// b'+' => Operator("+"), //::= Expr(add) ~> itlr | item | number
/// b'-' => Operator("-"), //::= Expr(mins) ~> itlr | item | number
/// b'*' => Operator("*"), //::= Expr(multipl) ~> itlr | item | number
/// b'/' => Operator("/"), //::= Expr(except) ~> itlr | item | number
/// b'>' => Operator(">"), //::= Expr(gt) ~> itlr | item | bool
/// b'=' => Operator("="), //::= Expr(eq) ~> itlr | item | bool
/// b'<' => Operator("-"), //::= Expr(lt) ~> itlr | item | bool
/// b'>=' => Operator(">="), //::= Expr(ge) ~> itlr | item | bool
/// b'<=' => Operator("<="), //::= Expr(le) ~> itlr | item | bool
/// b'!=' => Operator("!="), //::= Expr(ne) ~> itlr | item | bool
/// b'||' => Operator("||"), //::= Expr(or) ~> itlr | item | bool
/// b'&&' => Operator("&&"), //::= Expr(and) ~> itlr | item | bool
///
/// ;literal
/// b'z' => Operator("z"), //::= Expr(zero) ~> itlr | item | bool
/// b'n' => Operator("n"), //::= Expr(non-zero) ~> itlr | item | bool
/// b't' => Operator("t"), //::= Expr(true) ~> itlr | item | bool
/// b'f' => Operator("f"), //::= Expr(false) ~> itlr | item | bool
///
/// ;variable
/// b'(ltrl se-symbol)' => Variable("let"), //::= Expr(let) ~> itlr | item | *
/// b'(#ltrl se-symbol)' => Const("const"), //::= Expr(const) ~> itlr | item | */// ;expression
AST
/// expression ::= atom | list
/// atom ::= number | symbol
/// number ::= [+-]?['0'-'9']+
/// symbol ::= ['A'-'Z''a'-'z'].*
/// list ::= '(' expression* ')'
///
/// ;expression
/// (1 2) ::= cons | number
/// (a 1) ::= expr | define
/// (+ 1 2) ::= expr | operate
/// ((arg) (+ arg 1)) ::= expr | lambda
/// ((= 1 1) (+ 1 1))) ::= expr | condition
///
/// ;number
/// (x 1) ::= expr | define | i32
/// (x 1_u32) ::= expr | define | u32
/// (x 1_f64) ::= expr | define | f64
///
/// ;symbol
/// (x @_@) ::= cons | symbol
/// (x 1) ::= expr | defvar
/// (x (x) (+ x 1)) ::= expr | defunc
///
/// ;ident
/// symbol(;) ::= ident | comment
/// symbol(') ::= ident | literal
/// symbol(") ::= ident | string
/// symbol(#) ::= ident | super