summaryrefslogtreecommitdiffstats
path: root/socket.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 /socket.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 'socket.c')
-rw-r--r--socket.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/socket.c b/socket.c
index 102127b9..5871632e 100644
--- a/socket.c
+++ b/socket.c
@@ -436,7 +436,7 @@ static val dgram_get_char(val stream)
struct dgram_stream *d = coerce(struct dgram_stream *, stream->co.handle);
if (d->unget_c) {
- return pop(&d->unget_c);
+ return rcyc_pop(&d->unget_c);
} else {
wint_t ch = utf8_decode(&d->ud, dgram_get_byte_callback,
coerce(mem_t *, d));