|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| | added message attribute compared to the previous version of Exception.  It is
also a new-style class, making all exceptions now new-style.  KeyboardInterrupt
and SystemExit inherit from BaseException directly.  String exceptions now
raise DeprecationWarning.
Applies patch 1104669, and closes bugs 1012952 and 518846. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - New semantics for __exit__() -- it must re-raise the exception
  if type is not None; the with-statement itself doesn't do this.
  (See the updated PEP for motivation.)
- Added context managers to:
  - file
  - thread.LockType
  - threading.{Lock,RLock,Condition,Semaphore,BoundedSemaphore}
  - decimal.Context
- Added contextlib.py, which defines @contextmanager, nested(), closing().
- Unit tests all around; bot no docs yet. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | In a Windows debug build, trying to open a file using
an empty string as the name causes assertion death
inside MS's C runtime code.  We probably need to worm
around that in many places.  I'm worming around it here
to stop the new test_with.py from assert-dying in the
Windows debug build (it calls compile() with an empty
string for "the file name", which indirectly leads to
C-level code in Python trying to fopen("", "r")). | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| | * Py_BuildValue("(OOO)",a,b,c)  -->  PyTuple_Pack(3,a,b,c)
* Py_BuildValue("()",a)         -->  PyTuple_New(0)
* Py_BuildValue("O", a)         -->  Py_INCREF(a) | 
| | 
| 
| 
| 
| 
| | If the initial import of warnings fails, clear the error.  When the module
is actually needed, if the original import failed, see if it has managed
to find its way to sys.modules yet and if so, remember it. | 
| | 
| 
| 
| 
| 
| 
| 
| | return.  Setting an exception can mess with the exception state, and
continuing is definitely wrong (since type is dereferenced later on).
Some code that calls this seems to be prepared for a NULL exception
type, so let's be safe rather than sorry and simply assume there's
nothing to normalize in this case. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| | Ensure that even if FormatMessage fails we (a) don't crash, and (b) provide something useful.
Bugfix candidate. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | PyErr_SetExcFromWindowsErr(), PyErr_SetExcFromWindowsErrWithFilename().
Similar to PyErr_SetFromWindowsErrWithFilename() and
PyErr_SetFromWindowsErr(), but they allow to specify
the exception type to raise. Available on Windows.
See SF patch #576458. | 
| | 
| 
| 
| | Rename all occurrences of MS_WIN32 to MS_WINDOWS. | 
| | 
| 
| 
| 
| 
| 
| 
| | Highlights: import and friends will understand any of \r, \n and \r\n
as end of line. Python file input will do the same if you use mode 'U'.
Everything can be disabled by configuring with --without-universal-newlines.
See PEP278 for details. | 
| | |  | 
| | 
| 
| 
| 
| 
| | - recognize "SyntaxError"s by the print_file_and_line attribute.
- add the syntaxerror attributes to all exceptions in compile.c.
Fixes #221791 | 
| | 
| 
| 
| 
| 
| 
| | Unknown whether this fixes it.
- stringobject.c, PyString_FromFormatV:  don't assume that va_list is of
  a type that can be copied via an initializer.
- errors.c, PyErr_Format:  add a va_end() to balance the va_start(). | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | If a new exception occurs while an exception instance is being
created, try harder to make sure there is a traceback.  If the
original exception had a traceback associated with it and the new
exception does not, keep the old exception.
Of course, callers to PyErr_NormalizeException() must still be
prepared to have tb set to NULL.
XXX This isn't an ideal solution, but it's better than no traceback at
all.  It occurs if, for example, the exception occurs when the call to
the constructor fails before any Python code is executed.  Guido
suggests that it there is Python code that was about to be executed
-- but wasn't, say, because it was called with the wrong number of
arguments -- then we should point at the first line of the code object
anyway. | 
| | 
| 
| 
| 
| | PyString_FromFormat() since it's much more generally useful than
    just for exceptions. | 
| | 
| 
| 
| 
| 
| 
| 
| | in release builds.  Suggested by Martin v. Loewis.
I'm half tempted to macroize PyErr_Occurred too, as the whole thing could
collapse to just
     _PyThreadState_Current->curexc_type | 
| | |  | 
| | 
| 
| 
| | explicit filename, lineno etc. arguments. | 
| | 
| 
| 
| 
| 
| 
| | for errors raised in future.c.
Move some helper functions from compile.c to errors.c and make them
API functions: PyErr_SyntaxLocation() and PyErr_ProgramText(). | 
| | |  | 
| | 
| 
| 
| 
| 
| | Changes to error messages to increase consistency & clarity.
This (mostly) closes SourceForge patch #101839. | 
| | 
| 
| 
| 
| 
| 
| | these computations are required for their side effects in traversing the
variable arguments list.
Reported by Marc-Andre Lemburg <mal@lemburg.com>. | 
| | 
| 
| 
| | This should match the situation in the 1.6b1 tree. | 
| | 
| 
| 
| 
| | PyErr_Format computes size of buffer needed rather than relying on
static buffer. | 
| | 
| 
| 
| 
| | add sanity check to gc: if an exception occurs during GC, call
PyErr_WriteUnraisable and then call Py_FatalEror. | 
| | 
| 
| 
| 
| 
| | filename and line number of the call site to allow esier debugging.
This closes SourceForge patch #101214. | 
| | 
| 
| 
| | thus preserving the first one that has been raised. | 
| | 
| 
| 
| | an exception set.  This shouldn't happen, but we see it at times... | 
| | 
| 
| 
| | declarations yet, those come later. | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | return 0 (exceptions don't match).  This means that if an ImportError
is raised because exceptions.py can't be imported, the interpreter
will exit "cleanly" with an error message instead of just core
dumping.
PyErr_SetFromErrnoWithFilename(), PyErr_SetFromWindowsErrWithFilename():
Don't test on Py_UseClassExceptionsFlag. | 
| | 
| 
| 
| | in PyErr_SetFromWindowsErrWithFilename() like he intended to... :-) | 
| | 
| 
| 
| 
| | enough, it could be negative.  Add i > 0 test.  (Not i >= 0; zero isn't
a valid error number.) | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | * Changes to a recent patch by Chris Tismer to errors.c.  Chris' patch
always used FormatMessage() to get the error message passing the error code
from errno - but errno and FormatMessage use a different numbering scheme.
The main reason the patch looked OK was that ENOFILE==ERROR_FILE_NOT_FOUND -
but that is about the only shared error code :-).  The MS CRT docs tell you
to use _sys_errlist()/_sys_nerr.  My patch does also this, and adds a very
similar function specifically for win32 error codes. | 
| | 
| 
| 
| | strerror().  This improves the quality of the error messages. | 
| | |  | 
| | 
| 
| 
| | message. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | an exception from errno, with a supplied filename (primarily used by
IOError and OSError).  If class exceptions are used then the exception
is instantiated with a 3-tuple: (errno, strerror, filename).  For
backwards compatibility reasons, if string exceptions are used,
filename is ignored.
PyErr_SetFromErrno(): Implement in terms of
PyErr_SetFromErrnoWithFilename(). |