Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
Pyston
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
Pyston
Commits
077fffc6
Commit
077fffc6
authored
Feb 25, 2015
by
Kevin Modzelewski
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'exceptions'
parents
e3016cd2
acf80b82
Changes
23
Hide whitespace changes
Inline
Side-by-side
Showing
23 changed files
with
2553 additions
and
391 deletions
+2553
-391
Makefile
Makefile
+1
-1
from_cpython/CMakeLists.txt
from_cpython/CMakeLists.txt
+1
-1
from_cpython/Include/osdefs.h
from_cpython/Include/osdefs.h
+65
-0
from_cpython/Include/pyerrors.h
from_cpython/Include/pyerrors.h
+51
-106
from_cpython/Objects/exceptions.c
from_cpython/Objects/exceptions.c
+2236
-0
from_cpython/Python/formatter_unicode.c
from_cpython/Python/formatter_unicode.c
+20
-0
src/capi/errors.cpp
src/capi/errors.cpp
+67
-1
src/capi/object.cpp
src/capi/object.cpp
+4
-0
src/capi/typeobject.cpp
src/capi/typeobject.cpp
+4
-0
src/core/types.h
src/core/types.h
+0
-2
src/runtime/builtin_modules/builtins.cpp
src/runtime/builtin_modules/builtins.cpp
+0
-196
src/runtime/capi.cpp
src/runtime/capi.cpp
+13
-5
src/runtime/dict.cpp
src/runtime/dict.cpp
+15
-18
src/runtime/import.cpp
src/runtime/import.cpp
+7
-0
src/runtime/int.cpp
src/runtime/int.cpp
+2
-1
src/runtime/objmodel.cpp
src/runtime/objmodel.cpp
+1
-1
src/runtime/objmodel.h
src/runtime/objmodel.h
+1
-0
src/runtime/set.cpp
src/runtime/set.cpp
+1
-6
src/runtime/stacktrace.cpp
src/runtime/stacktrace.cpp
+6
-17
src/runtime/types.cpp
src/runtime/types.cpp
+37
-1
src/runtime/types.h
src/runtime/types.h
+21
-4
src/runtime/unicode.cpp
src/runtime/unicode.cpp
+0
-28
test/tests/exceptions_nonreprable.py
test/tests/exceptions_nonreprable.py
+0
-3
No files found.
Makefile
View file @
077fffc6
...
...
@@ -292,7 +292,7 @@ STDLIB_RELEASE_OBJS := stdlib.release.bc.o
ASM_SRCS
:=
$(
wildcard
src/runtime/
*
.S
)
STDMODULE_SRCS
:=
errnomodule.c shamodule.c sha256module.c sha512module.c _math.c mathmodule.c md5.c md5module.c _randommodule.c _sre.c operator.c binascii.c pwdmodule.c posixmodule.c _struct.c datetimemodule.c _functoolsmodule.c _collectionsmodule.c itertoolsmodule.c resource.c signalmodule.c selectmodule.c fcntlmodule.c timemodule.c arraymodule.c zlibmodule.c _codecsmodule.c socketmodule.c
$(EXTRA_STDMODULE_SRCS)
STDOBJECT_SRCS
:=
structseq.c capsule.c stringobject.c
$(EXTRA_STDOBJECT_SRCS)
STDOBJECT_SRCS
:=
structseq.c capsule.c stringobject.c
exceptions.c
$(EXTRA_STDOBJECT_SRCS)
STDPYTHON_SRCS
:=
pyctype.c getargs.c formatter_string.c pystrtod.c dtoa.c
$(EXTRA_STDPYTHON_SRCS)
FROM_CPYTHON_SRCS
:=
$(
addprefix
from_cpython/Modules/,
$(STDMODULE_SRCS)
)
$(
addprefix
from_cpython/Objects/,
$(STDOBJECT_SRCS)
)
$(
addprefix
from_cpython/Python/,
$(STDPYTHON_SRCS)
)
...
...
from_cpython/CMakeLists.txt
View file @
077fffc6
...
...
@@ -18,7 +18,7 @@ add_custom_target(copy_stdlib ALL DEPENDS ${STDLIB_TARGETS})
file
(
GLOB_RECURSE STDMODULE_SRCS Modules errnomodule.c shamodule.c sha256module.c sha512module.c _math.c mathmodule.c md5.c md5module.c _randommodule.c _sre.c operator.c binascii.c pwdmodule.c posixmodule.c _struct.c datetimemodule.c _functoolsmodule.c _collectionsmodule.c itertoolsmodule.c resource.c signalmodule.c selectmodule.c fcntlmodule.c timemodule.c arraymodule.c zlibmodule.c _codecsmodule.c socketmodule.c
)
# compile specified files in from_cpython/Objects
file
(
GLOB_RECURSE STDOBJECT_SRCS Objects structseq.c capsule.c stringobject.c
)
file
(
GLOB_RECURSE STDOBJECT_SRCS Objects structseq.c capsule.c stringobject.c
exceptions.c
)
# compile specified files in from_cpython/Python
file
(
GLOB_RECURSE STDPYTHON_SRCS Python getargs.c pyctype.c formatter_string.c pystrtod.c dtoa.c
)
...
...
from_cpython/Include/osdefs.h
0 → 100644
View file @
077fffc6
// This file is originally from CPython 2.7, with modifications for Pyston
#ifndef Py_OSDEFS_H
#define Py_OSDEFS_H
#ifdef __cplusplus
extern
"C"
{
#endif
/* Operating system dependencies */
/* Mod by chrish: QNX has WATCOM, but isn't DOS */
#if !defined(__QNX__)
#if defined(MS_WINDOWS) || defined(__BORLANDC__) || defined(__WATCOMC__) || defined(__DJGPP__) || defined(PYOS_OS2)
#if defined(PYOS_OS2) && defined(PYCC_GCC)
#define MAXPATHLEN 260
#define SEP '/'
#define ALTSEP '\\'
#else
#define SEP '\\'
#define ALTSEP '/'
#define MAXPATHLEN 256
#endif
#define DELIM ';'
#endif
#endif
#ifdef RISCOS
#define SEP '.'
#define MAXPATHLEN 256
#define DELIM ','
#endif
/* Filename separator */
#ifndef SEP
#define SEP '/'
#endif
/* Max pathname length */
#ifdef __hpux
#include <sys/param.h>
#include <limits.h>
#ifndef PATH_MAX
#define PATH_MAX MAXPATHLEN
#endif
#endif
#ifndef MAXPATHLEN
#if defined(PATH_MAX) && PATH_MAX > 1024
#define MAXPATHLEN PATH_MAX
#else
#define MAXPATHLEN 1024
#endif
#endif
/* Search path entry delimiter */
#ifndef DELIM
#define DELIM ':'
#endif
#ifdef __cplusplus
}
#endif
#endif
/* !Py_OSDEFS_H */
from_cpython/Include/pyerrors.h
View file @
077fffc6
...
...
@@ -8,8 +8,6 @@ extern "C" {
/* Error objects */
// Pyston change: these are not our object formats
#if 0
typedef
struct
{
PyObject_HEAD
PyObject
*
dict
;
...
...
@@ -74,8 +72,6 @@ typedef struct {
PyObject
*
winerror
;
}
PyWindowsErrorObject
;
#endif
#endif
// (Pyston TODO: add opaque definitions of those names)
/* Error handling definitions */
...
...
@@ -132,119 +128,68 @@ PyAPI_FUNC(PyObject*) PyExceptionInstance_Class(PyObject*) PYSTON_NOEXCEPT;
// as PyTypeObject's.
// TODO not sure if this is worth it -- a fair amount of confusion (duplicating these names) for fairly
// little gain (getting to treat them as PyTypeObject's and using our own names)
#define PyExc_BaseException ((PyObject*)BaseException)
PyAPI_DATA
(
PyTypeObject
*
)
BaseException
;
#define PyExc_Exception ((PyObject*)Exception)
PyAPI_DATA
(
PyTypeObject
*
)
Exception
;
#define PyExc_StopIteration ((PyObject*)StopIteration)
PyAPI_DATA
(
PyTypeObject
*
)
StopIteration
;
#define PyExc_GeneratorExit ((PyObject*)GeneratorExit)
PyAPI_DATA
(
PyTypeObject
*
)
GeneratorExit
;
#define PyExc_StandardError ((PyObject*)StandardError)
PyAPI_DATA
(
PyTypeObject
*
)
StandardError
;
#define PyExc_ArithmeticError ((PyObject*)ArithmeticError)
PyAPI_DATA
(
PyTypeObject
*
)
ArithmeticError
;
#define PyExc_LookupError ((PyObject*)LookupError)
PyAPI_DATA
(
PyTypeObject
*
)
LookupError
;
#define PyExc_AssertionError ((PyObject*)AssertionError)
PyAPI_DATA
(
PyTypeObject
*
)
AssertionError
;
#define PyExc_AttributeError ((PyObject*)AttributeError)
PyAPI_DATA
(
PyTypeObject
*
)
AttributeError
;
#define PyExc_EOFError ((PyObject*)EOFError)
PyAPI_DATA
(
PyTypeObject
*
)
EOFError
;
#define PyExc_FloatingPointError ((PyObject*)FloatingPointError)
PyAPI_DATA
(
PyTypeObject
*
)
FloatingPointError
;
#define PyExc_EnvironmentError ((PyObject*)EnvironmentError)
PyAPI_DATA
(
PyTypeObject
*
)
EnvironmentError
;
#define PyExc_IOError ((PyObject*)IOError)
PyAPI_DATA
(
PyTypeObject
*
)
IOError
;
#define PyExc_OSError ((PyObject*)OSError)
PyAPI_DATA
(
PyTypeObject
*
)
OSError
;
#define PyExc_ImportError ((PyObject*)ImportError)
PyAPI_DATA
(
PyTypeObject
*
)
ImportError
;
#define PyExc_IndexError ((PyObject*)IndexError)
PyAPI_DATA
(
PyTypeObject
*
)
IndexError
;
#define PyExc_KeyError ((PyObject*)KeyError)
PyAPI_DATA
(
PyTypeObject
*
)
KeyError
;
#define PyExc_KeyboardInterrupt ((PyObject*)KeyboardInterrupt)
PyAPI_DATA
(
PyTypeObject
*
)
KeyboardInterrupt
;
#define PyExc_MemoryError ((PyObject*)MemoryError)
PyAPI_DATA
(
PyTypeObject
*
)
MemoryError
;
#define PyExc_NameError ((PyObject*)NameError)
PyAPI_DATA
(
PyTypeObject
*
)
NameError
;
#define PyExc_OverflowError ((PyObject*)OverflowError)
PyAPI_DATA
(
PyTypeObject
*
)
OverflowError
;
#define PyExc_RuntimeError ((PyObject*)RuntimeError)
PyAPI_DATA
(
PyTypeObject
*
)
RuntimeError
;
#define PyExc_NotImplementedError ((PyObject*)NotImplementedError)
PyAPI_DATA
(
PyTypeObject
*
)
NotImplementedError
;
#define PyExc_SyntaxError ((PyObject*)SyntaxError)
PyAPI_DATA
(
PyTypeObject
*
)
SyntaxError
;
#define PyExc_IndentationError ((PyObject*)IndentationError)
PyAPI_DATA
(
PyTypeObject
*
)
IndentationError
;
#define PyExc_TabError ((PyObject*)TabError)
PyAPI_DATA
(
PyTypeObject
*
)
TabError
;
#define PyExc_ReferenceError ((PyObject*)ReferenceError)
PyAPI_DATA
(
PyTypeObject
*
)
ReferenceError
;
#define PyExc_SystemError ((PyObject*)SystemError)
PyAPI_DATA
(
PyTypeObject
*
)
SystemError
;
#define PyExc_SystemExit ((PyObject*)SystemExit)
PyAPI_DATA
(
PyTypeObject
*
)
SystemExit
;
#define PyExc_TypeError ((PyObject*)TypeError)
PyAPI_DATA
(
PyTypeObject
*
)
TypeError
;
#define PyExc_UnboundLocalError ((PyObject*)UnboundLocalError)
PyAPI_DATA
(
PyTypeObject
*
)
UnboundLocalError
;
#define PyExc_UnicodeError ((PyObject*)UnicodeError)
PyAPI_DATA
(
PyTypeObject
*
)
UnicodeError
;
#define PyExc_UnicodeEncodeError ((PyObject*)UnicodeEncodeError)
PyAPI_DATA
(
PyTypeObject
*
)
UnicodeEncodeError
;
#define PyExc_UnicodeDecodeError ((PyObject*)UnicodeDecodeError)
PyAPI_DATA
(
PyTypeObject
*
)
UnicodeDecodeError
;
#define PyExc_UnicodeTranslateError ((PyObject*)UnicodeTranslateError)
PyAPI_DATA
(
PyTypeObject
*
)
UnicodeTranslateError
;
#define PyExc_ValueError ((PyObject*)ValueError)
PyAPI_DATA
(
PyTypeObject
*
)
ValueError
;
#define PyExc_ZeroDivisionError ((PyObject*)ZeroDivisionError)
PyAPI_DATA
(
PyTypeObject
*
)
ZeroDivisionError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_BaseException
;
PyAPI_DATA
(
PyObject
*
)
PyExc_Exception
;
PyAPI_DATA
(
PyObject
*
)
PyExc_StopIteration
;
PyAPI_DATA
(
PyObject
*
)
PyExc_GeneratorExit
;
PyAPI_DATA
(
PyObject
*
)
PyExc_StandardError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_ArithmeticError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_LookupError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_AssertionError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_AttributeError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_EOFError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_FloatingPointError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_EnvironmentError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_IOError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_OSError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_ImportError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_IndexError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_KeyError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_KeyboardInterrupt
;
PyAPI_DATA
(
PyObject
*
)
PyExc_MemoryError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_NameError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_OverflowError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_RuntimeError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_NotImplementedError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_SyntaxError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_IndentationError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_TabError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_ReferenceError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_SystemError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_SystemExit
;
PyAPI_DATA
(
PyObject
*
)
PyExc_TypeError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_UnboundLocalError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_UnicodeError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_UnicodeEncodeError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_UnicodeDecodeError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_UnicodeTranslateError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_ValueError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_ZeroDivisionError
;
#ifdef MS_WINDOWS
#define PyExc_WindowsError ((PyObject*)WindowsError)
PyAPI_DATA
(
PyTypeObject
*
)
WindowsError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_WindowsError
;
#endif
#ifdef __VMS
#define PyExc_VMSError ((PyObject*)VMSError)
PyAPI_DATA
(
PyTypeObject
*
)
VMSError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_VMSError
;
#endif
#define PyExc_BufferError ((PyObject*)BufferError)
PyAPI_DATA
(
PyTypeObject
*
)
BufferError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_BufferError
;
PyAPI_DATA
(
PyObject
*
)
PyExc_MemoryErrorInst
;
PyAPI_DATA
(
PyObject
*
)
PyExc_RecursionErrorInst
;
/* Predefined warning categories */
#define PyExc_Warning ((PyObject*)Warning)
PyAPI_DATA
(
PyTypeObject
*
)
Warning
;
#define PyExc_UserWarning ((PyObject*)UserWarning)
PyAPI_DATA
(
PyTypeObject
*
)
UserWarning
;
#define PyExc_DeprecationWarning ((PyObject*)DeprecationWarning)
PyAPI_DATA
(
PyTypeObject
*
)
DeprecationWarning
;
#define PyExc_PendingDeprecationWarning ((PyObject*)PendingDeprecationWarning)
PyAPI_DATA
(
PyTypeObject
*
)
PendingDeprecationWarning
;
#define PyExc_SyntaxWarning ((PyObject*)SyntaxWarning)
PyAPI_DATA
(
PyTypeObject
*
)
SyntaxWarning
;
#define PyExc_RuntimeWarning ((PyObject*)RuntimeWarning)
PyAPI_DATA
(
PyTypeObject
*
)
RuntimeWarning
;
#define PyExc_FutureWarning ((PyObject*)FutureWarning)
PyAPI_DATA
(
PyTypeObject
*
)
FutureWarning
;
#define PyExc_ImportWarning ((PyObject*)ImportWarning)
PyAPI_DATA
(
PyTypeObject
*
)
ImportWarning
;
#define PyExc_UnicodeWarning ((PyObject*)UnicodeWarning)
PyAPI_DATA
(
PyTypeObject
*
)
UnicodeWarning
;
#define PyExc_BytesWarning ((PyObject*)BytesWarning)
PyAPI_DATA
(
PyTypeObject
*
)
BytesWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_Warning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_UserWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_DeprecationWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_PendingDeprecationWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_SyntaxWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_RuntimeWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_FutureWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_ImportWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_UnicodeWarning
;
PyAPI_DATA
(
PyObject
*
)
PyExc_BytesWarning
;
/* Convenience functions */
...
...
from_cpython/Objects/exceptions.c
0 → 100644
View file @
077fffc6
// This file is originally from CPython 2.7, with modifications for Pyston
/*
* New exceptions.c written in Iceland by Richard Jones and Georg Brandl.
*
* Thanks go to Tim Peters and Michael Hudson for debugging.
*/
#define PY_SSIZE_T_CLEAN
#include <Python.h>
#include "structmember.h"
#include "osdefs.h"
#define EXC_MODULE_NAME "exceptions."
/* NOTE: If the exception class hierarchy changes, don't forget to update
* Lib/test/exception_hierarchy.txt
*/
PyDoc_STRVAR
(
exceptions_doc
,
"Python's standard exception class hierarchy.
\n
\
\n
\
Exceptions found here are defined both in the exceptions module and the
\n
\
built-in namespace. It is recommended that user-defined exceptions
\n
\
inherit from Exception. See the documentation for the exception
\n
\
inheritance hierarchy.
\n
\
"
);
/*
* BaseException
*/
static
PyObject
*
BaseException_new
(
PyTypeObject
*
type
,
PyObject
*
args
,
PyObject
*
kwds
)
{
PyBaseExceptionObject
*
self
;
self
=
(
PyBaseExceptionObject
*
)
type
->
tp_alloc
(
type
,
0
);
if
(
!
self
)
return
NULL
;
/* the dict is created on the fly in PyObject_GenericSetAttr */
self
->
message
=
self
->
dict
=
NULL
;
self
->
args
=
PyTuple_New
(
0
);
if
(
!
self
->
args
)
{
Py_DECREF
(
self
);
return
NULL
;
}
self
->
message
=
PyString_FromString
(
""
);
if
(
!
self
->
message
)
{
Py_DECREF
(
self
);
return
NULL
;
}
return
(
PyObject
*
)
self
;
}
static
int
BaseException_init
(
PyBaseExceptionObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
)
{
if
(
!
_PyArg_NoKeywords
(
Py_TYPE
(
self
)
->
tp_name
,
kwds
))
return
-
1
;
Py_DECREF
(
self
->
args
);
self
->
args
=
args
;
Py_INCREF
(
self
->
args
);
if
(
PyTuple_GET_SIZE
(
self
->
args
)
==
1
)
{
Py_CLEAR
(
self
->
message
);
self
->
message
=
PyTuple_GET_ITEM
(
self
->
args
,
0
);
Py_INCREF
(
self
->
message
);
}
return
0
;
}
static
int
BaseException_clear
(
PyBaseExceptionObject
*
self
)
{
Py_CLEAR
(
self
->
dict
);
Py_CLEAR
(
self
->
args
);
Py_CLEAR
(
self
->
message
);
return
0
;
}
static
void
BaseException_dealloc
(
PyBaseExceptionObject
*
self
)
{
_PyObject_GC_UNTRACK
(
self
);
BaseException_clear
(
self
);
Py_TYPE
(
self
)
->
tp_free
((
PyObject
*
)
self
);
}
static
int
BaseException_traverse
(
PyBaseExceptionObject
*
self
,
visitproc
visit
,
void
*
arg
)
{
Py_VISIT
(
self
->
dict
);
Py_VISIT
(
self
->
args
);
Py_VISIT
(
self
->
message
);
return
0
;
}
static
PyObject
*
BaseException_str
(
PyBaseExceptionObject
*
self
)
{
PyObject
*
out
;
switch
(
PyTuple_GET_SIZE
(
self
->
args
))
{
case
0
:
out
=
PyString_FromString
(
""
);
break
;
case
1
:
out
=
PyObject_Str
(
PyTuple_GET_ITEM
(
self
->
args
,
0
));
break
;
default:
out
=
PyObject_Str
(
self
->
args
);
break
;
}
return
out
;
}
#ifdef Py_USING_UNICODE
static
PyObject
*
BaseException_unicode
(
PyBaseExceptionObject
*
self
)
{
PyObject
*
out
;
/* issue6108: if __str__ has been overridden in the subclass, unicode()
should return the message returned by __str__ as used to happen
before this method was implemented. */
if
(
Py_TYPE
(
self
)
->
tp_str
!=
(
reprfunc
)
BaseException_str
)
{
PyObject
*
str
;
/* Unlike PyObject_Str, tp_str can return unicode (i.e. return the
equivalent of unicode(e.__str__()) instead of unicode(str(e))). */
str
=
Py_TYPE
(
self
)
->
tp_str
((
PyObject
*
)
self
);
if
(
str
==
NULL
)
return
NULL
;
out
=
PyObject_Unicode
(
str
);
Py_DECREF
(
str
);
return
out
;
}
switch
(
PyTuple_GET_SIZE
(
self
->
args
))
{
case
0
:
out
=
PyUnicode_FromString
(
""
);
break
;
case
1
:
out
=
PyObject_Unicode
(
PyTuple_GET_ITEM
(
self
->
args
,
0
));
break
;
default:
out
=
PyObject_Unicode
(
self
->
args
);
break
;
}
return
out
;
}
#endif
static
PyObject
*
BaseException_repr
(
PyBaseExceptionObject
*
self
)
{
PyObject
*
repr_suffix
;
PyObject
*
repr
;
char
*
name
;
char
*
dot
;
repr_suffix
=
PyObject_Repr
(
self
->
args
);
if
(
!
repr_suffix
)
return
NULL
;
name
=
(
char
*
)
Py_TYPE
(
self
)
->
tp_name
;
dot
=
strrchr
(
name
,
'.'
);
if
(
dot
!=
NULL
)
name
=
dot
+
1
;
repr
=
PyString_FromString
(
name
);
if
(
!
repr
)
{
Py_DECREF
(
repr_suffix
);
return
NULL
;
}
PyString_ConcatAndDel
(
&
repr
,
repr_suffix
);
return
repr
;
}
/* Pickling support */
static
PyObject
*
BaseException_reduce
(
PyBaseExceptionObject
*
self
)
{
if
(
self
->
args
&&
self
->
dict
)
return
PyTuple_Pack
(
3
,
Py_TYPE
(
self
),
self
->
args
,
self
->
dict
);
else
return
PyTuple_Pack
(
2
,
Py_TYPE
(
self
),
self
->
args
);
}
/*
* Needed for backward compatibility, since exceptions used to store
* all their attributes in the __dict__. Code is taken from cPickle's
* load_build function.
*/
static
PyObject
*
BaseException_setstate
(
PyObject
*
self
,
PyObject
*
state
)
{
PyObject
*
d_key
,
*
d_value
;
Py_ssize_t
i
=
0
;
if
(
state
!=
Py_None
)
{
if
(
!
PyDict_Check
(
state
))
{
PyErr_SetString
(
PyExc_TypeError
,
"state is not a dictionary"
);
return
NULL
;
}
while
(
PyDict_Next
(
state
,
&
i
,
&
d_key
,
&
d_value
))
{
if
(
PyObject_SetAttr
(
self
,
d_key
,
d_value
)
<
0
)
return
NULL
;
}
}
Py_RETURN_NONE
;
}
static
PyMethodDef
BaseException_methods
[]
=
{
{
"__reduce__"
,
(
PyCFunction
)
BaseException_reduce
,
METH_NOARGS
},
{
"__setstate__"
,
(
PyCFunction
)
BaseException_setstate
,
METH_O
},
#ifdef Py_USING_UNICODE
{
"__unicode__"
,
(
PyCFunction
)
BaseException_unicode
,
METH_NOARGS
},
#endif
{
NULL
,
NULL
,
0
,
NULL
},
};
static
PyObject
*
BaseException_getitem
(
PyBaseExceptionObject
*
self
,
Py_ssize_t
index
)
{
if
(
PyErr_WarnPy3k
(
"__getitem__ not supported for exception "
"classes in 3.x; use args attribute"
,
1
)
<
0
)
return
NULL
;
return
PySequence_GetItem
(
self
->
args
,
index
);
}
static
PyObject
*
BaseException_getslice
(
PyBaseExceptionObject
*
self
,
Py_ssize_t
start
,
Py_ssize_t
stop
)
{
if
(
PyErr_WarnPy3k
(
"__getslice__ not supported for exception "
"classes in 3.x; use args attribute"
,
1
)
<
0
)
return
NULL
;
return
PySequence_GetSlice
(
self
->
args
,
start
,
stop
);
}
static
PySequenceMethods
BaseException_as_sequence
=
{
0
,
/* sq_length; */
0
,
/* sq_concat; */
0
,
/* sq_repeat; */
(
ssizeargfunc
)
BaseException_getitem
,
/* sq_item; */
(
ssizessizeargfunc
)
BaseException_getslice
,
/* sq_slice; */
0
,
/* sq_ass_item; */
0
,
/* sq_ass_slice; */
0
,
/* sq_contains; */
0
,
/* sq_inplace_concat; */
0
/* sq_inplace_repeat; */
};
static
PyObject
*
BaseException_get_dict
(
PyBaseExceptionObject
*
self
)
{
if
(
self
->
dict
==
NULL
)
{
self
->
dict
=
PyDict_New
();
if
(
!
self
->
dict
)
return
NULL
;
}
Py_INCREF
(
self
->
dict
);
return
self
->
dict
;
}
static
int
BaseException_set_dict
(
PyBaseExceptionObject
*
self
,
PyObject
*
val
)
{
if
(
val
==
NULL
)
{
PyErr_SetString
(
PyExc_TypeError
,
"__dict__ may not be deleted"
);
return
-
1
;
}
if
(
!
PyDict_Check
(
val
))
{
PyErr_SetString
(
PyExc_TypeError
,
"__dict__ must be a dictionary"
);
return
-
1
;
}
Py_CLEAR
(
self
->
dict
);
Py_INCREF
(
val
);
self
->
dict
=
val
;
return
0
;
}
static
PyObject
*
BaseException_get_args
(
PyBaseExceptionObject
*
self
)
{
if
(
self
->
args
==
NULL
)
{
Py_INCREF
(
Py_None
);
return
Py_None
;
}
Py_INCREF
(
self
->
args
);
return
self
->
args
;
}
static
int
BaseException_set_args
(
PyBaseExceptionObject
*
self
,
PyObject
*
val
)
{
PyObject
*
seq
;
if
(
val
==
NULL
)
{
PyErr_SetString
(
PyExc_TypeError
,
"args may not be deleted"
);
return
-
1
;
}
seq
=
PySequence_Tuple
(
val
);
if
(
!
seq
)
return
-
1
;
Py_CLEAR
(
self
->
args
);
self
->
args
=
seq
;
return
0
;
}
static
PyObject
*
BaseException_get_message
(
PyBaseExceptionObject
*
self
)
{
PyObject
*
msg
;
/* if "message" is in self->dict, accessing a user-set message attribute */
if
(
self
->
dict
&&
(
msg
=
PyDict_GetItemString
(
self
->
dict
,
"message"
)))
{
Py_INCREF
(
msg
);
return
msg
;
}
if
(
self
->
message
==
NULL
)
{
PyErr_SetString
(
PyExc_AttributeError
,
"message attribute was deleted"
);
return
NULL
;
}
/* accessing the deprecated "builtin" message attribute of Exception */
if
(
PyErr_WarnEx
(
PyExc_DeprecationWarning
,
"BaseException.message has been deprecated as "
"of Python 2.6"
,
1
)
<
0
)
return
NULL
;
Py_INCREF
(
self
->
message
);
return
self
->
message
;
}
static
int
BaseException_set_message
(
PyBaseExceptionObject
*
self
,
PyObject
*
val
)
{
/* if val is NULL, delete the message attribute */
if
(
val
==
NULL
)
{
if
(
self
->
dict
&&
PyDict_GetItemString
(
self
->
dict
,
"message"
))
{
if
(
PyDict_DelItemString
(
self
->
dict
,
"message"
)
<
0
)
return
-
1
;
}
Py_CLEAR
(
self
->
message
);
return
0
;
}
/* else set it in __dict__, but may need to create the dict first */
if
(
self
->
dict
==
NULL
)
{
self
->
dict
=
PyDict_New
();
if
(
!
self
->
dict
)
return
-
1
;
}
return
PyDict_SetItemString
(
self
->
dict
,
"message"
,
val
);
}
static
PyGetSetDef
BaseException_getset
[]
=
{
{
"__dict__"
,
(
getter
)
BaseException_get_dict
,
(
setter
)
BaseException_set_dict
},
{
"args"
,
(
getter
)
BaseException_get_args
,
(
setter
)
BaseException_set_args
},
{
"message"
,
(
getter
)
BaseException_get_message
,
(
setter
)
BaseException_set_message
},
{
NULL
},
};
// Leave this in as a reminder in case we want to go back to using it:
#define Py_TPFLAGS_BASE_EXC_SUBCLASS (0)
static
PyTypeObject
_PyExc_BaseException
=
{
PyObject_HEAD_INIT
(
NULL
)
0
,
/*ob_size*/
EXC_MODULE_NAME
"BaseException"
,
/*tp_name*/
sizeof
(
PyBaseExceptionObject
),
/*tp_basicsize*/
0
,
/*tp_itemsize*/
(
destructor
)
BaseException_dealloc
,
/*tp_dealloc*/
0
,
/*tp_print*/
0
,
/*tp_getattr*/
0
,
/*tp_setattr*/
0
,
/* tp_compare; */
(
reprfunc
)
BaseException_repr
,
/*tp_repr*/
0
,
/*tp_as_number*/
&
BaseException_as_sequence
,
/*tp_as_sequence*/
0
,
/*tp_as_mapping*/
0
,
/*tp_hash */
0
,
/*tp_call*/
(
reprfunc
)
BaseException_str
,
/*tp_str*/
PyObject_GenericGetAttr
,
/*tp_getattro*/
PyObject_GenericSetAttr
,
/*tp_setattro*/
0
,
/*tp_as_buffer*/
Py_TPFLAGS_DEFAULT
|
Py_TPFLAGS_BASETYPE
|
Py_TPFLAGS_HAVE_GC
|
Py_TPFLAGS_BASE_EXC_SUBCLASS
,
/*tp_flags*/
PyDoc_STR
(
"Common base class for all exceptions"
),
/* tp_doc */
(
traverseproc
)
BaseException_traverse
,
/* tp_traverse */
(
inquiry
)
BaseException_clear
,
/* tp_clear */
0
,
/* tp_richcompare */
0
,
/* tp_weaklistoffset */
0
,
/* tp_iter */
0
,
/* tp_iternext */
BaseException_methods
,
/* tp_methods */
0
,
/* tp_members */
BaseException_getset
,
/* tp_getset */
0
,
/* tp_base */
0
,
/* tp_dict */
0
,
/* tp_descr_get */
0
,
/* tp_descr_set */
offsetof
(
PyBaseExceptionObject
,
dict
),
/* tp_dictoffset */
(
initproc
)
BaseException_init
,
/* tp_init */
0
,
/* tp_alloc */
BaseException_new
,
/* tp_new */
};
/* the CPython API expects exceptions to be (PyObject *) - both a hold-over
from the previous implmentation and also allowing Python objects to be used
in the API */
PyObject
*
PyExc_BaseException
=
(
PyObject
*
)
&
_PyExc_BaseException
;
/* note these macros omit the last semicolon so the macro invocation may
* include it and not look strange.
*/
#define SimpleExtendsException(EXCBASE, EXCNAME, EXCDOC) \
static PyTypeObject _PyExc_ ## EXCNAME = { \
PyObject_HEAD_INIT(NULL) \
0, \
EXC_MODULE_NAME # EXCNAME, \
sizeof(PyBaseExceptionObject), \
0, (destructor)BaseException_dealloc, 0, 0, 0, 0, 0, 0, 0, \
0, 0, 0, 0, 0, 0, 0, \
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HAVE_GC, \
PyDoc_STR(EXCDOC), (traverseproc)BaseException_traverse, \
(inquiry)BaseException_clear, 0, 0, 0, 0, 0, 0, 0, &_ ## EXCBASE, \
0, 0, 0, offsetof(PyBaseExceptionObject, dict), \
(initproc)BaseException_init, 0, BaseException_new,\
}; \
PyObject *PyExc_ ## EXCNAME = (PyObject *)&_PyExc_ ## EXCNAME
#define MiddlingExtendsException(EXCBASE, EXCNAME, EXCSTORE, EXCDOC) \
static PyTypeObject _PyExc_ ## EXCNAME = { \
PyObject_HEAD_INIT(NULL) \
0, \
EXC_MODULE_NAME # EXCNAME, \
sizeof(Py ## EXCSTORE ## Object), \
0, (destructor)EXCSTORE ## _dealloc, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
0, 0, 0, 0, 0, \
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HAVE_GC, \
PyDoc_STR(EXCDOC), (traverseproc)EXCSTORE ## _traverse, \
(inquiry)EXCSTORE ## _clear, 0, 0, 0, 0, 0, 0, 0, &_ ## EXCBASE, \
0, 0, 0, offsetof(Py ## EXCSTORE ## Object, dict), \
(initproc)EXCSTORE ## _init, 0, BaseException_new,\
}; \
PyObject *PyExc_ ## EXCNAME = (PyObject *)&_PyExc_ ## EXCNAME
#define ComplexExtendsException(EXCBASE, EXCNAME, EXCSTORE, EXCDEALLOC, EXCMETHODS, EXCMEMBERS, EXCSTR, EXCDOC) \
static PyTypeObject _PyExc_ ## EXCNAME = { \
PyObject_HEAD_INIT(NULL) \
0, \
EXC_MODULE_NAME # EXCNAME, \
sizeof(Py ## EXCSTORE ## Object), 0, \
(destructor)EXCSTORE ## _dealloc, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \
(reprfunc)EXCSTR, 0, 0, 0, \
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HAVE_GC, \
PyDoc_STR(EXCDOC), (traverseproc)EXCSTORE ## _traverse, \
(inquiry)EXCSTORE ## _clear, 0, 0, 0, 0, EXCMETHODS, \
EXCMEMBERS, 0, &_ ## EXCBASE, \
0, 0, 0, offsetof(Py ## EXCSTORE ## Object, dict), \
(initproc)EXCSTORE ## _init, 0, BaseException_new,\
}; \
PyObject *PyExc_ ## EXCNAME = (PyObject *)&_PyExc_ ## EXCNAME
/*
* Exception extends BaseException
*/
SimpleExtendsException
(
PyExc_BaseException
,
Exception
,
"Common base class for all non-exit exceptions."
);
/*
* StandardError extends Exception
*/
SimpleExtendsException
(
PyExc_Exception
,
StandardError
,
"Base class for all standard Python exceptions that do not represent
\n
"
"interpreter exiting."
);
/*
* TypeError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
TypeError
,
"Inappropriate argument type."
);
/*
* StopIteration extends Exception
*/
SimpleExtendsException
(
PyExc_Exception
,
StopIteration
,
"Signal the end from iterator.next()."
);
/*
* GeneratorExit extends BaseException
*/
SimpleExtendsException
(
PyExc_BaseException
,
GeneratorExit
,
"Request that a generator exit."
);
/*
* SystemExit extends BaseException
*/
static
int
SystemExit_init
(
PySystemExitObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
)
{
Py_ssize_t
size
=
PyTuple_GET_SIZE
(
args
);
if
(
BaseException_init
((
PyBaseExceptionObject
*
)
self
,
args
,
kwds
)
==
-
1
)
return
-
1
;
if
(
size
==
0
)
return
0
;
Py_CLEAR
(
self
->
code
);
if
(
size
==
1
)
self
->
code
=
PyTuple_GET_ITEM
(
args
,
0
);
else
if
(
size
>
1
)
self
->
code
=
args
;
Py_INCREF
(
self
->
code
);
return
0
;
}
static
int
SystemExit_clear
(
PySystemExitObject
*
self
)
{
Py_CLEAR
(
self
->
code
);
return
BaseException_clear
((
PyBaseExceptionObject
*
)
self
);
}
static
void
SystemExit_dealloc
(
PySystemExitObject
*
self
)
{
_PyObject_GC_UNTRACK
(
self
);
SystemExit_clear
(
self
);
Py_TYPE
(
self
)
->
tp_free
((
PyObject
*
)
self
);
}
static
int
SystemExit_traverse
(
PySystemExitObject
*
self
,
visitproc
visit
,
void
*
arg
)
{
Py_VISIT
(
self
->
code
);
return
BaseException_traverse
((
PyBaseExceptionObject
*
)
self
,
visit
,
arg
);
}
static
PyMemberDef
SystemExit_members
[]
=
{
{
"code"
,
T_OBJECT
,
offsetof
(
PySystemExitObject
,
code
),
0
,
PyDoc_STR
(
"exception code"
)},
{
NULL
}
/* Sentinel */
};
ComplexExtendsException
(
PyExc_BaseException
,
SystemExit
,
SystemExit
,
SystemExit_dealloc
,
0
,
SystemExit_members
,
0
,
"Request to exit from the interpreter."
);
/*
* KeyboardInterrupt extends BaseException
*/
SimpleExtendsException
(
PyExc_BaseException
,
KeyboardInterrupt
,
"Program interrupted by user."
);
/*
* ImportError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
ImportError
,
"Import can't find module, or can't find name in module."
);
/*
* EnvironmentError extends StandardError
*/
/* Where a function has a single filename, such as open() or some
* of the os module functions, PyErr_SetFromErrnoWithFilename() is
* called, giving a third argument which is the filename. But, so
* that old code using in-place unpacking doesn't break, e.g.:
*
* except IOError, (errno, strerror):
*
* we hack args so that it only contains two items. This also
* means we need our own __str__() which prints out the filename
* when it was supplied.
*/
static
int
EnvironmentError_init
(
PyEnvironmentErrorObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
)
{
PyObject
*
myerrno
=
NULL
,
*
strerror
=
NULL
,
*
filename
=
NULL
;
PyObject
*
subslice
=
NULL
;
if
(
BaseException_init
((
PyBaseExceptionObject
*
)
self
,
args
,
kwds
)
==
-
1
)
return
-
1
;
if
(
PyTuple_GET_SIZE
(
args
)
<=
1
||
PyTuple_GET_SIZE
(
args
)
>
3
)
{
return
0
;
}
if
(
!
PyArg_UnpackTuple
(
args
,
"EnvironmentError"
,
2
,
3
,
&
myerrno
,
&
strerror
,
&
filename
))
{
return
-
1
;
}
Py_CLEAR
(
self
->
myerrno
);
/* replacing */
self
->
myerrno
=
myerrno
;
Py_INCREF
(
self
->
myerrno
);
Py_CLEAR
(
self
->
strerror
);
/* replacing */
self
->
strerror
=
strerror
;
Py_INCREF
(
self
->
strerror
);
/* self->filename will remain Py_None otherwise */
if
(
filename
!=
NULL
)
{
Py_CLEAR
(
self
->
filename
);
/* replacing */
self
->
filename
=
filename
;
Py_INCREF
(
self
->
filename
);
subslice
=
PyTuple_GetSlice
(
args
,
0
,
2
);
if
(
!
subslice
)
return
-
1
;
Py_DECREF
(
self
->
args
);
/* replacing args */
self
->
args
=
subslice
;
}
return
0
;
}
static
int
EnvironmentError_clear
(
PyEnvironmentErrorObject
*
self
)
{
Py_CLEAR
(
self
->
myerrno
);
Py_CLEAR
(
self
->
strerror
);
Py_CLEAR
(
self
->
filename
);
return
BaseException_clear
((
PyBaseExceptionObject
*
)
self
);
}
static
void
EnvironmentError_dealloc
(
PyEnvironmentErrorObject
*
self
)
{
_PyObject_GC_UNTRACK
(
self
);
EnvironmentError_clear
(
self
);
Py_TYPE
(
self
)
->
tp_free
((
PyObject
*
)
self
);
}
static
int
EnvironmentError_traverse
(
PyEnvironmentErrorObject
*
self
,
visitproc
visit
,
void
*
arg
)
{
Py_VISIT
(
self
->
myerrno
);
Py_VISIT
(
self
->
strerror
);
Py_VISIT
(
self
->
filename
);
return
BaseException_traverse
((
PyBaseExceptionObject
*
)
self
,
visit
,
arg
);
}
static
PyObject
*
EnvironmentError_str
(
PyEnvironmentErrorObject
*
self
)
{
PyObject
*
rtnval
=
NULL
;
if
(
self
->
filename
)
{
PyObject
*
fmt
;
PyObject
*
repr
;
PyObject
*
tuple
;
fmt
=
PyString_FromString
(
"[Errno %s] %s: %s"
);
if
(
!
fmt
)
return
NULL
;
repr
=
PyObject_Repr
(
self
->
filename
);
if
(
!
repr
)
{
Py_DECREF
(
fmt
);
return
NULL
;
}
tuple
=
PyTuple_New
(
3
);
if
(
!
tuple
)
{
Py_DECREF
(
repr
);
Py_DECREF
(
fmt
);
return
NULL
;
}
if
(
self
->
myerrno
)
{
Py_INCREF
(
self
->
myerrno
);
PyTuple_SET_ITEM
(
tuple
,
0
,
self
->
myerrno
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
0
,
Py_None
);
}
if
(
self
->
strerror
)
{
Py_INCREF
(
self
->
strerror
);
PyTuple_SET_ITEM
(
tuple
,
1
,
self
->
strerror
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
1
,
Py_None
);
}
PyTuple_SET_ITEM
(
tuple
,
2
,
repr
);
rtnval
=
PyString_Format
(
fmt
,
tuple
);
Py_DECREF
(
fmt
);
Py_DECREF
(
tuple
);
}
else
if
(
self
->
myerrno
&&
self
->
strerror
)
{
PyObject
*
fmt
;
PyObject
*
tuple
;
fmt
=
PyString_FromString
(
"[Errno %s] %s"
);
if
(
!
fmt
)
return
NULL
;
tuple
=
PyTuple_New
(
2
);
if
(
!
tuple
)
{
Py_DECREF
(
fmt
);
return
NULL
;
}
if
(
self
->
myerrno
)
{
Py_INCREF
(
self
->
myerrno
);
PyTuple_SET_ITEM
(
tuple
,
0
,
self
->
myerrno
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
0
,
Py_None
);
}
if
(
self
->
strerror
)
{
Py_INCREF
(
self
->
strerror
);
PyTuple_SET_ITEM
(
tuple
,
1
,
self
->
strerror
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
1
,
Py_None
);
}
rtnval
=
PyString_Format
(
fmt
,
tuple
);
Py_DECREF
(
fmt
);
Py_DECREF
(
tuple
);
}
else
rtnval
=
BaseException_str
((
PyBaseExceptionObject
*
)
self
);
return
rtnval
;
}
static
PyMemberDef
EnvironmentError_members
[]
=
{
{
"errno"
,
T_OBJECT
,
offsetof
(
PyEnvironmentErrorObject
,
myerrno
),
0
,
PyDoc_STR
(
"exception errno"
)},
{
"strerror"
,
T_OBJECT
,
offsetof
(
PyEnvironmentErrorObject
,
strerror
),
0
,
PyDoc_STR
(
"exception strerror"
)},
{
"filename"
,
T_OBJECT
,
offsetof
(
PyEnvironmentErrorObject
,
filename
),
0
,
PyDoc_STR
(
"exception filename"
)},
{
NULL
}
/* Sentinel */
};
static
PyObject
*
EnvironmentError_reduce
(
PyEnvironmentErrorObject
*
self
)
{
PyObject
*
args
=
self
->
args
;
PyObject
*
res
=
NULL
,
*
tmp
;
/* self->args is only the first two real arguments if there was a
* file name given to EnvironmentError. */
if
(
PyTuple_GET_SIZE
(
args
)
==
2
&&
self
->
filename
)
{
args
=
PyTuple_New
(
3
);
if
(
!
args
)
return
NULL
;
tmp
=
PyTuple_GET_ITEM
(
self
->
args
,
0
);
Py_INCREF
(
tmp
);
PyTuple_SET_ITEM
(
args
,
0
,
tmp
);
tmp
=
PyTuple_GET_ITEM
(
self
->
args
,
1
);
Py_INCREF
(
tmp
);
PyTuple_SET_ITEM
(
args
,
1
,
tmp
);
Py_INCREF
(
self
->
filename
);
PyTuple_SET_ITEM
(
args
,
2
,
self
->
filename
);
}
else
Py_INCREF
(
args
);
if
(
self
->
dict
)
res
=
PyTuple_Pack
(
3
,
Py_TYPE
(
self
),
args
,
self
->
dict
);
else
res
=
PyTuple_Pack
(
2
,
Py_TYPE
(
self
),
args
);
Py_DECREF
(
args
);
return
res
;
}
static
PyMethodDef
EnvironmentError_methods
[]
=
{
{
"__reduce__"
,
(
PyCFunction
)
EnvironmentError_reduce
,
METH_NOARGS
},
{
NULL
}
};
ComplexExtendsException
(
PyExc_StandardError
,
EnvironmentError
,
EnvironmentError
,
EnvironmentError_dealloc
,
EnvironmentError_methods
,
EnvironmentError_members
,
EnvironmentError_str
,
"Base class for I/O related errors."
);
/*
* IOError extends EnvironmentError
*/
MiddlingExtendsException
(
PyExc_EnvironmentError
,
IOError
,
EnvironmentError
,
"I/O operation failed."
);
/*
* OSError extends EnvironmentError
*/
MiddlingExtendsException
(
PyExc_EnvironmentError
,
OSError
,
EnvironmentError
,
"OS system call failed."
);
/*
* WindowsError extends OSError
*/
#ifdef MS_WINDOWS
#include "errmap.h"
static
int
WindowsError_clear
(
PyWindowsErrorObject
*
self
)
{
Py_CLEAR
(
self
->
myerrno
);
Py_CLEAR
(
self
->
strerror
);
Py_CLEAR
(
self
->
filename
);
Py_CLEAR
(
self
->
winerror
);
return
BaseException_clear
((
PyBaseExceptionObject
*
)
self
);
}
static
void
WindowsError_dealloc
(
PyWindowsErrorObject
*
self
)
{
_PyObject_GC_UNTRACK
(
self
);
WindowsError_clear
(
self
);
Py_TYPE
(
self
)
->
tp_free
((
PyObject
*
)
self
);
}
static
int
WindowsError_traverse
(
PyWindowsErrorObject
*
self
,
visitproc
visit
,
void
*
arg
)
{
Py_VISIT
(
self
->
myerrno
);
Py_VISIT
(
self
->
strerror
);
Py_VISIT
(
self
->
filename
);
Py_VISIT
(
self
->
winerror
);
return
BaseException_traverse
((
PyBaseExceptionObject
*
)
self
,
visit
,
arg
);
}
static
int
WindowsError_init
(
PyWindowsErrorObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
)
{
PyObject
*
o_errcode
=
NULL
;
long
errcode
;
long
posix_errno
;
if
(
EnvironmentError_init
((
PyEnvironmentErrorObject
*
)
self
,
args
,
kwds
)
==
-
1
)
return
-
1
;
if
(
self
->
myerrno
==
NULL
)
return
0
;
/* Set errno to the POSIX errno, and winerror to the Win32
error code. */
errcode
=
PyInt_AsLong
(
self
->
myerrno
);
if
(
errcode
==
-
1
&&
PyErr_Occurred
())
return
-
1
;
posix_errno
=
winerror_to_errno
(
errcode
);
Py_CLEAR
(
self
->
winerror
);
self
->
winerror
=
self
->
myerrno
;
o_errcode
=
PyInt_FromLong
(
posix_errno
);
if
(
!
o_errcode
)
return
-
1
;
self
->
myerrno
=
o_errcode
;
return
0
;
}
static
PyObject
*
WindowsError_str
(
PyWindowsErrorObject
*
self
)
{
PyObject
*
rtnval
=
NULL
;
if
(
self
->
filename
)
{
PyObject
*
fmt
;
PyObject
*
repr
;
PyObject
*
tuple
;
fmt
=
PyString_FromString
(
"[Error %s] %s: %s"
);
if
(
!
fmt
)
return
NULL
;
repr
=
PyObject_Repr
(
self
->
filename
);
if
(
!
repr
)
{
Py_DECREF
(
fmt
);
return
NULL
;
}
tuple
=
PyTuple_New
(
3
);
if
(
!
tuple
)
{
Py_DECREF
(
repr
);
Py_DECREF
(
fmt
);
return
NULL
;
}
if
(
self
->
winerror
)
{
Py_INCREF
(
self
->
winerror
);
PyTuple_SET_ITEM
(
tuple
,
0
,
self
->
winerror
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
0
,
Py_None
);
}
if
(
self
->
strerror
)
{
Py_INCREF
(
self
->
strerror
);
PyTuple_SET_ITEM
(
tuple
,
1
,
self
->
strerror
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
1
,
Py_None
);
}
PyTuple_SET_ITEM
(
tuple
,
2
,
repr
);
rtnval
=
PyString_Format
(
fmt
,
tuple
);
Py_DECREF
(
fmt
);
Py_DECREF
(
tuple
);
}
else
if
(
self
->
winerror
&&
self
->
strerror
)
{
PyObject
*
fmt
;
PyObject
*
tuple
;
fmt
=
PyString_FromString
(
"[Error %s] %s"
);
if
(
!
fmt
)
return
NULL
;
tuple
=
PyTuple_New
(
2
);
if
(
!
tuple
)
{
Py_DECREF
(
fmt
);
return
NULL
;
}
if
(
self
->
winerror
)
{
Py_INCREF
(
self
->
winerror
);
PyTuple_SET_ITEM
(
tuple
,
0
,
self
->
winerror
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
0
,
Py_None
);
}
if
(
self
->
strerror
)
{
Py_INCREF
(
self
->
strerror
);
PyTuple_SET_ITEM
(
tuple
,
1
,
self
->
strerror
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
1
,
Py_None
);
}
rtnval
=
PyString_Format
(
fmt
,
tuple
);
Py_DECREF
(
fmt
);
Py_DECREF
(
tuple
);
}
else
rtnval
=
EnvironmentError_str
((
PyEnvironmentErrorObject
*
)
self
);
return
rtnval
;
}
static
PyMemberDef
WindowsError_members
[]
=
{
{
"errno"
,
T_OBJECT
,
offsetof
(
PyWindowsErrorObject
,
myerrno
),
0
,
PyDoc_STR
(
"POSIX exception code"
)},
{
"strerror"
,
T_OBJECT
,
offsetof
(
PyWindowsErrorObject
,
strerror
),
0
,
PyDoc_STR
(
"exception strerror"
)},
{
"filename"
,
T_OBJECT
,
offsetof
(
PyWindowsErrorObject
,
filename
),
0
,
PyDoc_STR
(
"exception filename"
)},
{
"winerror"
,
T_OBJECT
,
offsetof
(
PyWindowsErrorObject
,
winerror
),
0
,
PyDoc_STR
(
"Win32 exception code"
)},
{
NULL
}
/* Sentinel */
};
ComplexExtendsException
(
PyExc_OSError
,
WindowsError
,
WindowsError
,
WindowsError_dealloc
,
0
,
WindowsError_members
,
WindowsError_str
,
"MS-Windows OS system call failed."
);
#endif
/* MS_WINDOWS */
/*
* VMSError extends OSError (I think)
*/
#ifdef __VMS
MiddlingExtendsException
(
PyExc_OSError
,
VMSError
,
EnvironmentError
,
"OpenVMS OS system call failed."
);
#endif
/*
* EOFError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
EOFError
,
"Read beyond end of file."
);
/*
* RuntimeError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
RuntimeError
,
"Unspecified run-time error."
);
/*
* NotImplementedError extends RuntimeError
*/
SimpleExtendsException
(
PyExc_RuntimeError
,
NotImplementedError
,
"Method or function hasn't been implemented yet."
);
/*
* NameError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
NameError
,
"Name not found globally."
);
/*
* UnboundLocalError extends NameError
*/
SimpleExtendsException
(
PyExc_NameError
,
UnboundLocalError
,
"Local name referenced but not bound to a value."
);
/*
* AttributeError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
AttributeError
,
"Attribute not found."
);
/*
* SyntaxError extends StandardError
*/
static
int
SyntaxError_init
(
PySyntaxErrorObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
)
{
PyObject
*
info
=
NULL
;
Py_ssize_t
lenargs
=
PyTuple_GET_SIZE
(
args
);
if
(
BaseException_init
((
PyBaseExceptionObject
*
)
self
,
args
,
kwds
)
==
-
1
)
return
-
1
;
if
(
lenargs
>=
1
)
{
Py_CLEAR
(
self
->
msg
);
self
->
msg
=
PyTuple_GET_ITEM
(
args
,
0
);
Py_INCREF
(
self
->
msg
);
}
if
(
lenargs
==
2
)
{
info
=
PyTuple_GET_ITEM
(
args
,
1
);
info
=
PySequence_Tuple
(
info
);
if
(
!
info
)
return
-
1
;
if
(
PyTuple_GET_SIZE
(
info
)
!=
4
)
{
/* not a very good error message, but it's what Python 2.4 gives */
PyErr_SetString
(
PyExc_IndexError
,
"tuple index out of range"
);
Py_DECREF
(
info
);
return
-
1
;
}
Py_CLEAR
(
self
->
filename
);
self
->
filename
=
PyTuple_GET_ITEM
(
info
,
0
);
Py_INCREF
(
self
->
filename
);
Py_CLEAR
(
self
->
lineno
);
self
->
lineno
=
PyTuple_GET_ITEM
(
info
,
1
);
Py_INCREF
(
self
->
lineno
);
Py_CLEAR
(
self
->
offset
);
self
->
offset
=
PyTuple_GET_ITEM
(
info
,
2
);
Py_INCREF
(
self
->
offset
);
Py_CLEAR
(
self
->
text
);
self
->
text
=
PyTuple_GET_ITEM
(
info
,
3
);
Py_INCREF
(
self
->
text
);
Py_DECREF
(
info
);
}
return
0
;
}
static
int
SyntaxError_clear
(
PySyntaxErrorObject
*
self
)
{
Py_CLEAR
(
self
->
msg
);
Py_CLEAR
(
self
->
filename
);
Py_CLEAR
(
self
->
lineno
);
Py_CLEAR
(
self
->
offset
);
Py_CLEAR
(
self
->
text
);
Py_CLEAR
(
self
->
print_file_and_line
);
return
BaseException_clear
((
PyBaseExceptionObject
*
)
self
);
}
static
void
SyntaxError_dealloc
(
PySyntaxErrorObject
*
self
)
{
_PyObject_GC_UNTRACK
(
self
);
SyntaxError_clear
(
self
);
Py_TYPE
(
self
)
->
tp_free
((
PyObject
*
)
self
);
}
static
int
SyntaxError_traverse
(
PySyntaxErrorObject
*
self
,
visitproc
visit
,
void
*
arg
)
{
Py_VISIT
(
self
->
msg
);
Py_VISIT
(
self
->
filename
);
Py_VISIT
(
self
->
lineno
);
Py_VISIT
(
self
->
offset
);
Py_VISIT
(
self
->
text
);
Py_VISIT
(
self
->
print_file_and_line
);
return
BaseException_traverse
((
PyBaseExceptionObject
*
)
self
,
visit
,
arg
);
}
/* This is called "my_basename" instead of just "basename" to avoid name
conflicts with glibc; basename is already prototyped if _GNU_SOURCE is
defined, and Python does define that. */
static
char
*
my_basename
(
char
*
name
)
{
char
*
cp
=
name
;
char
*
result
=
name
;
if
(
name
==
NULL
)
return
"???"
;
while
(
*
cp
!=
'\0'
)
{
if
(
*
cp
==
SEP
)
result
=
cp
+
1
;
++
cp
;
}
return
result
;
}
static
PyObject
*
SyntaxError_str
(
PySyntaxErrorObject
*
self
)
{
PyObject
*
str
;
PyObject
*
result
;
int
have_filename
=
0
;
int
have_lineno
=
0
;
char
*
buffer
=
NULL
;
Py_ssize_t
bufsize
;
if
(
self
->
msg
)
str
=
PyObject_Str
(
self
->
msg
);
else
str
=
PyObject_Str
(
Py_None
);
if
(
!
str
)
return
NULL
;
/* Don't fiddle with non-string return (shouldn't happen anyway) */
if
(
!
PyString_Check
(
str
))
return
str
;
/* XXX -- do all the additional formatting with filename and
lineno here */
have_filename
=
(
self
->
filename
!=
NULL
)
&&
PyString_Check
(
self
->
filename
);
have_lineno
=
(
self
->
lineno
!=
NULL
)
&&
PyInt_Check
(
self
->
lineno
);
if
(
!
have_filename
&&
!
have_lineno
)
return
str
;
bufsize
=
PyString_GET_SIZE
(
str
)
+
64
;
if
(
have_filename
)
bufsize
+=
PyString_GET_SIZE
(
self
->
filename
);
buffer
=
PyMem_MALLOC
(
bufsize
);
if
(
buffer
==
NULL
)
return
str
;
if
(
have_filename
&&
have_lineno
)
PyOS_snprintf
(
buffer
,
bufsize
,
"%s (%s, line %ld)"
,
PyString_AS_STRING
(
str
),
my_basename
(
PyString_AS_STRING
(
self
->
filename
)),
PyInt_AsLong
(
self
->
lineno
));
else
if
(
have_filename
)
PyOS_snprintf
(
buffer
,
bufsize
,
"%s (%s)"
,
PyString_AS_STRING
(
str
),
my_basename
(
PyString_AS_STRING
(
self
->
filename
)));
else
/* only have_lineno */
PyOS_snprintf
(
buffer
,
bufsize
,
"%s (line %ld)"
,
PyString_AS_STRING
(
str
),
PyInt_AsLong
(
self
->
lineno
));
result
=
PyString_FromString
(
buffer
);
PyMem_FREE
(
buffer
);
if
(
result
==
NULL
)
result
=
str
;
else
Py_DECREF
(
str
);
return
result
;
}
static
PyMemberDef
SyntaxError_members
[]
=
{
{
"msg"
,
T_OBJECT
,
offsetof
(
PySyntaxErrorObject
,
msg
),
0
,
PyDoc_STR
(
"exception msg"
)},
{
"filename"
,
T_OBJECT
,
offsetof
(
PySyntaxErrorObject
,
filename
),
0
,
PyDoc_STR
(
"exception filename"
)},
{
"lineno"
,
T_OBJECT
,
offsetof
(
PySyntaxErrorObject
,
lineno
),
0
,
PyDoc_STR
(
"exception lineno"
)},
{
"offset"
,
T_OBJECT
,
offsetof
(
PySyntaxErrorObject
,
offset
),
0
,
PyDoc_STR
(
"exception offset"
)},
{
"text"
,
T_OBJECT
,
offsetof
(
PySyntaxErrorObject
,
text
),
0
,
PyDoc_STR
(
"exception text"
)},
{
"print_file_and_line"
,
T_OBJECT
,
offsetof
(
PySyntaxErrorObject
,
print_file_and_line
),
0
,
PyDoc_STR
(
"exception print_file_and_line"
)},
{
NULL
}
/* Sentinel */
};
ComplexExtendsException
(
PyExc_StandardError
,
SyntaxError
,
SyntaxError
,
SyntaxError_dealloc
,
0
,
SyntaxError_members
,
SyntaxError_str
,
"Invalid syntax."
);
/*
* IndentationError extends SyntaxError
*/
MiddlingExtendsException
(
PyExc_SyntaxError
,
IndentationError
,
SyntaxError
,
"Improper indentation."
);
/*
* TabError extends IndentationError
*/
MiddlingExtendsException
(
PyExc_IndentationError
,
TabError
,
SyntaxError
,
"Improper mixture of spaces and tabs."
);
/*
* LookupError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
LookupError
,
"Base class for lookup errors."
);
/*
* IndexError extends LookupError
*/
SimpleExtendsException
(
PyExc_LookupError
,
IndexError
,
"Sequence index out of range."
);
/*
* KeyError extends LookupError
*/
static
PyObject
*
KeyError_str
(
PyBaseExceptionObject
*
self
)
{
/* If args is a tuple of exactly one item, apply repr to args[0].
This is done so that e.g. the exception raised by {}[''] prints
KeyError: ''
rather than the confusing
KeyError
alone. The downside is that if KeyError is raised with an explanatory
string, that string will be displayed in quotes. Too bad.
If args is anything else, use the default BaseException__str__().
*/
if
(
PyTuple_GET_SIZE
(
self
->
args
)
==
1
)
{
return
PyObject_Repr
(
PyTuple_GET_ITEM
(
self
->
args
,
0
));
}
return
BaseException_str
(
self
);
}
ComplexExtendsException
(
PyExc_LookupError
,
KeyError
,
BaseException
,
0
,
0
,
0
,
KeyError_str
,
"Mapping key not found."
);
/*
* ValueError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
ValueError
,
"Inappropriate argument value (of correct type)."
);
/*
* UnicodeError extends ValueError
*/
SimpleExtendsException
(
PyExc_ValueError
,
UnicodeError
,
"Unicode related error."
);
#ifdef Py_USING_UNICODE
static
PyObject
*
get_string
(
PyObject
*
attr
,
const
char
*
name
)
{
if
(
!
attr
)
{
PyErr_Format
(
PyExc_TypeError
,
"%.200s attribute not set"
,
name
);
return
NULL
;
}
if
(
!
PyString_Check
(
attr
))
{
PyErr_Format
(
PyExc_TypeError
,
"%.200s attribute must be str"
,
name
);
return
NULL
;
}
Py_INCREF
(
attr
);
return
attr
;
}
static
int
set_string
(
PyObject
**
attr
,
const
char
*
value
)
{
PyObject
*
obj
=
PyString_FromString
(
value
);
if
(
!
obj
)
return
-
1
;
Py_CLEAR
(
*
attr
);
*
attr
=
obj
;
return
0
;
}
static
PyObject
*
get_unicode
(
PyObject
*
attr
,
const
char
*
name
)
{
if
(
!
attr
)
{
PyErr_Format
(
PyExc_TypeError
,
"%.200s attribute not set"
,
name
);
return
NULL
;
}
if
(
!
PyUnicode_Check
(
attr
))
{
PyErr_Format
(
PyExc_TypeError
,
"%.200s attribute must be unicode"
,
name
);
return
NULL
;
}
Py_INCREF
(
attr
);
return
attr
;
}
PyObject
*
PyUnicodeEncodeError_GetEncoding
(
PyObject
*
exc
)
{
return
get_string
(((
PyUnicodeErrorObject
*
)
exc
)
->
encoding
,
"encoding"
);
}
PyObject
*
PyUnicodeDecodeError_GetEncoding
(
PyObject
*
exc
)
{
return
get_string
(((
PyUnicodeErrorObject
*
)
exc
)
->
encoding
,
"encoding"
);
}
PyObject
*
PyUnicodeEncodeError_GetObject
(
PyObject
*
exc
)
{
return
get_unicode
(((
PyUnicodeErrorObject
*
)
exc
)
->
object
,
"object"
);
}
PyObject
*
PyUnicodeDecodeError_GetObject
(
PyObject
*
exc
)
{
return
get_string
(((
PyUnicodeErrorObject
*
)
exc
)
->
object
,
"object"
);
}
PyObject
*
PyUnicodeTranslateError_GetObject
(
PyObject
*
exc
)
{
return
get_unicode
(((
PyUnicodeErrorObject
*
)
exc
)
->
object
,
"object"
);
}
int
PyUnicodeEncodeError_GetStart
(
PyObject
*
exc
,
Py_ssize_t
*
start
)
{
Py_ssize_t
size
;
PyObject
*
obj
=
get_unicode
(((
PyUnicodeErrorObject
*
)
exc
)
->
object
,
"object"
);
if
(
!
obj
)
return
-
1
;
*
start
=
((
PyUnicodeErrorObject
*
)
exc
)
->
start
;
size
=
PyUnicode_GET_SIZE
(
obj
);
if
(
*
start
<
0
)
*
start
=
0
;
/*XXX check for values <0*/
if
(
*
start
>=
size
)
*
start
=
size
-
1
;
Py_DECREF
(
obj
);
return
0
;
}
int
PyUnicodeDecodeError_GetStart
(
PyObject
*
exc
,
Py_ssize_t
*
start
)
{
Py_ssize_t
size
;
PyObject
*
obj
=
get_string
(((
PyUnicodeErrorObject
*
)
exc
)
->
object
,
"object"
);
if
(
!
obj
)
return
-
1
;
size
=
PyString_GET_SIZE
(
obj
);
*
start
=
((
PyUnicodeErrorObject
*
)
exc
)
->
start
;
if
(
*
start
<
0
)
*
start
=
0
;
if
(
*
start
>=
size
)
*
start
=
size
-
1
;
Py_DECREF
(
obj
);
return
0
;
}
int
PyUnicodeTranslateError_GetStart
(
PyObject
*
exc
,
Py_ssize_t
*
start
)
{
return
PyUnicodeEncodeError_GetStart
(
exc
,
start
);
}
int
PyUnicodeEncodeError_SetStart
(
PyObject
*
exc
,
Py_ssize_t
start
)
{
((
PyUnicodeErrorObject
*
)
exc
)
->
start
=
start
;
return
0
;
}
int
PyUnicodeDecodeError_SetStart
(
PyObject
*
exc
,
Py_ssize_t
start
)
{
((
PyUnicodeErrorObject
*
)
exc
)
->
start
=
start
;
return
0
;
}
int
PyUnicodeTranslateError_SetStart
(
PyObject
*
exc
,
Py_ssize_t
start
)
{
((
PyUnicodeErrorObject
*
)
exc
)
->
start
=
start
;
return
0
;
}
int
PyUnicodeEncodeError_GetEnd
(
PyObject
*
exc
,
Py_ssize_t
*
end
)
{
Py_ssize_t
size
;
PyObject
*
obj
=
get_unicode
(((
PyUnicodeErrorObject
*
)
exc
)
->
object
,
"object"
);
if
(
!
obj
)
return
-
1
;
*
end
=
((
PyUnicodeErrorObject
*
)
exc
)
->
end
;
size
=
PyUnicode_GET_SIZE
(
obj
);
if
(
*
end
<
1
)
*
end
=
1
;
if
(
*
end
>
size
)
*
end
=
size
;
Py_DECREF
(
obj
);
return
0
;
}
int
PyUnicodeDecodeError_GetEnd
(
PyObject
*
exc
,
Py_ssize_t
*
end
)
{
Py_ssize_t
size
;
PyObject
*
obj
=
get_string
(((
PyUnicodeErrorObject
*
)
exc
)
->
object
,
"object"
);
if
(
!
obj
)
return
-
1
;
*
end
=
((
PyUnicodeErrorObject
*
)
exc
)
->
end
;
size
=
PyString_GET_SIZE
(
obj
);
if
(
*
end
<
1
)
*
end
=
1
;
if
(
*
end
>
size
)
*
end
=
size
;
Py_DECREF
(
obj
);
return
0
;
}
int
PyUnicodeTranslateError_GetEnd
(
PyObject
*
exc
,
Py_ssize_t
*
start
)
{
return
PyUnicodeEncodeError_GetEnd
(
exc
,
start
);
}
int
PyUnicodeEncodeError_SetEnd
(
PyObject
*
exc
,
Py_ssize_t
end
)
{
((
PyUnicodeErrorObject
*
)
exc
)
->
end
=
end
;
return
0
;
}
int
PyUnicodeDecodeError_SetEnd
(
PyObject
*
exc
,
Py_ssize_t
end
)
{
((
PyUnicodeErrorObject
*
)
exc
)
->
end
=
end
;
return
0
;
}
int
PyUnicodeTranslateError_SetEnd
(
PyObject
*
exc
,
Py_ssize_t
end
)
{
((
PyUnicodeErrorObject
*
)
exc
)
->
end
=
end
;
return
0
;
}
PyObject
*
PyUnicodeEncodeError_GetReason
(
PyObject
*
exc
)
{
return
get_string
(((
PyUnicodeErrorObject
*
)
exc
)
->
reason
,
"reason"
);
}
PyObject
*
PyUnicodeDecodeError_GetReason
(
PyObject
*
exc
)
{
return
get_string
(((
PyUnicodeErrorObject
*
)
exc
)
->
reason
,
"reason"
);
}
PyObject
*
PyUnicodeTranslateError_GetReason
(
PyObject
*
exc
)
{
return
get_string
(((
PyUnicodeErrorObject
*
)
exc
)
->
reason
,
"reason"
);
}
int
PyUnicodeEncodeError_SetReason
(
PyObject
*
exc
,
const
char
*
reason
)
{
return
set_string
(
&
((
PyUnicodeErrorObject
*
)
exc
)
->
reason
,
reason
);
}
int
PyUnicodeDecodeError_SetReason
(
PyObject
*
exc
,
const
char
*
reason
)
{
return
set_string
(
&
((
PyUnicodeErrorObject
*
)
exc
)
->
reason
,
reason
);
}
int
PyUnicodeTranslateError_SetReason
(
PyObject
*
exc
,
const
char
*
reason
)
{
return
set_string
(
&
((
PyUnicodeErrorObject
*
)
exc
)
->
reason
,
reason
);
}
static
int
UnicodeError_init
(
PyUnicodeErrorObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
,
PyTypeObject
*
objecttype
)
{
Py_CLEAR
(
self
->
encoding
);
Py_CLEAR
(
self
->
object
);
Py_CLEAR
(
self
->
reason
);
if
(
!
PyArg_ParseTuple
(
args
,
"O!O!nnO!"
,
&
PyString_Type
,
&
self
->
encoding
,
objecttype
,
&
self
->
object
,
&
self
->
start
,
&
self
->
end
,
&
PyString_Type
,
&
self
->
reason
))
{
self
->
encoding
=
self
->
object
=
self
->
reason
=
NULL
;
return
-
1
;
}
Py_INCREF
(
self
->
encoding
);
Py_INCREF
(
self
->
object
);
Py_INCREF
(
self
->
reason
);
return
0
;
}
static
int
UnicodeError_clear
(
PyUnicodeErrorObject
*
self
)
{
Py_CLEAR
(
self
->
encoding
);
Py_CLEAR
(
self
->
object
);
Py_CLEAR
(
self
->
reason
);
return
BaseException_clear
((
PyBaseExceptionObject
*
)
self
);
}
static
void
UnicodeError_dealloc
(
PyUnicodeErrorObject
*
self
)
{
_PyObject_GC_UNTRACK
(
self
);
UnicodeError_clear
(
self
);
Py_TYPE
(
self
)
->
tp_free
((
PyObject
*
)
self
);
}
static
int
UnicodeError_traverse
(
PyUnicodeErrorObject
*
self
,
visitproc
visit
,
void
*
arg
)
{
Py_VISIT
(
self
->
encoding
);
Py_VISIT
(
self
->
object
);
Py_VISIT
(
self
->
reason
);
return
BaseException_traverse
((
PyBaseExceptionObject
*
)
self
,
visit
,
arg
);
}
static
PyMemberDef
UnicodeError_members
[]
=
{
{
"encoding"
,
T_OBJECT
,
offsetof
(
PyUnicodeErrorObject
,
encoding
),
0
,
PyDoc_STR
(
"exception encoding"
)},
{
"object"
,
T_OBJECT
,
offsetof
(
PyUnicodeErrorObject
,
object
),
0
,
PyDoc_STR
(
"exception object"
)},
{
"start"
,
T_PYSSIZET
,
offsetof
(
PyUnicodeErrorObject
,
start
),
0
,
PyDoc_STR
(
"exception start"
)},
{
"end"
,
T_PYSSIZET
,
offsetof
(
PyUnicodeErrorObject
,
end
),
0
,
PyDoc_STR
(
"exception end"
)},
{
"reason"
,
T_OBJECT
,
offsetof
(
PyUnicodeErrorObject
,
reason
),
0
,
PyDoc_STR
(
"exception reason"
)},
{
NULL
}
/* Sentinel */
};
/*
* UnicodeEncodeError extends UnicodeError
*/
static
int
UnicodeEncodeError_init
(
PyObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
)
{
if
(
BaseException_init
((
PyBaseExceptionObject
*
)
self
,
args
,
kwds
)
==
-
1
)
return
-
1
;
return
UnicodeError_init
((
PyUnicodeErrorObject
*
)
self
,
args
,
kwds
,
&
PyUnicode_Type
);
}
static
PyObject
*
UnicodeEncodeError_str
(
PyObject
*
self
)
{
PyUnicodeErrorObject
*
uself
=
(
PyUnicodeErrorObject
*
)
self
;
PyObject
*
result
=
NULL
;
PyObject
*
reason_str
=
NULL
;
PyObject
*
encoding_str
=
NULL
;
if
(
!
uself
->
object
)
/* Not properly initialized. */
return
PyUnicode_FromString
(
""
);
/* Get reason and encoding as strings, which they might not be if
they've been modified after we were contructed. */
reason_str
=
PyObject_Str
(
uself
->
reason
);
if
(
reason_str
==
NULL
)
goto
done
;
encoding_str
=
PyObject_Str
(
uself
->
encoding
);
if
(
encoding_str
==
NULL
)
goto
done
;
if
(
uself
->
start
<
PyUnicode_GET_SIZE
(
uself
->
object
)
&&
uself
->
end
==
uself
->
start
+
1
)
{
int
badchar
=
(
int
)
PyUnicode_AS_UNICODE
(
uself
->
object
)[
uself
->
start
];
char
badchar_str
[
20
];
if
(
badchar
<=
0xff
)
PyOS_snprintf
(
badchar_str
,
sizeof
(
badchar_str
),
"x%02x"
,
badchar
);
else
if
(
badchar
<=
0xffff
)
PyOS_snprintf
(
badchar_str
,
sizeof
(
badchar_str
),
"u%04x"
,
badchar
);
else
PyOS_snprintf
(
badchar_str
,
sizeof
(
badchar_str
),
"U%08x"
,
badchar
);
result
=
PyString_FromFormat
(
"'%.400s' codec can't encode character u'
\\
%s' in position %zd: %.400s"
,
PyString_AS_STRING
(
encoding_str
),
badchar_str
,
uself
->
start
,
PyString_AS_STRING
(
reason_str
));
}
else
{
result
=
PyString_FromFormat
(
"'%.400s' codec can't encode characters in position %zd-%zd: %.400s"
,
PyString_AS_STRING
(
encoding_str
),
uself
->
start
,
uself
->
end
-
1
,
PyString_AS_STRING
(
reason_str
));
}
done:
Py_XDECREF
(
reason_str
);
Py_XDECREF
(
encoding_str
);
return
result
;
}
static
PyTypeObject
_PyExc_UnicodeEncodeError
=
{
PyObject_HEAD_INIT
(
NULL
)
0
,
EXC_MODULE_NAME
"UnicodeEncodeError"
,
sizeof
(
PyUnicodeErrorObject
),
0
,
(
destructor
)
UnicodeError_dealloc
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
(
reprfunc
)
UnicodeEncodeError_str
,
0
,
0
,
0
,
Py_TPFLAGS_DEFAULT
|
Py_TPFLAGS_BASETYPE
|
Py_TPFLAGS_HAVE_GC
,
PyDoc_STR
(
"Unicode encoding error."
),
(
traverseproc
)
UnicodeError_traverse
,
(
inquiry
)
UnicodeError_clear
,
0
,
0
,
0
,
0
,
0
,
UnicodeError_members
,
0
,
&
_PyExc_UnicodeError
,
0
,
0
,
0
,
offsetof
(
PyUnicodeErrorObject
,
dict
),
(
initproc
)
UnicodeEncodeError_init
,
0
,
BaseException_new
,
};
PyObject
*
PyExc_UnicodeEncodeError
=
(
PyObject
*
)
&
_PyExc_UnicodeEncodeError
;
PyObject
*
PyUnicodeEncodeError_Create
(
const
char
*
encoding
,
const
Py_UNICODE
*
object
,
Py_ssize_t
length
,
Py_ssize_t
start
,
Py_ssize_t
end
,
const
char
*
reason
)
{
return
PyObject_CallFunction
(
PyExc_UnicodeEncodeError
,
"su#nns"
,
encoding
,
object
,
length
,
start
,
end
,
reason
);
}
/*
* UnicodeDecodeError extends UnicodeError
*/
static
int
UnicodeDecodeError_init
(
PyObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
)
{
if
(
BaseException_init
((
PyBaseExceptionObject
*
)
self
,
args
,
kwds
)
==
-
1
)
return
-
1
;
return
UnicodeError_init
((
PyUnicodeErrorObject
*
)
self
,
args
,
kwds
,
&
PyString_Type
);
}
static
PyObject
*
UnicodeDecodeError_str
(
PyObject
*
self
)
{
PyUnicodeErrorObject
*
uself
=
(
PyUnicodeErrorObject
*
)
self
;
PyObject
*
result
=
NULL
;
PyObject
*
reason_str
=
NULL
;
PyObject
*
encoding_str
=
NULL
;
if
(
!
uself
->
object
)
/* Not properly initialized. */
return
PyUnicode_FromString
(
""
);
/* Get reason and encoding as strings, which they might not be if
they've been modified after we were contructed. */
reason_str
=
PyObject_Str
(
uself
->
reason
);
if
(
reason_str
==
NULL
)
goto
done
;
encoding_str
=
PyObject_Str
(
uself
->
encoding
);
if
(
encoding_str
==
NULL
)
goto
done
;
if
(
uself
->
start
<
PyUnicode_GET_SIZE
(
uself
->
object
)
&&
uself
->
end
==
uself
->
start
+
1
)
{
/* FromFormat does not support %02x, so format that separately */
char
byte
[
4
];
PyOS_snprintf
(
byte
,
sizeof
(
byte
),
"%02x"
,
((
int
)
PyString_AS_STRING
(
uself
->
object
)[
uself
->
start
])
&
0xff
);
result
=
PyString_FromFormat
(
"'%.400s' codec can't decode byte 0x%s in position %zd: %.400s"
,
PyString_AS_STRING
(
encoding_str
),
byte
,
uself
->
start
,
PyString_AS_STRING
(
reason_str
));
}
else
{
result
=
PyString_FromFormat
(
"'%.400s' codec can't decode bytes in position %zd-%zd: %.400s"
,
PyString_AS_STRING
(
encoding_str
),
uself
->
start
,
uself
->
end
-
1
,
PyString_AS_STRING
(
reason_str
));
}
done:
Py_XDECREF
(
reason_str
);
Py_XDECREF
(
encoding_str
);
return
result
;
}
static
PyTypeObject
_PyExc_UnicodeDecodeError
=
{
PyObject_HEAD_INIT
(
NULL
)
0
,
EXC_MODULE_NAME
"UnicodeDecodeError"
,
sizeof
(
PyUnicodeErrorObject
),
0
,
(
destructor
)
UnicodeError_dealloc
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
(
reprfunc
)
UnicodeDecodeError_str
,
0
,
0
,
0
,
Py_TPFLAGS_DEFAULT
|
Py_TPFLAGS_BASETYPE
|
Py_TPFLAGS_HAVE_GC
,
PyDoc_STR
(
"Unicode decoding error."
),
(
traverseproc
)
UnicodeError_traverse
,
(
inquiry
)
UnicodeError_clear
,
0
,
0
,
0
,
0
,
0
,
UnicodeError_members
,
0
,
&
_PyExc_UnicodeError
,
0
,
0
,
0
,
offsetof
(
PyUnicodeErrorObject
,
dict
),
(
initproc
)
UnicodeDecodeError_init
,
0
,
BaseException_new
,
};
PyObject
*
PyExc_UnicodeDecodeError
=
(
PyObject
*
)
&
_PyExc_UnicodeDecodeError
;
PyObject
*
PyUnicodeDecodeError_Create
(
const
char
*
encoding
,
const
char
*
object
,
Py_ssize_t
length
,
Py_ssize_t
start
,
Py_ssize_t
end
,
const
char
*
reason
)
{
return
PyObject_CallFunction
(
PyExc_UnicodeDecodeError
,
"ss#nns"
,
encoding
,
object
,
length
,
start
,
end
,
reason
);
}
/*
* UnicodeTranslateError extends UnicodeError
*/
static
int
UnicodeTranslateError_init
(
PyUnicodeErrorObject
*
self
,
PyObject
*
args
,
PyObject
*
kwds
)
{
if
(
BaseException_init
((
PyBaseExceptionObject
*
)
self
,
args
,
kwds
)
==
-
1
)
return
-
1
;
Py_CLEAR
(
self
->
object
);
Py_CLEAR
(
self
->
reason
);
if
(
!
PyArg_ParseTuple
(
args
,
"O!nnO!"
,
&
PyUnicode_Type
,
&
self
->
object
,
&
self
->
start
,
&
self
->
end
,
&
PyString_Type
,
&
self
->
reason
))
{
self
->
object
=
self
->
reason
=
NULL
;
return
-
1
;
}
Py_INCREF
(
self
->
object
);
Py_INCREF
(
self
->
reason
);
return
0
;
}
static
PyObject
*
UnicodeTranslateError_str
(
PyObject
*
self
)
{
PyUnicodeErrorObject
*
uself
=
(
PyUnicodeErrorObject
*
)
self
;
PyObject
*
result
=
NULL
;
PyObject
*
reason_str
=
NULL
;
if
(
!
uself
->
object
)
/* Not properly initialized. */
return
PyUnicode_FromString
(
""
);
/* Get reason as a string, which it might not be if it's been
modified after we were contructed. */
reason_str
=
PyObject_Str
(
uself
->
reason
);
if
(
reason_str
==
NULL
)
goto
done
;
if
(
uself
->
start
<
PyUnicode_GET_SIZE
(
uself
->
object
)
&&
uself
->
end
==
uself
->
start
+
1
)
{
int
badchar
=
(
int
)
PyUnicode_AS_UNICODE
(
uself
->
object
)[
uself
->
start
];
char
badchar_str
[
20
];
if
(
badchar
<=
0xff
)
PyOS_snprintf
(
badchar_str
,
sizeof
(
badchar_str
),
"x%02x"
,
badchar
);
else
if
(
badchar
<=
0xffff
)
PyOS_snprintf
(
badchar_str
,
sizeof
(
badchar_str
),
"u%04x"
,
badchar
);
else
PyOS_snprintf
(
badchar_str
,
sizeof
(
badchar_str
),
"U%08x"
,
badchar
);
result
=
PyString_FromFormat
(
"can't translate character u'
\\
%s' in position %zd: %.400s"
,
badchar_str
,
uself
->
start
,
PyString_AS_STRING
(
reason_str
));
}
else
{
result
=
PyString_FromFormat
(
"can't translate characters in position %zd-%zd: %.400s"
,
uself
->
start
,
uself
->
end
-
1
,
PyString_AS_STRING
(
reason_str
));
}
done:
Py_XDECREF
(
reason_str
);
return
result
;
}
static
PyTypeObject
_PyExc_UnicodeTranslateError
=
{
PyObject_HEAD_INIT
(
NULL
)
0
,
EXC_MODULE_NAME
"UnicodeTranslateError"
,
sizeof
(
PyUnicodeErrorObject
),
0
,
(
destructor
)
UnicodeError_dealloc
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
(
reprfunc
)
UnicodeTranslateError_str
,
0
,
0
,
0
,
Py_TPFLAGS_DEFAULT
|
Py_TPFLAGS_BASETYPE
|
Py_TPFLAGS_HAVE_GC
,
PyDoc_STR
(
"Unicode translation error."
),
(
traverseproc
)
UnicodeError_traverse
,
(
inquiry
)
UnicodeError_clear
,
0
,
0
,
0
,
0
,
0
,
UnicodeError_members
,
0
,
&
_PyExc_UnicodeError
,
0
,
0
,
0
,
offsetof
(
PyUnicodeErrorObject
,
dict
),
(
initproc
)
UnicodeTranslateError_init
,
0
,
BaseException_new
,
};
PyObject
*
PyExc_UnicodeTranslateError
=
(
PyObject
*
)
&
_PyExc_UnicodeTranslateError
;
PyObject
*
PyUnicodeTranslateError_Create
(
const
Py_UNICODE
*
object
,
Py_ssize_t
length
,
Py_ssize_t
start
,
Py_ssize_t
end
,
const
char
*
reason
)
{
return
PyObject_CallFunction
(
PyExc_UnicodeTranslateError
,
"u#nns"
,
object
,
length
,
start
,
end
,
reason
);
}
#endif
/*
* AssertionError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
AssertionError
,
"Assertion failed."
);
/*
* ArithmeticError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
ArithmeticError
,
"Base class for arithmetic errors."
);
/*
* FloatingPointError extends ArithmeticError
*/
SimpleExtendsException
(
PyExc_ArithmeticError
,
FloatingPointError
,
"Floating point operation failed."
);
/*
* OverflowError extends ArithmeticError
*/
SimpleExtendsException
(
PyExc_ArithmeticError
,
OverflowError
,
"Result too large to be represented."
);
/*
* ZeroDivisionError extends ArithmeticError
*/
SimpleExtendsException
(
PyExc_ArithmeticError
,
ZeroDivisionError
,
"Second argument to a division or modulo operation was zero."
);
/*
* SystemError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
SystemError
,
"Internal error in the Python interpreter.
\n
"
"
\n
"
"Please report this to the Python maintainer, along with the traceback,
\n
"
"the Python version, and the hardware/OS platform and version."
);
/*
* ReferenceError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
ReferenceError
,
"Weak ref proxy used after referent went away."
);
/*
* MemoryError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
MemoryError
,
"Out of memory."
);
/*
* BufferError extends StandardError
*/
SimpleExtendsException
(
PyExc_StandardError
,
BufferError
,
"Buffer error."
);
/* Warning category docstrings */
/*
* Warning extends Exception
*/
SimpleExtendsException
(
PyExc_Exception
,
Warning
,
"Base class for warning categories."
);
/*
* UserWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
UserWarning
,
"Base class for warnings generated by user code."
);
/*
* DeprecationWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
DeprecationWarning
,
"Base class for warnings about deprecated features."
);
/*
* PendingDeprecationWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
PendingDeprecationWarning
,
"Base class for warnings about features which will be deprecated
\n
"
"in the future."
);
/*
* SyntaxWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
SyntaxWarning
,
"Base class for warnings about dubious syntax."
);
/*
* RuntimeWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
RuntimeWarning
,
"Base class for warnings about dubious runtime behavior."
);
/*
* FutureWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
FutureWarning
,
"Base class for warnings about constructs that will change semantically
\n
"
"in the future."
);
/*
* ImportWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
ImportWarning
,
"Base class for warnings about probable mistakes in module imports"
);
/*
* UnicodeWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
UnicodeWarning
,
"Base class for warnings about Unicode related problems, mostly
\n
"
"related to conversion problems."
);
/*
* BytesWarning extends Warning
*/
SimpleExtendsException
(
PyExc_Warning
,
BytesWarning
,
"Base class for warnings about bytes and buffer related problems, mostly
\n
"
"related to conversion from str or comparing to str."
);
/* Pre-computed MemoryError instance. Best to create this as early as
* possible and not wait until a MemoryError is actually raised!
*/
PyObject
*
PyExc_MemoryErrorInst
=
NULL
;
/* Pre-computed RuntimeError instance for when recursion depth is reached.
Meant to be used when normalizing the exception for exceeding the recursion
depth will cause its own infinite recursion.
*/
PyObject
*
PyExc_RecursionErrorInst
=
NULL
;
/* module global functions */
static
PyMethodDef
functions
[]
=
{
/* Sentinel */
{
NULL
,
NULL
}
};
#define PRE_INIT(TYPE) if (PyType_Ready(&_PyExc_ ## TYPE) < 0) \
Py_FatalError("exceptions bootstrapping error.");
#define POST_INIT(TYPE) Py_INCREF(PyExc_ ## TYPE); \
PyModule_AddObject(m, # TYPE, PyExc_ ## TYPE); \
if (PyDict_SetItemString(bdict, # TYPE, PyExc_ ## TYPE)) \
Py_FatalError("Module dictionary insertion problem.");
PyMODINIT_FUNC
_PyExc_Init
(
void
)
{
PyObject
*
m
,
*
bltinmod
,
*
bdict
;
PRE_INIT
(
BaseException
)
PRE_INIT
(
Exception
)
PRE_INIT
(
StandardError
)
PRE_INIT
(
TypeError
)
PRE_INIT
(
StopIteration
)
PRE_INIT
(
GeneratorExit
)
PRE_INIT
(
SystemExit
)
PRE_INIT
(
KeyboardInterrupt
)
PRE_INIT
(
ImportError
)
PRE_INIT
(
EnvironmentError
)
PRE_INIT
(
IOError
)
PRE_INIT
(
OSError
)
#ifdef MS_WINDOWS
PRE_INIT
(
WindowsError
)
#endif
#ifdef __VMS
PRE_INIT
(
VMSError
)
#endif
PRE_INIT
(
EOFError
)
PRE_INIT
(
RuntimeError
)
PRE_INIT
(
NotImplementedError
)
PRE_INIT
(
NameError
)
PRE_INIT
(
UnboundLocalError
)
PRE_INIT
(
AttributeError
)
PRE_INIT
(
SyntaxError
)
PRE_INIT
(
IndentationError
)
PRE_INIT
(
TabError
)
PRE_INIT
(
LookupError
)
PRE_INIT
(
IndexError
)
PRE_INIT
(
KeyError
)
PRE_INIT
(
ValueError
)
PRE_INIT
(
UnicodeError
)
#ifdef Py_USING_UNICODE
PRE_INIT
(
UnicodeEncodeError
)
PRE_INIT
(
UnicodeDecodeError
)
PRE_INIT
(
UnicodeTranslateError
)
#endif
PRE_INIT
(
AssertionError
)
PRE_INIT
(
ArithmeticError
)
PRE_INIT
(
FloatingPointError
)
PRE_INIT
(
OverflowError
)
PRE_INIT
(
ZeroDivisionError
)
PRE_INIT
(
SystemError
)
PRE_INIT
(
ReferenceError
)
PRE_INIT
(
MemoryError
)
PRE_INIT
(
BufferError
)
PRE_INIT
(
Warning
)
PRE_INIT
(
UserWarning
)
PRE_INIT
(
DeprecationWarning
)
PRE_INIT
(
PendingDeprecationWarning
)
PRE_INIT
(
SyntaxWarning
)
PRE_INIT
(
RuntimeWarning
)
PRE_INIT
(
FutureWarning
)
PRE_INIT
(
ImportWarning
)
PRE_INIT
(
UnicodeWarning
)
PRE_INIT
(
BytesWarning
)
m
=
Py_InitModule4
(
"exceptions"
,
functions
,
exceptions_doc
,
(
PyObject
*
)
NULL
,
PYTHON_API_VERSION
);
if
(
m
==
NULL
)
return
;
bltinmod
=
PyImport_ImportModule
(
"__builtin__"
);
if
(
bltinmod
==
NULL
)
Py_FatalError
(
"exceptions bootstrapping error."
);
bdict
=
PyModule_GetDict
(
bltinmod
);
if
(
bdict
==
NULL
)
Py_FatalError
(
"exceptions bootstrapping error."
);
POST_INIT
(
BaseException
)
POST_INIT
(
Exception
)
POST_INIT
(
StandardError
)
POST_INIT
(
TypeError
)
POST_INIT
(
StopIteration
)
POST_INIT
(
GeneratorExit
)
POST_INIT
(
SystemExit
)
POST_INIT
(
KeyboardInterrupt
)
POST_INIT
(
ImportError
)
POST_INIT
(
EnvironmentError
)
POST_INIT
(
IOError
)
POST_INIT
(
OSError
)
#ifdef MS_WINDOWS
POST_INIT
(
WindowsError
)
#endif
#ifdef __VMS
POST_INIT
(
VMSError
)
#endif
POST_INIT
(
EOFError
)
POST_INIT
(
RuntimeError
)
POST_INIT
(
NotImplementedError
)
POST_INIT
(
NameError
)
POST_INIT
(
UnboundLocalError
)
POST_INIT
(
AttributeError
)
POST_INIT
(
SyntaxError
)
POST_INIT
(
IndentationError
)
POST_INIT
(
TabError
)
POST_INIT
(
LookupError
)
POST_INIT
(
IndexError
)
POST_INIT
(
KeyError
)
POST_INIT
(
ValueError
)
POST_INIT
(
UnicodeError
)
#ifdef Py_USING_UNICODE
POST_INIT
(
UnicodeEncodeError
)
POST_INIT
(
UnicodeDecodeError
)
POST_INIT
(
UnicodeTranslateError
)
#endif
POST_INIT
(
AssertionError
)
POST_INIT
(
ArithmeticError
)
POST_INIT
(
FloatingPointError
)
POST_INIT
(
OverflowError
)
POST_INIT
(
ZeroDivisionError
)
POST_INIT
(
SystemError
)
POST_INIT
(
ReferenceError
)
POST_INIT
(
MemoryError
)
POST_INIT
(
BufferError
)
POST_INIT
(
Warning
)
POST_INIT
(
UserWarning
)
POST_INIT
(
DeprecationWarning
)
POST_INIT
(
PendingDeprecationWarning
)
POST_INIT
(
SyntaxWarning
)
POST_INIT
(
RuntimeWarning
)
POST_INIT
(
FutureWarning
)
POST_INIT
(
ImportWarning
)
POST_INIT
(
UnicodeWarning
)
POST_INIT
(
BytesWarning
)
PyExc_MemoryErrorInst
=
BaseException_new
(
&
_PyExc_MemoryError
,
NULL
,
NULL
);
if
(
!
PyExc_MemoryErrorInst
)
Py_FatalError
(
"Cannot pre-allocate MemoryError instance"
);
PyExc_RecursionErrorInst
=
BaseException_new
(
&
_PyExc_RuntimeError
,
NULL
,
NULL
);
if
(
!
PyExc_RecursionErrorInst
)
Py_FatalError
(
"Cannot pre-allocate RuntimeError instance for "
"recursion errors"
);
else
{
PyBaseExceptionObject
*
err_inst
=
(
PyBaseExceptionObject
*
)
PyExc_RecursionErrorInst
;
PyObject
*
args_tuple
;
PyObject
*
exc_message
;
exc_message
=
PyString_FromString
(
"maximum recursion depth exceeded"
);
if
(
!
exc_message
)
Py_FatalError
(
"cannot allocate argument for RuntimeError "
"pre-allocation"
);
args_tuple
=
PyTuple_Pack
(
1
,
exc_message
);
if
(
!
args_tuple
)
Py_FatalError
(
"cannot allocate tuple for RuntimeError "
"pre-allocation"
);
Py_DECREF
(
exc_message
);
if
(
BaseException_init
(
err_inst
,
args_tuple
,
NULL
))
Py_FatalError
(
"init of pre-allocated RuntimeError failed"
);
Py_DECREF
(
args_tuple
);
}
Py_DECREF
(
bltinmod
);
}
void
_PyExc_Fini
(
void
)
{
Py_CLEAR
(
PyExc_MemoryErrorInst
);
Py_CLEAR
(
PyExc_RecursionErrorInst
);
}
from_cpython/Python/formatter_unicode.c
0 → 100644
View file @
077fffc6
// This file is originally from CPython 2.7, with modifications for Pyston
/* Implements the unicode (as opposed to string) version of the
built-in formatter for unicode. That is, unicode.__format__(). */
#include "Python.h"
#ifdef Py_USING_UNICODE
#include "../Objects/stringlib/unicodedefs.h"
#define FORMAT_STRING _PyUnicode_FormatAdvanced
/* don't define FORMAT_LONG, FORMAT_FLOAT, and FORMAT_COMPLEX, since
we can live with only the string versions of those. The builtin
format() will convert them to unicode. */
#include "../Objects/stringlib/formatter.h"
#endif
src/capi/errors.cpp
View file @
077fffc6
...
...
@@ -188,7 +188,73 @@ extern "C" void PyErr_WriteUnraisable(PyObject* obj) noexcept {
static
int
parse_syntax_error
(
PyObject
*
err
,
PyObject
**
message
,
const
char
**
filename
,
int
*
lineno
,
int
*
offset
,
const
char
**
text
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
long
hold
;
PyObject
*
v
;
/* old style errors */
if
(
PyTuple_Check
(
err
))
return
PyArg_ParseTuple
(
err
,
"O(ziiz)"
,
message
,
filename
,
lineno
,
offset
,
text
);
*
message
=
NULL
;
/* new style errors. `err' is an instance */
*
message
=
PyObject_GetAttrString
(
err
,
"msg"
);
if
(
!*
message
)
goto
finally
;
v
=
PyObject_GetAttrString
(
err
,
"filename"
);
if
(
!
v
)
goto
finally
;
if
(
v
==
Py_None
)
{
Py_DECREF
(
v
);
*
filename
=
NULL
;
}
else
{
*
filename
=
PyString_AsString
(
v
);
Py_DECREF
(
v
);
if
(
!*
filename
)
goto
finally
;
}
v
=
PyObject_GetAttrString
(
err
,
"lineno"
);
if
(
!
v
)
goto
finally
;
hold
=
PyInt_AsLong
(
v
);
Py_DECREF
(
v
);
if
(
hold
<
0
&&
PyErr_Occurred
())
goto
finally
;
*
lineno
=
(
int
)
hold
;
v
=
PyObject_GetAttrString
(
err
,
"offset"
);
if
(
!
v
)
goto
finally
;
if
(
v
==
Py_None
)
{
*
offset
=
-
1
;
Py_DECREF
(
v
);
}
else
{
hold
=
PyInt_AsLong
(
v
);
Py_DECREF
(
v
);
if
(
hold
<
0
&&
PyErr_Occurred
())
goto
finally
;
*
offset
=
(
int
)
hold
;
}
v
=
PyObject_GetAttrString
(
err
,
"text"
);
if
(
!
v
)
goto
finally
;
if
(
v
==
Py_None
)
{
Py_DECREF
(
v
);
*
text
=
NULL
;
}
else
{
*
text
=
PyString_AsString
(
v
);
Py_DECREF
(
v
);
if
(
!*
text
)
goto
finally
;
}
return
1
;
finally:
Py_XDECREF
(
*
message
);
return
0
;
}
static
void
print_error_text
(
PyObject
*
f
,
int
offset
,
const
char
*
text
)
noexcept
{
...
...
src/capi/object.cpp
View file @
077fffc6
...
...
@@ -72,6 +72,10 @@ extern "C" int PyObject_GenericSetAttr(PyObject* obj, PyObject* name, PyObject*
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyObject_SetAttr
(
PyObject
*
v
,
PyObject
*
name
,
PyObject
*
value
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyObject_GetAttrString
(
PyObject
*
o
,
const
char
*
attr
)
noexcept
{
// TODO do something like this? not sure if this is safe; will people expect that calling into a known function
// won't end up doing a GIL check?
...
...
src/capi/typeobject.cpp
View file @
077fffc6
...
...
@@ -1784,6 +1784,10 @@ void PystonType_Ready(BoxedClass* cls) {
}
}
extern
"C"
void
PyType_Modified
(
PyTypeObject
*
type
)
noexcept
{
// We don't cache anything yet that would need to be invalidated:
}
extern
"C"
int
PyType_Ready
(
PyTypeObject
*
cls
)
noexcept
{
gc
::
registerNonheapRootObject
(
cls
);
...
...
src/core/types.h
View file @
077fffc6
...
...
@@ -522,8 +522,6 @@ void appendToSysPath(const std::string& path);
void
prependToSysPath
(
const
std
::
string
&
path
);
void
addToSysArgv
(
const
char
*
str
);
std
::
string
formatException
(
Box
*
e
);
// Raise a SyntaxError that occurs at a specific location.
// The traceback given to the user will include this,
// even though the execution didn't actually arrive there.
...
...
src/runtime/builtin_modules/builtins.cpp
View file @
077fffc6
...
...
@@ -589,19 +589,6 @@ Box* eval(Box* code) {
BoxedClass
*
notimplemented_cls
;
BoxedModule
*
builtins_module
;
// TODO looks like CPython and pypy put this into an "exceptions" module:
extern
"C"
{
BoxedClass
*
BaseException
,
*
Exception
,
*
StandardError
,
*
AssertionError
,
*
AttributeError
,
*
GeneratorExit
,
*
TypeError
,
*
NameError
,
*
KeyError
,
*
IndexError
,
*
IOError
,
*
OSError
,
*
ZeroDivisionError
,
*
ValueError
,
*
UnboundLocalError
,
*
RuntimeError
,
*
ImportError
,
*
StopIteration
,
*
Warning
,
*
SyntaxError
,
*
OverflowError
,
*
DeprecationWarning
,
*
MemoryError
,
*
LookupError
,
*
EnvironmentError
,
*
ArithmeticError
,
*
BufferError
,
*
KeyboardInterrupt
,
*
SystemExit
,
*
SystemError
,
*
NotImplementedError
,
*
PendingDeprecationWarning
,
*
EOFError
,
*
UnicodeError
,
*
UnicodeEncodeError
,
*
UnicodeDecodeError
,
*
UnicodeTranslateError
;
Box
*
PyExc_RecursionErrorInst
;
Box
*
PyExc_MemoryErrorInst
;
}
class
BoxedException
:
public
Box
{
public:
HCAttrs
attrs
;
...
...
@@ -879,123 +866,6 @@ Box* pydumpAddr(Box* p) {
return
None
;
}
class
BoxedEnvironmentError
:
public
BoxedException
{
public:
// Box* args, *message, *myerrno, *strerror, *filename;
Box
*
myerrno
,
*
strerror
,
*
filename
;
static
Box
*
__init__
(
BoxedEnvironmentError
*
self
,
Box
*
errno_
,
Box
*
strerror
,
Box
**
_args
)
{
Box
*
filename
=
_args
[
0
];
RELEASE_ASSERT
(
isSubclass
(
self
->
cls
,
EnvironmentError
),
""
);
self
->
myerrno
=
errno_
;
self
->
strerror
=
strerror
;
self
->
filename
=
filename
;
return
None
;
}
static
Box
*
__reduce__
(
Box
*
self
)
{
Py_FatalError
(
"unimplemented"
);
}
static
PyObject
*
__str__
(
BoxedEnvironmentError
*
self
)
noexcept
{
PyObject
*
rtnval
=
NULL
;
if
(
self
->
filename
)
{
PyObject
*
fmt
;
PyObject
*
repr
;
PyObject
*
tuple
;
fmt
=
PyString_FromString
(
"[Errno %s] %s: %s"
);
if
(
!
fmt
)
return
NULL
;
repr
=
PyObject_Repr
(
self
->
filename
);
if
(
!
repr
)
{
Py_DECREF
(
fmt
);
return
NULL
;
}
tuple
=
PyTuple_New
(
3
);
if
(
!
tuple
)
{
Py_DECREF
(
repr
);
Py_DECREF
(
fmt
);
return
NULL
;
}
if
(
self
->
myerrno
)
{
Py_INCREF
(
self
->
myerrno
);
PyTuple_SET_ITEM
(
tuple
,
0
,
self
->
myerrno
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
0
,
Py_None
);
}
if
(
self
->
strerror
)
{
Py_INCREF
(
self
->
strerror
);
PyTuple_SET_ITEM
(
tuple
,
1
,
self
->
strerror
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
1
,
Py_None
);
}
PyTuple_SET_ITEM
(
tuple
,
2
,
repr
);
rtnval
=
PyString_Format
(
fmt
,
tuple
);
Py_DECREF
(
fmt
);
Py_DECREF
(
tuple
);
}
else
if
(
self
->
myerrno
&&
self
->
strerror
)
{
PyObject
*
fmt
;
PyObject
*
tuple
;
fmt
=
PyString_FromString
(
"[Errno %s] %s"
);
if
(
!
fmt
)
return
NULL
;
tuple
=
PyTuple_New
(
2
);
if
(
!
tuple
)
{
Py_DECREF
(
fmt
);
return
NULL
;
}
if
(
self
->
myerrno
)
{
Py_INCREF
(
self
->
myerrno
);
PyTuple_SET_ITEM
(
tuple
,
0
,
self
->
myerrno
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
0
,
Py_None
);
}
if
(
self
->
strerror
)
{
Py_INCREF
(
self
->
strerror
);
PyTuple_SET_ITEM
(
tuple
,
1
,
self
->
strerror
);
}
else
{
Py_INCREF
(
Py_None
);
PyTuple_SET_ITEM
(
tuple
,
1
,
Py_None
);
}
rtnval
=
PyString_Format
(
fmt
,
tuple
);
Py_DECREF
(
fmt
);
Py_DECREF
(
tuple
);
}
else
rtnval
=
exceptionStr
(
self
);
return
rtnval
;
}
static
void
gcHandler
(
GCVisitor
*
v
,
Box
*
_b
)
{
assert
(
isSubclass
(
_b
->
cls
,
EnvironmentError
));
boxGCHandler
(
v
,
_b
);
BoxedEnvironmentError
*
ee
=
static_cast
<
BoxedEnvironmentError
*>
(
_b
);
if
(
ee
->
myerrno
)
v
->
visit
(
ee
->
myerrno
);
if
(
ee
->
strerror
)
v
->
visit
(
ee
->
strerror
);
if
(
ee
->
filename
)
v
->
visit
(
ee
->
filename
);
}
};
void
setupBuiltins
()
{
builtins_module
=
createModule
(
"__builtin__"
,
"__builtin__"
);
...
...
@@ -1018,67 +888,6 @@ void setupBuiltins() {
builtins_module
->
giveAttr
(
"all"
,
new
BoxedBuiltinFunctionOrMethod
(
boxRTFunction
((
void
*
)
all
,
BOXED_BOOL
,
1
),
"all"
));
builtins_module
->
giveAttr
(
"any"
,
new
BoxedBuiltinFunctionOrMethod
(
boxRTFunction
((
void
*
)
any
,
BOXED_BOOL
,
1
),
"any"
));
BaseException
=
makeBuiltinException
(
object_cls
,
"BaseException"
,
sizeof
(
BoxedException
));
Exception
=
makeBuiltinException
(
BaseException
,
"Exception"
);
StandardError
=
makeBuiltinException
(
Exception
,
"StandardError"
);
AssertionError
=
makeBuiltinException
(
StandardError
,
"AssertionError"
);
AttributeError
=
makeBuiltinException
(
StandardError
,
"AttributeError"
);
GeneratorExit
=
makeBuiltinException
(
BaseException
,
"GeneratorExit"
);
TypeError
=
makeBuiltinException
(
StandardError
,
"TypeError"
);
NameError
=
makeBuiltinException
(
StandardError
,
"NameError"
);
LookupError
=
makeBuiltinException
(
StandardError
,
"LookupError"
);
KeyError
=
makeBuiltinException
(
LookupError
,
"KeyError"
);
IndexError
=
makeBuiltinException
(
LookupError
,
"IndexError"
);
EnvironmentError
=
makeBuiltinException
(
StandardError
,
"EnvironmentError"
,
sizeof
(
BoxedEnvironmentError
));
IOError
=
makeBuiltinException
(
EnvironmentError
,
"IOError"
);
OSError
=
makeBuiltinException
(
EnvironmentError
,
"OSError"
);
ArithmeticError
=
makeBuiltinException
(
StandardError
,
"ArithmeticError"
);
ZeroDivisionError
=
makeBuiltinException
(
ArithmeticError
,
"ZeroDivisionError"
);
ValueError
=
makeBuiltinException
(
StandardError
,
"ValueError"
);
UnboundLocalError
=
makeBuiltinException
(
NameError
,
"UnboundLocalError"
);
RuntimeError
=
makeBuiltinException
(
StandardError
,
"RuntimeError"
);
ImportError
=
makeBuiltinException
(
StandardError
,
"ImportError"
);
StopIteration
=
makeBuiltinException
(
Exception
,
"StopIteration"
);
Warning
=
makeBuiltinException
(
Exception
,
"Warning"
);
SyntaxError
=
makeBuiltinException
(
StandardError
,
"SyntaxError"
);
OverflowError
=
makeBuiltinException
(
ArithmeticError
,
"OverflowError"
);
/*ImportWarning =*/
makeBuiltinException
(
Warning
,
"ImportWarning"
);
DeprecationWarning
=
makeBuiltinException
(
Warning
,
"DeprecationWarning"
);
/*BytesWarning =*/
makeBuiltinException
(
Warning
,
"BytesWarning"
);
MemoryError
=
makeBuiltinException
(
StandardError
,
"MemoryError"
);
BufferError
=
makeBuiltinException
(
StandardError
,
"BufferError"
);
KeyboardInterrupt
=
makeBuiltinException
(
BaseException
,
"KeyboardInterrupt"
);
SystemExit
=
makeBuiltinException
(
BaseException
,
"SystemExit"
);
SystemError
=
makeBuiltinException
(
StandardError
,
"SystemError"
);
NotImplementedError
=
makeBuiltinException
(
RuntimeError
,
"NotImplementedError"
);
PendingDeprecationWarning
=
makeBuiltinException
(
Warning
,
"PendingDeprecationWarning"
);
EOFError
=
makeBuiltinException
(
StandardError
,
"EOFError"
);
// Unicode errors
UnicodeError
=
makeBuiltinException
(
ValueError
,
"UnicodeError"
);
UnicodeEncodeError
=
makeBuiltinException
(
UnicodeError
,
"UnicodeEncodeError"
);
UnicodeDecodeError
=
makeBuiltinException
(
UnicodeError
,
"UnicodeDecodeError"
);
UnicodeTranslateError
=
makeBuiltinException
(
UnicodeError
,
"UnicodeTranslateError"
);
BaseException
->
giveAttr
(
"__reduce__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
BoxedException
::
__reduce__
,
UNKNOWN
,
1
)));
EnvironmentError
->
giveAttr
(
"__reduce__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
BoxedEnvironmentError
::
__reduce__
,
UNKNOWN
,
1
)));
EnvironmentError
->
gc_visit
=
BoxedEnvironmentError
::
gcHandler
;
EnvironmentError
->
giveAttr
(
"__init__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
BoxedEnvironmentError
::
__init__
,
NONE
,
4
,
3
,
false
,
false
),
{
NULL
,
NULL
,
NULL
}));
EnvironmentError
->
giveAttr
(
"errno"
,
new
BoxedMemberDescriptor
(
BoxedMemberDescriptor
::
OBJECT
,
offsetof
(
BoxedEnvironmentError
,
myerrno
)));
EnvironmentError
->
giveAttr
(
"strerror"
,
new
BoxedMemberDescriptor
(
BoxedMemberDescriptor
::
OBJECT
,
offsetof
(
BoxedEnvironmentError
,
strerror
)));
EnvironmentError
->
giveAttr
(
"filename"
,
new
BoxedMemberDescriptor
(
BoxedMemberDescriptor
::
OBJECT
,
offsetof
(
BoxedEnvironmentError
,
filename
)));
EnvironmentError
->
giveAttr
(
"__str__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
BoxedEnvironmentError
::
__str__
,
UNKNOWN
,
1
)));
repr_obj
=
new
BoxedBuiltinFunctionOrMethod
(
boxRTFunction
((
void
*
)
repr
,
UNKNOWN
,
1
),
"repr"
);
builtins_module
->
giveAttr
(
"repr"
,
repr_obj
);
...
...
@@ -1228,10 +1037,5 @@ void setupBuiltins() {
builtins_module
->
giveAttr
(
"classmethod"
,
classmethod_cls
);
builtins_module
->
giveAttr
(
"eval"
,
new
BoxedBuiltinFunctionOrMethod
(
boxRTFunction
((
void
*
)
eval
,
UNKNOWN
,
1
,
0
,
false
,
false
),
"eval"
));
PyExc_RecursionErrorInst
=
new
(
RuntimeError
)
BoxedException
();
gc
::
registerPermanentRoot
(
PyExc_RecursionErrorInst
);
PyExc_MemoryErrorInst
=
new
(
MemoryError
)
BoxedException
();
gc
::
registerPermanentRoot
(
PyExc_MemoryErrorInst
);
}
}
src/runtime/capi.cpp
View file @
077fffc6
...
...
@@ -673,21 +673,24 @@ void checkAndThrowCAPIException() {
if
(
!
tb
)
tb
=
None
;
// Make sure to call PyErr_Clear() *before* normalizing the exception, since otherwise
// the normalization can think that it had raised an exception, resulting to a call
// to checkAndThrowCAPIException, and boom.
PyErr_Clear
();
// This is similar to PyErr_NormalizeException:
if
(
!
isInstance
(
value
,
type
))
{
if
(
value
->
cls
==
tuple_cls
)
{
value
=
runtimeCall
(
cur_thread_state
.
curexc_type
,
ArgPassSpec
(
0
,
0
,
true
,
false
),
value
,
NULL
,
NULL
,
NULL
,
NULL
);
value
=
runtimeCall
(
type
,
ArgPassSpec
(
0
,
0
,
true
,
false
),
value
,
NULL
,
NULL
,
NULL
,
NULL
);
}
else
if
(
value
==
None
)
{
value
=
runtimeCall
(
cur_thread_state
.
curexc_
type
,
ArgPassSpec
(
0
),
NULL
,
NULL
,
NULL
,
NULL
,
NULL
);
value
=
runtimeCall
(
type
,
ArgPassSpec
(
0
),
NULL
,
NULL
,
NULL
,
NULL
,
NULL
);
}
else
{
value
=
runtimeCall
(
cur_thread_state
.
curexc_
type
,
ArgPassSpec
(
1
),
value
,
NULL
,
NULL
,
NULL
,
NULL
);
value
=
runtimeCall
(
type
,
ArgPassSpec
(
1
),
value
,
NULL
,
NULL
,
NULL
,
NULL
);
}
}
RELEASE_ASSERT
(
value
->
cls
==
type
,
"unsupported"
);
PyErr_Clear
();
if
(
tb
!=
None
)
raiseRaw
(
ExcInfo
(
value
->
cls
,
value
,
tb
));
raiseExc
(
value
);
...
...
@@ -856,6 +859,11 @@ extern "C" PyObject* PyErr_Occurred() noexcept {
}
extern
"C"
int
PyErr_WarnEx
(
PyObject
*
category
,
const
char
*
text
,
Py_ssize_t
stacklevel
)
noexcept
{
// These warnings are silenced by default:
// We should copy the real CPython code in here
if
(
category
==
PyExc_DeprecationWarning
)
return
0
;
Py_FatalError
(
"unimplemented"
);
}
...
...
src/runtime/dict.cpp
View file @
077fffc6
...
...
@@ -174,12 +174,7 @@ Box* dictGetitem(BoxedDict* self, Box* k) {
auto
it
=
self
->
d
.
find
(
k
);
if
(
it
==
self
->
d
.
end
())
{
BoxedString
*
s
=
reprOrNull
(
k
);
if
(
s
)
raiseExcHelper
(
KeyError
,
"%s"
,
s
->
s
.
c_str
());
else
raiseExcHelper
(
KeyError
,
""
);
raiseExcHelper
(
KeyError
,
k
);
}
Box
*
pos
=
self
->
d
[
k
];
...
...
@@ -306,12 +301,7 @@ Box* dictDelitem(BoxedDict* self, Box* k) {
auto
it
=
self
->
d
.
find
(
k
);
if
(
it
==
self
->
d
.
end
())
{
BoxedString
*
s
=
reprOrNull
(
k
);
if
(
s
)
raiseExcHelper
(
KeyError
,
"%s"
,
s
->
s
.
c_str
());
else
raiseExcHelper
(
KeyError
,
""
);
raiseExcHelper
(
KeyError
,
k
);
}
self
->
d
.
erase
(
it
);
...
...
@@ -329,6 +319,18 @@ extern "C" int PyDict_DelItem(PyObject* op, PyObject* key) noexcept {
return
0
;
}
extern
"C"
int
PyDict_DelItemString
(
PyObject
*
v
,
const
char
*
key
)
noexcept
{
PyObject
*
kv
;
int
err
;
kv
=
PyString_FromString
(
key
);
if
(
kv
==
NULL
)
return
-
1
;
err
=
PyDict_DelItem
(
v
,
kv
);
Py_DECREF
(
kv
);
return
err
;
}
Box
*
dictPop
(
BoxedDict
*
self
,
Box
*
k
,
Box
*
d
)
{
if
(
!
isSubclass
(
self
->
cls
,
dict_cls
))
raiseExcHelper
(
TypeError
,
"descriptor 'pop' requires a 'dict' object but received a '%s'"
,
getTypeName
(
self
));
...
...
@@ -338,12 +340,7 @@ Box* dictPop(BoxedDict* self, Box* k, Box* d) {
if
(
d
)
return
d
;
BoxedString
*
s
=
reprOrNull
(
k
);
if
(
s
)
raiseExcHelper
(
KeyError
,
"%s"
,
s
->
s
.
c_str
());
else
raiseExcHelper
(
KeyError
,
""
);
raiseExcHelper
(
KeyError
,
k
);
}
Box
*
rtn
=
it
->
second
;
...
...
src/runtime/import.cpp
View file @
077fffc6
...
...
@@ -261,6 +261,13 @@ static void ensure_fromlist(Box* module, Box* fromlist, const std::string& modul
}
}
extern
"C"
PyObject
*
PyImport_ImportModule
(
const
char
*
name
)
noexcept
{
if
(
strcmp
(
"__builtin__"
,
name
)
==
0
)
return
builtins_module
;
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Box
*
import
(
int
level
,
Box
*
from_imports
,
const
std
::
string
*
module_name
)
{
RELEASE_ASSERT
(
level
==
-
1
||
level
==
0
,
"not implemented"
);
...
...
src/runtime/int.cpp
View file @
077fffc6
...
...
@@ -45,7 +45,8 @@ extern "C" long PyInt_AsLong(PyObject* op) noexcept {
if
(
op
->
cls
==
long_cls
)
return
PyLong_AsLong
(
op
);
Py_FatalError
(
"unimplemented"
);
PyErr_SetString
(
PyExc_TypeError
,
"an integer is required"
);
return
-
1
;
}
extern
"C"
Py_ssize_t
PyInt_AsSsize_t
(
PyObject
*
op
)
noexcept
{
...
...
src/runtime/objmodel.cpp
View file @
077fffc6
...
...
@@ -208,7 +208,7 @@ extern "C" void assertFail(BoxedModule* inModule, Box* msg) {
BoxedString
*
tostr
=
str
(
msg
);
raiseExcHelper
(
AssertionError
,
"%s"
,
tostr
->
s
.
c_str
());
}
else
{
raiseExcHelper
(
AssertionError
,
NULL
);
raiseExcHelper
(
AssertionError
,
""
);
}
}
...
...
src/runtime/objmodel.h
View file @
077fffc6
...
...
@@ -41,6 +41,7 @@ extern "C" Box* deopt(AST_expr* expr, Box* value);
// helper function for raising from the runtime:
void
raiseExcHelper
(
BoxedClass
*
,
const
char
*
fmt
,
...)
__attribute__
((
__noreturn__
));
void
raiseExcHelper
(
BoxedClass
*
,
Box
*
arg
)
__attribute__
((
__noreturn__
));
BoxedModule
*
getCurrentModule
();
...
...
src/runtime/set.cpp
View file @
077fffc6
...
...
@@ -200,12 +200,7 @@ Box* setRemove(BoxedSet* self, Box* v) {
auto
it
=
self
->
s
.
find
(
v
);
if
(
it
==
self
->
s
.
end
())
{
BoxedString
*
s
=
reprOrNull
(
v
);
if
(
s
)
raiseExcHelper
(
KeyError
,
"%s"
,
s
->
s
.
c_str
());
else
raiseExcHelper
(
KeyError
,
""
);
raiseExcHelper
(
KeyError
,
v
);
}
self
->
s
.
erase
(
it
);
...
...
src/runtime/stacktrace.cpp
View file @
077fffc6
...
...
@@ -196,9 +196,7 @@ ExcInfo::ExcInfo(Box* type, Box* value, Box* traceback) : type(type), value(valu
#endif
void
ExcInfo
::
printExcAndTraceback
()
const
{
std
::
string
msg
=
formatException
(
value
);
printTraceback
(
traceback
);
fprintf
(
stderr
,
"%s
\n
"
,
msg
.
c_str
());
PyErr_Display
(
type
,
value
,
traceback
);
}
bool
ExcInfo
::
matches
(
BoxedClass
*
cls
)
const
{
...
...
@@ -242,6 +240,11 @@ void raise3(Box* arg0, Box* arg1, Box* arg2) {
getTypeName
(
arg0
));
}
void
raiseExcHelper
(
BoxedClass
*
cls
,
Box
*
arg
)
{
Box
*
exc_obj
=
runtimeCall
(
cls
,
ArgPassSpec
(
1
),
arg
,
NULL
,
NULL
,
NULL
,
NULL
);
raiseExc
(
exc_obj
);
}
void
raiseExcHelper
(
BoxedClass
*
cls
,
const
char
*
msg
,
...)
{
if
(
msg
!=
NULL
)
{
va_list
ap
;
...
...
@@ -265,18 +268,4 @@ void raiseExcHelper(BoxedClass* cls, const char* msg, ...) {
raiseExc
(
exc_obj
);
}
}
std
::
string
formatException
(
Box
*
b
)
{
std
::
string
name
=
getTypeName
(
b
);
BoxedString
*
r
=
strOrNull
(
b
);
if
(
!
r
)
return
name
;
assert
(
r
->
cls
==
str_cls
);
const
std
::
string
*
msg
=
&
r
->
s
;
if
(
msg
->
size
())
return
name
+
": "
+
*
msg
;
return
name
;
}
}
src/runtime/types.cpp
View file @
077fffc6
...
...
@@ -559,7 +559,7 @@ extern "C" Box* createUserClass(const std::string* name, Box* _bases, Box* _attr
RELEASE_ASSERT
(
e
.
matches
(
BaseException
),
""
);
Box
*
msg
=
e
.
value
->
getattr
(
"message"
);
Box
*
msg
=
getattr
(
e
.
value
,
"message"
);
RELEASE_ASSERT
(
msg
,
""
);
RELEASE_ASSERT
(
msg
->
cls
==
str_cls
,
""
);
...
...
@@ -834,6 +834,40 @@ Box* typeRepr(BoxedClass* self) {
return
boxString
(
os
.
str
());
}
static
PyObject
*
typeModule
(
Box
*
_type
,
void
*
context
)
{
PyTypeObject
*
type
=
static_cast
<
PyTypeObject
*>
(
_type
);
PyObject
*
mod
;
const
char
*
s
;
if
(
type
->
tp_flags
&
Py_TPFLAGS_HEAPTYPE
)
{
mod
=
type
->
getattr
(
"__module__"
);
if
(
!
mod
)
raiseExcHelper
(
AttributeError
,
"__module__"
);
return
mod
;
}
else
{
s
=
strrchr
(
type
->
tp_name
,
'.'
);
if
(
s
!=
NULL
)
return
PyString_FromStringAndSize
(
type
->
tp_name
,
(
Py_ssize_t
)(
s
-
type
->
tp_name
));
return
PyString_FromString
(
"__builtin__"
);
}
}
static
void
typeSetModule
(
Box
*
_type
,
PyObject
*
value
,
void
*
context
)
{
PyTypeObject
*
type
=
static_cast
<
PyTypeObject
*>
(
_type
);
if
(
!
(
type
->
tp_flags
&
Py_TPFLAGS_HEAPTYPE
))
{
raiseExcHelper
(
TypeError
,
"can't set %s.__module__"
,
type
->
tp_name
);
}
if
(
!
value
)
{
raiseExcHelper
(
TypeError
,
"can't delete %s.__module__"
,
type
->
tp_name
);
}
PyType_Modified
(
type
);
type
->
setattr
(
"__module__"
,
value
,
NULL
);
}
Box
*
typeHash
(
BoxedClass
*
self
)
{
assert
(
isSubclass
(
self
->
cls
,
type_cls
));
...
...
@@ -1272,6 +1306,7 @@ void setupRuntime() {
new
BoxedFunction
(
boxRTFunction
((
void
*
)
typeNew
,
UNKNOWN
,
4
,
2
,
false
,
false
),
{
NULL
,
NULL
}));
type_cls
->
giveAttr
(
"__repr__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
typeRepr
,
STR
,
1
)));
type_cls
->
giveAttr
(
"__hash__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
typeHash
,
BOXED_INT
,
1
)));
type_cls
->
giveAttr
(
"__module__"
,
new
(
pyston_getset_cls
)
BoxedGetsetDescriptor
(
typeModule
,
typeSetModule
,
NULL
));
type_cls
->
freeze
();
none_cls
->
giveAttr
(
"__repr__"
,
new
BoxedFunction
(
boxRTFunction
((
void
*
)
noneRepr
,
STR
,
1
)));
...
...
@@ -1365,6 +1400,7 @@ void setupRuntime() {
setupSys
();
setupBuiltins
();
_PyExc_Init
();
setupThread
();
setupGC
();
setupImport
();
...
...
src/runtime/types.h
View file @
077fffc6
...
...
@@ -613,12 +613,29 @@ extern "C" void boxGCHandler(GCVisitor* v, Box* b);
Box
*
objectNewNoArgs
(
BoxedClass
*
cls
);
extern
"C"
BoxedClass
*
Exception
,
*
AssertionError
,
*
AttributeError
,
*
TypeError
,
*
NameError
,
*
KeyError
,
*
IndexError
,
*
IOError
,
*
OSError
,
*
ZeroDivisionError
,
*
ValueError
,
*
UnboundLocalError
,
*
RuntimeError
,
*
ImportError
,
*
StopIteration
,
*
GeneratorExit
,
*
SyntaxError
;
Box
*
makeAttrWrapper
(
Box
*
b
);
#define SystemError ((BoxedClass*)PyExc_SystemError)
#define StopIteration ((BoxedClass*)PyExc_StopIteration)
#define NameError ((BoxedClass*)PyExc_NameError)
#define UnboundLocalError ((BoxedClass*)PyExc_UnboundLocalError)
#define BaseException ((BoxedClass*)PyExc_BaseException)
#define TypeError ((BoxedClass*)PyExc_TypeError)
#define AssertionError ((BoxedClass*)PyExc_AssertionError)
#define ValueError ((BoxedClass*)PyExc_ValueError)
#define SystemExit ((BoxedClass*)PyExc_SystemExit)
#define SyntaxError ((BoxedClass*)PyExc_SyntaxError)
#define Exception ((BoxedClass*)PyExc_Exception)
#define AttributeError ((BoxedClass*)PyExc_AttributeError)
#define RuntimeError ((BoxedClass*)PyExc_RuntimeError)
#define ZeroDivisionError ((BoxedClass*)PyExc_ZeroDivisionError)
#define ImportError ((BoxedClass*)PyExc_ImportError)
#define IndexError ((BoxedClass*)PyExc_IndexError)
#define GeneratorExit ((BoxedClass*)PyExc_GeneratorExit)
#define IOError ((BoxedClass*)PyExc_IOError)
#define KeyError ((BoxedClass*)PyExc_KeyError)
#define OverflowError ((BoxedClass*)PyExc_OverflowError)
// Our default for tp_alloc:
PyObject
*
PystonType_GenericAlloc
(
BoxedClass
*
cls
,
Py_ssize_t
nitems
)
noexcept
;
}
...
...
src/runtime/unicode.cpp
View file @
077fffc6
...
...
@@ -373,34 +373,6 @@ extern "C" Py_UNICODE _PyUnicode_ToUppercase(Py_UNICODE ch) noexcept {
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyUnicodeEncodeError_GetStart
(
PyObject
*
,
Py_ssize_t
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyUnicodeDecodeError_GetStart
(
PyObject
*
,
Py_ssize_t
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyUnicodeTranslateError_GetStart
(
PyObject
*
,
Py_ssize_t
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyUnicodeEncodeError_GetEnd
(
PyObject
*
,
Py_ssize_t
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyUnicodeDecodeError_GetEnd
(
PyObject
*
,
Py_ssize_t
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyUnicodeTranslateError_GetEnd
(
PyObject
*
,
Py_ssize_t
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicodeEncodeError_GetObject
(
PyObject
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
_PyUnicode_DecodeUnicodeInternal
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
...
...
test/tests/exceptions_nonreprable.py
View file @
077fffc6
# expected: fail
# - exception printing
class
BadException
(
Exception
):
def
__str__
(
self
):
print
"str"
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment