The following patch should fix the problem:

# HG changeset patch
# User ZyX <[email protected]>
# Date 1390927556 -14400
#      Tue Jan 28 20:45:56 2014 +0400
# Branch VimTryEnd-current_exception-fix
# Node ID 5595c64ce5eaeefe60958ae5cb93f9f1ab359a0c
# Parent  c9cad40b418113f62ce3481f66351137b90910ef
Only work with exception variables if did_throw

Second change assumes that whenever did_throw is TRUE discard_current_exception
is valid. First change assumes that if did_throw is not TRUE then need_rethrow
and current_exception values are not valid and do not require any attention.

diff -r c9cad40b4181 -r 5595c64ce5ea src/if_py_both.h
--- a/src/if_py_both.h  Fri Jan 24 19:55:37 2014 +0100
+++ b/src/if_py_both.h  Tue Jan 28 20:45:56 2014 +0400
@@ -564,10 +564,8 @@
     /* 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 @@
     /* 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 */

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
For more options, visit https://groups.google.com/groups/opt_out.
*** /tmp/extdiff.735OVr/vim-small-patches.c9cad40b4181/src/if_py_both.h	2014-01-28 20:47:50.617024419 +0400
--- vim-small-patches.5595c64ce5ea/src/if_py_both.h	2014-01-28 20:47:50.621024418 +0400
***************
*** 564,573 ****
      /* Keyboard interrupt should be preferred over anything else */
      if (got_int)
      {
! 	if (current_exception != NULL)
  	    discard_current_exception();
- 	else
- 	    need_rethrow = did_throw = FALSE;
  	got_int = FALSE;
  	PyErr_SetNone(PyExc_KeyboardInterrupt);
  	return -1;
--- 564,571 ----
      /* Keyboard interrupt should be preferred over anything else */
      if (got_int)
      {
! 	if (did_throw)
  	    discard_current_exception();
  	got_int = FALSE;
  	PyErr_SetNone(PyExc_KeyboardInterrupt);
  	return -1;
***************
*** 599,608 ****
      /* 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;
  	return -1;
      }
      /* Finally transform VimL exception to python one */
--- 597,603 ----
      /* Python exception is preferred over vim one; unlikely to occur though */
      else if (PyErr_Occurred())
      {
! 	discard_current_exception();
  	return -1;
      }
      /* Finally transform VimL exception to python one */

Raspunde prin e-mail lui