update export callback and add tests
Signed-off-by: Ava Hahn <ava@aidanis.online>
This commit is contained in:
parent
c5e68f25ba
commit
fbb85f2e3d
2 changed files with 108 additions and 2 deletions
|
|
@ -59,7 +59,7 @@ pub fn static_stdlib(syms: &mut SymTable) -> Result<(), String> {
|
|||
pub fn dynamic_stdlib(env: bool, syms: &mut SymTable) -> Result<(), String> {
|
||||
syms.insert("def".to_string(), Symbol {
|
||||
name: String::from("define"),
|
||||
args: Args::Lazy(2),
|
||||
args: Args::Infinite,
|
||||
conditional_branches: true,
|
||||
value: ValueType::Internal(Rc::new( move |ast: &Seg, syms: &mut SymTable| -> Result<Ctr, String> {
|
||||
_store_callback(ast, syms, env)
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@ mod var_lib_tests {
|
|||
use relish::stdlib::{static_stdlib, dynamic_stdlib};
|
||||
|
||||
#[test]
|
||||
fn test_variable_export_and_lookup() {
|
||||
fn test_variable_def_and_lookup() {
|
||||
let doc1 = "(def test 1)";
|
||||
let doc2 = "(test)";
|
||||
let result = "(1)";
|
||||
|
|
@ -39,4 +39,110 @@ mod var_lib_tests {
|
|||
assert!(false);
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_variable_def_redef_and_lookup() {
|
||||
let doc1 = "(def test 1)";
|
||||
let doc2 = "(def test '2')";
|
||||
let doc3 = "(test)";
|
||||
let result = "('2')";
|
||||
|
||||
let mut syms = SymTable::new();
|
||||
static_stdlib(&mut syms).unwrap();
|
||||
dynamic_stdlib(false, &mut syms).unwrap();
|
||||
|
||||
if let Ok(tree) = lex(&doc1.to_string()) {
|
||||
let eval_result = *eval(&tree, &mut syms).unwrap();
|
||||
if let Ctr::None = eval_result {
|
||||
// pass
|
||||
} else {
|
||||
eprintln!("bad: {eval_result}");
|
||||
assert!(false);
|
||||
}
|
||||
} else {
|
||||
eprintln!("couldn't lex doc1");
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(tree) = lex(&doc2.to_string()) {
|
||||
println!("tree: {tree}");
|
||||
let eval_result = *eval(&tree, &mut syms).unwrap();
|
||||
if let Ctr::None = eval_result {
|
||||
// pass
|
||||
} else {
|
||||
eprintln!("bad: {eval_result}");
|
||||
assert!(false);
|
||||
}
|
||||
} else {
|
||||
eprintln!("couldn't lex doc2");
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(tree) = lex(&doc3.to_string()) {
|
||||
println!("tree: {tree}");
|
||||
let eval_result = *eval(&tree, &mut syms).unwrap();
|
||||
if let Ctr::Seg(ref i) = eval_result {
|
||||
assert_eq!(i.to_string(), result);
|
||||
} else {
|
||||
eprintln!("bad: {eval_result}");
|
||||
assert!(false);
|
||||
}
|
||||
} else {
|
||||
eprintln!("couldn't lex doc3");
|
||||
assert!(false);
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_variable_def_undef_and_lookup_fail() {
|
||||
let doc1 = "(def test 1)";
|
||||
let doc2 = "(def test)";
|
||||
let doc3 = "(test)";
|
||||
|
||||
let mut syms = SymTable::new();
|
||||
static_stdlib(&mut syms).unwrap();
|
||||
dynamic_stdlib(false, &mut syms).unwrap();
|
||||
|
||||
if let Ok(tree) = lex(&doc1.to_string()) {
|
||||
let eval_result = *eval(&tree, &mut syms).unwrap();
|
||||
if let Ctr::None = eval_result {
|
||||
// pass
|
||||
} else {
|
||||
eprintln!("bad: {eval_result}");
|
||||
assert!(false);
|
||||
}
|
||||
} else {
|
||||
eprintln!("couldn't lex doc1");
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(tree) = lex(&doc2.to_string()) {
|
||||
println!("tree: {tree}");
|
||||
let eval_result = *eval(&tree, &mut syms).unwrap();
|
||||
if let Ctr::None = eval_result {
|
||||
// pass
|
||||
} else {
|
||||
eprintln!("bad: {eval_result}");
|
||||
assert!(false);
|
||||
}
|
||||
} else {
|
||||
eprintln!("couldn't lex doc2");
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(tree) = lex(&doc3.to_string()) {
|
||||
println!("tree: {tree}");
|
||||
let eval_result = eval(&tree, &mut syms);
|
||||
if let Err(s) = eval_result {
|
||||
assert_eq!(s.to_string(), "error in call to test: undefined symbol: test".to_string());
|
||||
} else {
|
||||
let res = eval_result.unwrap();
|
||||
eprintln!("shouldn't have suceeded: {res}");
|
||||
assert!(false);
|
||||
}
|
||||
} else {
|
||||
eprintln!("couldn't lex doc3");
|
||||
assert!(false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue