diff options
-rw-r--r-- | ChangeLog | 10 | ||||
-rw-r--r-- | stream.c | 21 |
2 files changed, 28 insertions, 3 deletions
@@ -1,5 +1,15 @@ 2011-12-06 Kaz Kylheku <kaz@kylheku.com> + * stream.c (find_char): New function. + (string_in_get_line): Following up TODO. Fixed broken + function. Now get_line on a string stream properly returns characters + up to and not including the next newlne character, and also consumes + the newline character. Other cases are handled properly, also: + the stream being at EOF already, or at the last line not being + newline-terminated. + +2011-12-06 Kaz Kylheku <kaz@kylheku.com> + * eval.c (op_unwind_protect): Fixed uninitialized variable warning. (eval_init): New functions registered: typeof and vector functions, @@ -306,16 +306,31 @@ static void string_in_stream_mark(val stream) gc_mark(stuff); } +static val find_char(val string, val start, val ch) +{ + const wchar_t *str = c_str(string); + cnum pos = c_num(start); + cnum len = c_num(length_str(string)); + wchar_t c = c_chr(ch); + + for (; pos < len; pos++) { + if (str[pos] == c) + return num(pos); + } + + return nil; +} + static val string_in_get_line(val stream) { val pair = (val) stream->co.handle; val string = car(pair); val pos = cdr(pair); - /* TODO: broken, should only scan to newline */ if (lt(pos, length_str(string))) { - val result = sub_str(string, pos, nil); - *cdr_l(pair) = length_str(string); + val nlpos = find_char(string, pos, chr('\n')); + val result = sub_str(string, pos, nlpos); + *cdr_l(pair) = nlpos ? plus(nlpos, one) : length_str(string); return result; } |