diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2015-09-06 18:35:48 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2015-09-06 18:35:48 -0700 |
commit | c2e0ec801502ae26dae3dfdd035ff10436cffedd (patch) | |
tree | c27e5fd60688f16939d98d331fa4bbe0d2a0303a /parser.c | |
parent | 59aa1488ac6deec474dc5287d4866223e1bcd005 (diff) | |
download | txr-c2e0ec801502ae26dae3dfdd035ff10436cffedd.tar.gz txr-c2e0ec801502ae26dae3dfdd035ff10436cffedd.tar.bz2 txr-c2e0ec801502ae26dae3dfdd035ff10436cffedd.zip |
Allow evaluation from repl to be interrupted.
* eval.c (do_eval): Check for pending signals.
* parser.c (repl_intr): New static function.
(repl): Set up signal handler for SIGINT around REPL.
* signal.h (sig_deferred): declared.
(sig_check_fast): New inline function/macro.
A bit of a rearrangement here.
Diffstat (limited to 'parser.c')
-rw-r--r-- | parser.c | 7 |
1 files changed, 7 insertions, 0 deletions
@@ -473,6 +473,11 @@ static void provide_completions(const char *data, } } +static val repl_intr(val signo, val async_p) +{ + uw_throw(error_s, lit("intr")); +} + val repl(val bindings, val in_stream, val out_stream) { val ifd = stream_get_prop(in_stream, fd_k); @@ -489,6 +494,7 @@ val repl(val bindings, val in_stream, val out_stream) val result_hash = make_hash(nil, nil, nil); val done = nil; val counter = one; + val old_sig_handler = set_sig_handler(num(SIGINT), func_n2(repl_intr)); reg_varl(result_hash_sym, result_hash); @@ -570,6 +576,7 @@ val repl(val bindings, val in_stream, val out_stream) gc_hint(prompt); } + set_sig_handler(num(SIGINT), old_sig_handler); free(prompt_u8); free(line_u8); lino_free(ls); |