summaryrefslogtreecommitdiffstats
path: root/lib.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib.c')
-rw-r--r--lib.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/lib.c b/lib.c
index c2180abb..040294b5 100644
--- a/lib.c
+++ b/lib.c
@@ -1486,6 +1486,52 @@ val seqp(val obj)
return tnil(si.kind != SEQ_NOTSEQ);
}
+val list_seq(val seq)
+{
+ val self = lit("list-seq");
+ seq_iter_t iter;
+ val elem;
+ seq_iter_init(self, &iter, seq);
+ list_collect_decl (out, ptail);
+
+ while (seq_get(&iter, &elem))
+ ptail = list_collect(ptail, elem);
+
+ return out;
+}
+
+val vec_seq(val seq)
+{
+ val self = lit("vec-seq");
+ seq_iter_t iter;
+ val elem;
+ val vec = vector(zero, nil);
+ seq_iter_init(self, &iter, seq);
+
+ while (seq_get(&iter, &elem))
+ vec_push(vec, elem);
+
+ return vec;
+}
+
+val str_seq(val seq)
+{
+ val self = lit("str-seq");
+ seq_iter_t iter;
+ val elem;
+ val str = mkustring(zero);
+ seq_iter_init(self, &iter, seq);
+
+ while (seq_get(&iter, &elem)) {
+ if (chrp(elem) || stringp(elem))
+ string_extend(str, elem);
+ else
+ unsup_obj(self, elem);
+ }
+
+ return str;
+}
+
loc list_collect(loc ptail, val obj)
{
val items = cons(obj, nil);