diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2021-09-07 07:21:53 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2021-09-07 07:21:53 -0700 |
commit | b8ba39ca691b71d2d6f66959c0787693c563dc4f (patch) | |
tree | ba39aef9d5f33b51cefae00333af025614a19ef1 /lib.c | |
parent | 98ed59198be3104e82c00734e01f4a1022440d1b (diff) | |
download | txr-b8ba39ca691b71d2d6f66959c0787693c563dc4f.tar.gz txr-b8ba39ca691b71d2d6f66959c0787693c563dc4f.tar.bz2 txr-b8ba39ca691b71d2d6f66959c0787693c563dc4f.zip |
string-finish: new function.
* eval.c (eval_init): Register string-finish intrinsic.
* lib.c (string_finish): New function.
* lib.h (string_finish): Declared.
* txr.1: Documented.
* stdlib/doc-syms.tl: Updated.
Diffstat (limited to 'lib.c')
-rw-r--r-- | lib.c | 19 |
1 files changed, 19 insertions, 0 deletions
@@ -4843,6 +4843,25 @@ val string_extend(val str, val tail, val finish_in) return str; } +val string_finish(val str) +{ + val self = lit("string-finish"); + type_check(self, str, STR); + + { + cnum len = c_fixnum(length_str(str), self); + cnum alloc = c_fixnum(str->st.alloc, self); + + if (alloc > len + 1) { + alloc = len + 1; + str->st.str = chk_wrealloc(str->st.str, alloc); + set(mkloc(str->st.alloc, str), num_fast(alloc)); + } + } + + return str; +} + val stringp(val str) { switch (type(str)) { |