mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-30 20:00:19 +02:00
* libguile/gc.c (scm_oom_fn, scm_init_gc): Install an out-of-memory handler that raises an unwind-only out-of-memory exception. (scm_gc_warn_proc, scm_init_gc): Install a warning proc that tries to print to the current warning port, if the current warning port is a file port. (scm_gc_after_nonlocal_exit): New interface. Should be called after a nonlocal return to potentially collect memory; otherwise allocations could try to expand again when they should collect. * libguile/continuations.c (scm_i_make_continuation): * libguile/eval.c (eval): * libguile/throw.c (catch): * libguile/vm.c (scm_call_n): Call scm_gc_after_nonlocal_exit after nonlocal returns. * libguile/throw.c (abort_to_prompt, throw_without_pre_unwind): Rework to avoid allocating memory. (scm_report_out_of_memory): New interface. (scm_init_throw): Pre-allocate the arguments for stack-overflow and out-of-memory errors. * module/ice-9/boot-9.scm: Add an out-of-memory exception printer. * module/system/repl/error-handling.scm (call-with-error-handling): Add out-of-memory to the report-keys set. * libguile/gc-malloc.c (scm_realloc): Call scm_report_out_of_memory if realloc fails. * libguile/error.h: * libguile/error.c: * libguile/deprecated.h: * libguile/deprecated.c (scm_memory_error): Deprecate. * test-suite/standalone/Makefile.am: * test-suite/standalone/test-out-of-memory: New test case.
79 lines
2.8 KiB
C
79 lines
2.8 KiB
C
/* classes: h_files */
|
||
|
||
#ifndef SCM_ERROR_H
|
||
#define SCM_ERROR_H
|
||
|
||
/* Copyright (C) 1995,1996,1997,1998,2000,2001, 2002, 2006, 2008, 2011, 2014 Free Software Foundation, Inc.
|
||
*
|
||
* This library is free software; you can redistribute it and/or
|
||
* modify it under the terms of the GNU Lesser General Public License
|
||
* as published by the Free Software Foundation; either version 3 of
|
||
* the License, or (at your option) any later version.
|
||
*
|
||
* This library is distributed in the hope that it will be useful, but
|
||
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
* Lesser General Public License for more details.
|
||
*
|
||
* You should have received a copy of the GNU Lesser General Public
|
||
* License along with this library; if not, write to the Free Software
|
||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
||
* 02110-1301 USA
|
||
*/
|
||
|
||
|
||
|
||
#include "libguile/__scm.h"
|
||
|
||
|
||
SCM_API SCM scm_system_error_key;
|
||
SCM_API SCM scm_num_overflow_key;
|
||
SCM_API SCM scm_out_of_range_key;
|
||
SCM_API SCM scm_args_number_key;
|
||
SCM_API SCM scm_arg_type_key;
|
||
SCM_API SCM scm_misc_error_key;
|
||
|
||
|
||
|
||
#define SCM_ASSERT(_cond, _arg, _pos, _subr) \
|
||
do { if (SCM_UNLIKELY (!(_cond))) \
|
||
scm_wrong_type_arg (_subr, _pos, _arg); } while (0)
|
||
#define SCM_ASSERT_TYPE(_cond, _arg, _pos, _subr, _msg) \
|
||
do { if (SCM_UNLIKELY (!(_cond))) \
|
||
scm_wrong_type_arg_msg(_subr, _pos, _arg, _msg); } while (0)
|
||
|
||
|
||
|
||
|
||
SCM_API void scm_error (SCM key, const char *subr, const char *message,
|
||
SCM args, SCM rest) SCM_NORETURN;
|
||
SCM_API SCM scm_error_scm (SCM key, SCM subr, SCM message,
|
||
SCM args, SCM rest) SCM_NORETURN;
|
||
SCM_API SCM scm_strerror (SCM err);
|
||
SCM_API void scm_syserror (const char *subr) SCM_NORETURN;
|
||
SCM_API void scm_syserror_msg (const char *subr, const char *message,
|
||
SCM args, int eno) SCM_NORETURN;
|
||
SCM_API void scm_num_overflow (const char *subr) SCM_NORETURN;
|
||
SCM_API void scm_out_of_range (const char *subr, SCM bad_value)
|
||
SCM_NORETURN;
|
||
SCM_API void scm_out_of_range_pos (const char *subr, SCM bad_value, SCM pos)
|
||
SCM_NORETURN;
|
||
SCM_API void scm_wrong_num_args (SCM proc) SCM_NORETURN;
|
||
SCM_API void scm_error_num_args_subr (const char* subr) SCM_NORETURN;
|
||
SCM_API void scm_wrong_type_arg (const char *subr, int pos,
|
||
SCM bad_value) SCM_NORETURN;
|
||
SCM_INTERNAL void scm_i_wrong_type_arg_symbol (SCM symbol, int pos,
|
||
SCM bad_value) SCM_NORETURN;
|
||
SCM_API void scm_wrong_type_arg_msg (const char *subr, int pos,
|
||
SCM bad_value, const char *sz) SCM_NORETURN;
|
||
SCM_API void scm_misc_error (const char *subr, const char *message,
|
||
SCM args) SCM_NORETURN;
|
||
SCM_INTERNAL void scm_init_error (void);
|
||
|
||
#endif /* SCM_ERROR_H */
|
||
|
||
/*
|
||
Local Variables:
|
||
c-file-style: "gnu"
|
||
End:
|
||
*/
|