diff options
author | Tom Tromey <tromey@redhat.com> | 2013-05-30 17:18:54 +0000 |
---|---|---|
committer | Tom Tromey <tromey@redhat.com> | 2013-05-30 17:18:54 +0000 |
commit | f2be34e2d2574ca696ad9dfc7122a24a0d582fb7 (patch) | |
tree | b56965d6aadbb550197711ecc1eb774be9e0cf48 /gdb/python/py-value.c | |
parent | db1d5ba6b2833a2b4fdd360032e5090e9e575bff (diff) | |
download | gdb-f2be34e2d2574ca696ad9dfc7122a24a0d582fb7.tar.gz |
fix py-value.c
Some code in py-value.c could exit a loop without running some
cleanups made in the loop.
* python/py-value.c (valpy_binop): Call do_cleanups before
exiting loop.
Diffstat (limited to 'gdb/python/py-value.c')
-rw-r--r-- | gdb/python/py-value.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/gdb/python/py-value.c b/gdb/python/py-value.c index 0b2a38fa404..0d87219ae84 100644 --- a/gdb/python/py-value.c +++ b/gdb/python/py-value.c @@ -769,11 +769,17 @@ valpy_binop (enum valpy_opcode opcode, PyObject *self, PyObject *other) a gdb.Value object and need to convert it from python as well. */ arg1 = convert_value_from_python (self); if (arg1 == NULL) - break; + { + do_cleanups (cleanup); + break; + } arg2 = convert_value_from_python (other); if (arg2 == NULL) - break; + { + do_cleanups (cleanup); + break; + } switch (opcode) { |