summaryrefslogtreecommitdiffstats
path: root/stream.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2014-03-06 07:35:15 -0800
committerKaz Kylheku <kaz@kylheku.com>2014-03-06 07:35:15 -0800
commit24b4b36628fd2ab3d3ff946907ad3a88e325a772 (patch)
tree0c05defafd9814dd57fb515f910859a84740aac5 /stream.c
parentbd49a5f0328a2a4091af212961d4d6581d159f67 (diff)
downloadtxr-24b4b36628fd2ab3d3ff946907ad3a88e325a772.tar.gz
txr-24b4b36628fd2ab3d3ff946907ad3a88e325a772.tar.bz2
txr-24b4b36628fd2ab3d3ff946907ad3a88e325a772.zip
* eval.c (apply_intrinsic, lazy_mapcar): Changed linkage to external.
* eval.h (apply_intrinsic, lazy_mapcar): Declarations added. * stream.c (open_files, open_file_star): New functions. (stream_init): Registered new functions as intrinsics. * txr.1: Documented open-files and open-files*. Added to make-catenated-stream documentation. * genvim.txr: Replace bunch of code with open-files. * txr.vim: Regenerated.
Diffstat (limited to 'stream.c')
-rw-r--r--stream.c27
1 files changed, 27 insertions, 0 deletions
diff --git a/stream.c b/stream.c
index 414e840e..912e6a80 100644
--- a/stream.c
+++ b/stream.c
@@ -2555,6 +2555,31 @@ val readlink_wrap(val path)
#endif
+static val open_files(val file_list, val substitute_stream)
+{
+ substitute_stream = default_bool_arg(substitute_stream);
+
+ if (nilp(file_list) && substitute_stream) {
+ return substitute_stream;
+ } else {
+ return apply_intrinsic(func_n0v(make_catenated_stream),
+ cons(mapcar(func_n2o(open_file, 1), file_list), nil));
+
+ }
+}
+
+static val open_files_star(val file_list, val substitute_stream)
+{
+ substitute_stream = default_bool_arg(substitute_stream);
+
+ if (nilp(file_list) && substitute_stream) {
+ return substitute_stream;
+ } else {
+ return apply_intrinsic(func_n0v(make_catenated_stream),
+ cons(lazy_mapcar(func_n2o(open_file, 1), file_list), nil));
+ }
+}
+
#endif
void stream_init(void)
@@ -2704,4 +2729,6 @@ void stream_init(void)
reg_fun(intern(lit("open-process"), user_package), func_n3o(open_process, 2));
reg_fun(intern(lit("remove-path"), user_package), func_n1(remove_path));
reg_fun(intern(lit("rename-path"), user_package), func_n2(rename_path));
+ reg_fun(intern(lit("open-files"), user_package), func_n2o(open_files, 1));
+ reg_fun(intern(lit("open-files*"), user_package), func_n2o(open_files_star, 1));
}