Change sys_exit to use METH_VARARGS.

sys.exit() now requires 0-1 arguments.  Previously 2+ arguments were allowed.
This commit is contained in:
Neal Norwitz 2002-03-27 13:03:09 +00:00
parent 496f9e41ef
commit 0c766a0bb6
2 changed files with 8 additions and 2 deletions

View file

@ -146,8 +146,11 @@ This should be called from inside an except clause only.";
static PyObject *
sys_exit(PyObject *self, PyObject *args)
{
PyObject *exit_code = 0;
if (!PyArg_ParseTuple(args, "|O:exit", &exit_code))
return NULL;
/* Raise SystemExit so callers may catch it or clean up. */
PyErr_SetObject(PyExc_SystemExit, args);
PyErr_SetObject(PyExc_SystemExit, exit_code);
return NULL;
}
@ -528,7 +531,7 @@ static PyMethodDef sys_methods[] = {
{"displayhook", sys_displayhook, METH_O, displayhook_doc},
{"exc_info", (PyCFunction)sys_exc_info, METH_NOARGS, exc_info_doc},
{"excepthook", sys_excepthook, METH_VARARGS, excepthook_doc},
{"exit", sys_exit, METH_OLDARGS, exit_doc},
{"exit", sys_exit, METH_VARARGS, exit_doc},
#ifdef Py_USING_UNICODE
{"getdefaultencoding", (PyCFunction)sys_getdefaultencoding, METH_NOARGS,
getdefaultencoding_doc},