aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2018-08-21 16:48:30 +0100
committerPedro Alves <palves@redhat.com>2018-08-21 16:48:30 +0100
commit4895f384b47628c8c354dccbb0bfab45b8c33984 (patch)
tree234161ab89a377ef079869d8663b41f4a2719202 /include
parentae19acf3201ee0b921cde8e70e278fe123e82105 (diff)
downloadgdb-4895f384b47628c8c354dccbb0bfab45b8c33984.zip
gdb-4895f384b47628c8c354dccbb0bfab45b8c33984.tar.gz
gdb-4895f384b47628c8c354dccbb0bfab45b8c33984.tar.bz2
Don't throw Scheme exceptions with live std::vector objects
A complication with the Guile code is that we have two types of exceptions to consider: GDB/C++ exceptions, and Guile/SJLJ exceptions. Because Guile exceptions are SJLJ based, we must make sure to not have live local variables of types with non-trivial dtors when a Guile exception is thrown, because the dtors won't be run when a Guile exceptions is thrown. gdbscm_parse_function_args currently violates this: void gdbscm_parse_function_args (const char *func_name, int beginning_arg_pos, const SCM *keywords, const char *format, ...) { ... /* Keep track of malloc'd strings. We need to free them upon error. */ std::vector<char *> allocated_strings; ... for (char *ptr : allocated_strings) xfree (ptr); gdbscm_throw (status); /// dtor of "allocated_strings" is not run! } This commit fixes the above making using of gdbscm_wrap. It would be nice if we had a way to make it impossible to write such code. PR guile/23429 has an idea for that, if someone's interested. gdb/ChangeLog: 2018-08-21 Pedro Alves <palves@redhat.com> * guile/scm-utils.c (gdbscm_parse_function_args_1): New, factored out from gdbscm_parse_function_args. (gdbscm_parse_function_args): Rework to use gdbscm_wrap and gdbscm_parse_function_args_1.
Diffstat (limited to 'include')
0 files changed, 0 insertions, 0 deletions