summaryrefslogtreecommitdiffstats
path: root/tree.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2019-10-16 00:05:08 -0700
committerKaz Kylheku <kaz@kylheku.com>2019-10-16 00:05:08 -0700
commit337ffc1e586d48b5fe6a334a6fd61587961fe261 (patch)
tree1bc2179b76884142de6d00a6361fe6029ba6b99f /tree.c
parentc59462de5168b4050ff8517e8215a7692949e85b (diff)
downloadtxr-337ffc1e586d48b5fe6a334a6fd61587961fe261.tar.gz
txr-337ffc1e586d48b5fe6a334a6fd61587961fe261.tar.bz2
txr-337ffc1e586d48b5fe6a334a6fd61587961fe261.zip
tree: introduce copy-tnode.
* lib.c (copy): Handle TNOD casee via copy_tnode. * tree.c (copy_tnode): New function. (tree_init): copy-tnode intrinsic registered. * tree.h (copy_tnode): Declared. * txr.1: copy function documented as handling tnode type via copy-tnode. That function is documented.
Diffstat (limited to 'tree.c')
-rw-r--r--tree.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/tree.c b/tree.c
index 22cac379..43330c06 100644
--- a/tree.c
+++ b/tree.c
@@ -119,6 +119,13 @@ val key(val node)
return node->tn.key;
}
+val copy_tnode(val node)
+{
+ val obj = (type_check(lit("copy-tnode"), node, TNOD), make_obj());
+ obj->tn = node->tn;
+ return obj;
+}
+
static ucnum tn_size(val node)
{
return 1 + if3(node->tn.right, tn_size(node->tn.right), 0) +
@@ -677,6 +684,7 @@ void tree_init(void)
reg_fun(intern(lit("left"), user_package), func_n1(left));
reg_fun(intern(lit("right"), user_package), func_n1(right));
reg_fun(intern(lit("key"), user_package), func_n1(key));
+ reg_fun(intern(lit("copy-tnode"), user_package), func_n1(copy_tnode));
reg_fun(tree_s, func_n4o(tree, 0));
reg_fun(tree_construct_s, func_n2(tree_construct));
reg_fun(intern(lit("treep"), user_package), func_n1(treep));