summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2019-06-15 21:48:49 -0700
committerKaz Kylheku <kaz@kylheku.com>2019-06-15 21:48:49 -0700
commitf301e8071b32552f8096286ae7c978ab9e79061c (patch)
tree706db4722d98dc283b7663ea58d93884596807c3
parent3f87793404053b98fe0f6a20fafaf7e841f23f71 (diff)
downloadtxr-f301e8071b32552f8096286ae7c978ab9e79061c.tar.gz
txr-f301e8071b32552f8096286ae7c978ab9e79061c.tar.bz2
txr-f301e8071b32552f8096286ae7c978ab9e79061c.zip
buffers: expose sub-buf and replace-buf.
* buf.c (buf_init): Intrinsics sub-buf and replace-buf registered. * txr.1: Documented.
-rw-r--r--buf.c2
-rw-r--r--txr.159
2 files changed, 61 insertions, 0 deletions
diff --git a/buf.c b/buf.c
index 506ac45a..910d7801 100644
--- a/buf.c
+++ b/buf.c
@@ -1075,6 +1075,8 @@ void buf_init(void)
reg_fun(intern(lit("length-buf"), user_package), func_n1(length_buf));
reg_fun(intern(lit("buf-alloc-size"), user_package), func_n1(buf_alloc_size));
reg_fun(intern(lit("copy-buf"), user_package), func_n1(copy_buf));
+ reg_fun(intern(lit("sub-buf"), user_package), func_n3(sub_buf));
+ reg_fun(intern(lit("replace-buf"), user_package), func_n4(replace_buf));
#if HAVE_I8
reg_fun(intern(lit("buf-put-i8"), user_package), func_n3(buf_put_i8));
diff --git a/txr.1 b/txr.1
index 72cbdbce..635ce352 100644
--- a/txr.1
+++ b/txr.1
@@ -26873,6 +26873,13 @@ object, then the function behaves like
If
.meta sequence
+is a
+.code buf
+object, then the function behaves like
+.codn buf-sub .
+
+If
+.meta sequence
is a structure, it must support the
.code lambda
method. The
@@ -27051,6 +27058,15 @@ behaves like
If
.meta sequence
+is a
+.code buf
+object, then
+.code replace
+behaves like
+.codn buf-replace .
+
+If
+.meta sequence
is a structure, then the structure must support the
.code lambda-set
method. The
@@ -59542,6 +59558,49 @@ which has the same length and contents, and compares
to
.metn buf .
+.coNP Function @ sub-buf
+.synb
+.mets (sub-buf < buf >> [ from <> [ to ]])
+.syne
+.desc
+The
+.code sub-buf
+function has the same semantics as the
+.code sub
+function, except that the first argument must be a buffer.
+
+The extracted sub-range of a buffer is itself a buffer object.
+
+For a description of the arguments and semantics, refer to the
+.code sub
+function.
+
+.coNP Function @ replace-buf
+.synb
+.mets (replace-buf < buf < item-sequence >> [ from <> [ to ]])
+.syne
+.desc
+The
+.code replace-buf
+function has the same semantics as the
+.code replace
+function, except that the first argument must be a buffer.
+
+The elements of
+.code item-sequence
+are stored into
+.meta buf
+as if using the
+.code buf-put-u8
+function and therefore must be suitable
+.meta val
+arguments for that function.
+
+The of the arguments, semantics and return value given for
+.code replace
+apply to
+.codn replace-buf .
+
.coNP Function @ buf-put-i8
.synb
.mets (buf-put-i8 < buf < pos << val )