summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2014-01-31 14:54:04 +0100
committerBram Moolenaar <Bram@vim.org>2014-01-31 14:54:04 +0100
commit4315f26500934bff48ed9bda85d2c9db0c8c73f7 (patch)
treee1cfa888575dadbcae99dd8c66e9752d1d18fd4e
parentfcc3f46735b8c47fde0961228ca1fdd20cb709a0 (diff)
updated for version 7.4.161v7.4.161
Problem: Crash in Python exception handling. Solution: Only use exception variables if did_throw is set. (ZyX)
-rw-r--r--src/if_py_both.h9
-rw-r--r--src/version.c2
2 files changed, 4 insertions, 7 deletions
diff --git a/src/if_py_both.h b/src/if_py_both.h
index 4d81a4b927..dd7e82a713 100644
--- a/src/if_py_both.h
+++ b/src/if_py_both.h
@@ -564,10 +564,8 @@ VimTryEnd(void)
/* Keyboard interrupt should be preferred over anything else */
if (got_int)
{
- if (current_exception != NULL)
+ if (did_throw)
discard_current_exception();
- else
- need_rethrow = did_throw = FALSE;
got_int = FALSE;
PyErr_SetNone(PyExc_KeyboardInterrupt);
return -1;
@@ -599,10 +597,7 @@ VimTryEnd(void)
/* Python exception is preferred over vim one; unlikely to occur though */
else if (PyErr_Occurred())
{
- if (current_exception != NULL)
- discard_current_exception();
- else
- need_rethrow = did_throw = FALSE;
+ discard_current_exception();
return -1;
}
/* Finally transform VimL exception to python one */
diff --git a/src/version.c b/src/version.c
index 974c8f88fe..8501c0871a 100644
--- a/src/version.c
+++ b/src/version.c
@@ -739,6 +739,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 161,
+/**/
160,
/**/
159,