completed index op on hashtable, added puts builtin

This commit is contained in:
Ishan Jain 2024-05-28 11:14:11 +05:30
parent f51ead1641
commit 8bd701c03c
Signed by: ishan
GPG Key ID: 0506DB2A1CC75C27
3 changed files with 22 additions and 4 deletions

View File

@ -19,6 +19,7 @@ pub const BUILTINS: LazyCell<HashMap<&'static str, Object>> = LazyCell::new(|| {
match &args[0] { match &args[0] {
Object::String(s) => Object::Integer(s.len() as i64), Object::String(s) => Object::Integer(s.len() as i64),
Object::Array(s) => Object::Integer(s.elements.len() as i64), Object::Array(s) => Object::Integer(s.elements.len() as i64),
Object::Hash(h) => Object::Integer(h.pairs.len() as i64),
v => Object::Error(format!("argument to `len` not supported, got {}", v)), v => Object::Error(format!("argument to `len` not supported, got {}", v)),
} }
}), }),
@ -110,5 +111,17 @@ pub const BUILTINS: LazyCell<HashMap<&'static str, Object>> = LazyCell::new(|| {
}), }),
}), }),
); );
map.insert(
"puts",
Object::Builtin(BuiltinFunction {
func: Box::new(|args: Vec<Object>| {
for arg in args {
println!("{}", arg.inspect());
}
Object::Null
}),
}),
);
map map
}); });

View File

@ -517,6 +517,7 @@ mod tests {
elements: vec![Object::Integer(1), Object::Integer(5)], elements: vec![Object::Integer(1), Object::Integer(5)],
})), })),
), ),
("len({\"foo\": \"bar\"})", Some(Object::Integer(1))),
]; ];
run_test_cases(&test_cases); run_test_cases(&test_cases);

View File

@ -318,10 +318,14 @@ impl TreeWalker {
} }
fn eval_hash_index_expression(&self, left: &HashObject, index: Object) -> Option<Object> { fn eval_hash_index_expression(&self, left: &HashObject, index: Object) -> Option<Object> {
Some(Object::Error(format!( if let Object::Function(_) = index {
"index operator not supported: {:?}", return Some(Object::Error(format!("unusable as hash key: {}", index)));
left }
)))
match left.pairs.get(&index) {
Some(v) => Some(v.clone()),
None => Some(Object::Null),
}
} }
fn eval_array_index_expression(array: &Array, index: i64) -> Object { fn eval_array_index_expression(array: &Array, index: i64) -> Object {
let max = array.elements.len() as i64; let max = array.elements.len() as i64;