summaryrefslogtreecommitdiffstats
path: root/txr.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2017-08-18 06:38:30 -0700
committerKaz Kylheku <kaz@kylheku.com>2017-08-18 06:38:30 -0700
commitb79bc438aadeda878eaa2a26c72129edffba4be7 (patch)
tree0b5e993bb988e49375d5d6d75549ae7e330932ac /txr.c
parent56ff4d38c78dd99873017c075861efefe5428bad (diff)
downloadtxr-b79bc438aadeda878eaa2a26c72129edffba4be7.tar.gz
txr-b79bc438aadeda878eaa2a26c72129edffba4be7.tar.bz2
txr-b79bc438aadeda878eaa2a26c72129edffba4be7.zip
Revising out-of-memory handling.
We don't want to be aborting on OOM, but throwing an exception. * lib.c (alloc_error_s): New symbol variable. (oom_realloc): Global variable removed. (oom): New static function. (chk_malloc, chk_malloc_gc_more, chk_calloc, chk_realloc): Call oom instead of removed oom_realloc handler. (env): Throw alloc-error rather than error by calling oom. (obj_init): Initialize alloc_error_s. (init): Drop function pointer argument; do not initialize removed oom_realloc. * lib.h (alloc_error_s): Declared. (oom_realloc): Declaration removed. (init): Declaration updated. * txr.1: Type tree diagram includes alloc-error.
Diffstat (limited to 'txr.c')
-rw-r--r--txr.c15
1 files changed, 1 insertions, 14 deletions
diff --git a/txr.c b/txr.c
index 16cecb63..2591b339 100644
--- a/txr.c
+++ b/txr.c
@@ -68,19 +68,6 @@ int opt_compat;
int opt_dbg_expansion;
val stdlib_path;
-/*
- * Can implement an emergency allocator here from a fixed storage
- * pool, which sets an OOM flag. Program can check flag
- * and gracefully terminate instead of aborting like this.
- */
-static mem_t *oom_realloc_handler(mem_t *old, size_t size)
-{
- format(std_error, lit("~a: out of memory\n"), prog_string, nao);
- if (opt_print_bindings)
- put_line(lit("false"), std_output);
- abort();
-}
-
static void help(void)
{
val text = lit(
@@ -375,7 +362,7 @@ int main(int argc, char **argv)
repress_privilege();
progname = utf8_dup_from(argv[0] ? argv[0]: "txr");
progname_u8 = argv[0];
- init(oom_realloc_handler, &stack_bottom);
+ init(&stack_bottom);
match_init();
debug_init();
sysroot_init();