From 85b3f17007825b023d549d8e926322797e08ce6d Mon Sep 17 00:00:00 2001 From: William Carroll Date: Mon, 5 Sep 2022 11:41:50 -0700 Subject: feat(tvix/eval): Support builtins.head TL;DR: - support `builtins.head` - define `ErrorKind::IndexOutOfBounds` and canonical error code - support basic unit tests Change-Id: I859107ffb4e220cba1be8c2ac41d1913dcca37ff Reviewed-on: https://cl.tvl.fyi/c/depot/+/6544 Reviewed-by: wpcarro Autosubmit: wpcarro Reviewed-by: sterni Reviewed-by: tazjin Tested-by: BuildkiteCI --- tvix/eval/src/builtins/mod.rs | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'tvix/eval/src/builtins/mod.rs') diff --git a/tvix/eval/src/builtins/mod.rs b/tvix/eval/src/builtins/mod.rs index 74215cd37c..3598ac71f7 100644 --- a/tvix/eval/src/builtins/mod.rs +++ b/tvix/eval/src/builtins/mod.rs @@ -75,6 +75,14 @@ fn pure_builtins() -> Vec { } Ok(Value::Integer(args[0].to_list()?.len() as i64)) }), + Builtin::new("head", 1, |args, vm| { + force!(vm, &args[0], xs, { + match xs.to_list()?.get(0) { + Some(x) => Ok(x.clone()), + None => Err(ErrorKind::IndexOutOfBounds { index: 0 }), + } + }) + }), Builtin::new("isAttrs", 1, |args, _| { Ok(Value::Bool(matches!(args[0], Value::Attrs(_)))) }), -- cgit 1.4.1