summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2000-08-24 22:38:39 (GMT)
committerFred Drake <fdrake@acm.org>2000-08-24 22:38:39 (GMT)
commit6d63adfbb7e97b218bede1052d3826b3461e9c59 (patch)
treea586109a41da3627dee96786ace955b43e58db43
parent9ed49e979f342d0341d0208ea1ee12ad80835a91 (diff)
downloadcpython-6d63adfbb7e97b218bede1052d3826b3461e9c59.zip
cpython-6d63adfbb7e97b218bede1052d3826b3461e9c59.tar.gz
cpython-6d63adfbb7e97b218bede1052d3826b3461e9c59.tar.bz2
Improve the exceptions raised by PyErr_BadInternalCall(); adding the
filename and line number of the call site to allow esier debugging. This closes SourceForge patch #101214.
-rw-r--r--Include/pyerrors.h5
-rw-r--r--Python/errors.c17
2 files changed, 20 insertions, 2 deletions
diff --git a/Include/pyerrors.h b/Include/pyerrors.h
index f461068..6e60353 100644
--- a/Include/pyerrors.h
+++ b/Include/pyerrors.h
@@ -82,7 +82,12 @@ extern DL_IMPORT(PyObject *) PyErr_SetFromWindowsErrWithFilename(int, const char
extern DL_IMPORT(PyObject *) PyErr_SetFromWindowsErr(int);
#endif
+/* Export the old function so that the existing API remains available: */
extern DL_IMPORT(void) PyErr_BadInternalCall(void);
+extern DL_IMPORT(void) _PyErr_BadInternalCall(char *filename, int lineno);
+/* Mask the old API with a call to the new API for code compiled under
+ Python 2.0: */
+#define PyErr_BadInternalCall() _PyErr_BadInternalCall(__FILE__, __LINE__)
/* Function to create a new exception */
DL_IMPORT(PyObject *) PyErr_NewException(char *name, PyObject *base,
diff --git a/Python/errors.c b/Python/errors.c
index ffa7f82..8486423 100644
--- a/Python/errors.c
+++ b/Python/errors.c
@@ -369,11 +369,24 @@ PyObject *PyErr_SetFromWindowsErr(int ierr)
#endif /* MS_WINDOWS */
void
+_PyErr_BadInternalCall(char *filename, int lineno)
+{
+ PyErr_Format(PyExc_SystemError,
+ "%s:%d: bad argument to internal function",
+ filename, lineno);
+}
+
+/* Remove the preprocessor macro for PyErr_BadInternalCall() so that we can
+ export the entry point for existing object code: */
+#undef PyErr_BadInternalCall
+void
PyErr_BadInternalCall(void)
{
- PyErr_SetString(PyExc_SystemError,
- "bad argument to internal function");
+ PyErr_Format(PyExc_SystemError,
+ "bad argument to internal function");
}
+#define PyErr_BadInternalCall() _PyErr_BadInternalCall(__FILE__, __LINE__)
+
PyObject *