summaryrefslogtreecommitdiffstats
path: root/stream.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2016-04-20 06:30:36 -0700
committerKaz Kylheku <kaz@kylheku.com>2016-04-20 06:30:36 -0700
commit814b1a284fc22feb9444f2195a36c57cbacd84aa (patch)
tree2d452a5528667d95f7bb71a99d4b84a490f0836e /stream.c
parentc636a168cd57ca5db253db7a0907f06621a6991e (diff)
downloadtxr-814b1a284fc22feb9444f2195a36c57cbacd84aa.tar.gz
txr-814b1a284fc22feb9444f2195a36c57cbacd84aa.tar.bz2
txr-814b1a284fc22feb9444f2195a36c57cbacd84aa.zip
Recycle conses in unget-char and read-until-match.
* regex.c (ead_until_match): Use rcyc_pop instead of pop to move the conses to the recycle list. We know these are not shared with anything. Adding additional logic to completely recycle the stack. * socket.c (dgram_get_char): Use rcyc_pop to get the character from the push-back list. * stream.c (stdio_get_char): Likewise.
Diffstat (limited to 'stream.c')
-rw-r--r--stream.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/stream.c b/stream.c
index 774359f4..3acf430a 100644
--- a/stream.c
+++ b/stream.c
@@ -685,7 +685,7 @@ static val stdio_get_char(val stream)
struct stdio_handle *h = coerce(struct stdio_handle *, stream->co.handle);
if (h->unget_c)
- return pop(&h->unget_c);
+ return rcyc_pop(&h->unget_c);
if (h->f) {
wint_t ch = utf8_decode(&h->ud, stdio_get_char_callback,