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
398ee469
Commit
398ee469
authored
Feb 25, 2015
by
Kevin Modzelewski
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use CPython (2.7's) unicode implementation
parent
f4b1b16a
Changes
22
Hide whitespace changes
Inline
Side-by-side
Showing
22 changed files
with
115 additions
and
476 deletions
+115
-476
Makefile
Makefile
+2
-2
from_cpython/CMakeLists.txt
from_cpython/CMakeLists.txt
+2
-2
from_cpython/Include/abstract.h
from_cpython/Include/abstract.h
+2
-2
from_cpython/Include/listobject.h
from_cpython/Include/listobject.h
+3
-0
from_cpython/Include/stringobject.h
from_cpython/Include/stringobject.h
+3
-0
from_cpython/Include/tupleobject.h
from_cpython/Include/tupleobject.h
+3
-0
from_cpython/Include/unicodeobject.h
from_cpython/Include/unicodeobject.h
+1
-16
from_cpython/Objects/bytearrayobject.c
from_cpython/Objects/bytearrayobject.c
+6
-3
from_cpython/Objects/stringlib/string_format.h
from_cpython/Objects/stringlib/string_format.h
+1
-2
from_cpython/Objects/stringobject.c
from_cpython/Objects/stringobject.c
+9
-0
from_cpython/Objects/unicodeobject.c
from_cpython/Objects/unicodeobject.c
+18
-7
src/capi/abstract.cpp
src/capi/abstract.cpp
+8
-0
src/capi/object.cpp
src/capi/object.cpp
+4
-0
src/runtime/builtin_modules/builtins.cpp
src/runtime/builtin_modules/builtins.cpp
+2
-0
src/runtime/builtin_modules/sys.cpp
src/runtime/builtin_modules/sys.cpp
+5
-0
src/runtime/capi.cpp
src/runtime/capi.cpp
+16
-21
src/runtime/list.cpp
src/runtime/list.cpp
+10
-0
src/runtime/str.cpp
src/runtime/str.cpp
+7
-2
src/runtime/tuple.cpp
src/runtime/tuple.cpp
+6
-0
src/runtime/types.cpp
src/runtime/types.cpp
+3
-4
src/runtime/types.h
src/runtime/types.h
+4
-3
src/runtime/unicode.cpp
src/runtime/unicode.cpp
+0
-412
No files found.
Makefile
View file @
398ee469
...
...
@@ -292,8 +292,8 @@ 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 exceptions.c
$(EXTRA_STDOBJECT_SRCS)
STDPYTHON_SRCS
:=
pyctype.c getargs.c formatter_string.c pystrtod.c dtoa.c
$(EXTRA_STDPYTHON_SRCS)
STDOBJECT_SRCS
:=
structseq.c capsule.c stringobject.c exceptions.c
unicodeobject.c unicodectype.c bytearrayobject.c bytes_methods.c
$(EXTRA_STDOBJECT_SRCS)
STDPYTHON_SRCS
:=
pyctype.c getargs.c formatter_string.c pystrtod.c dtoa.c
formatter_unicode.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)
)
# The stdlib objects have slightly longer dependency chains,
...
...
from_cpython/CMakeLists.txt
View file @
398ee469
...
...
@@ -18,10 +18,10 @@ 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 exceptions.c
)
file
(
GLOB_RECURSE STDOBJECT_SRCS Objects structseq.c capsule.c stringobject.c exceptions.c
unicodeobject.c unicodectype.c bytearrayobject.c bytes_methods.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
)
file
(
GLOB_RECURSE STDPYTHON_SRCS Python getargs.c pyctype.c formatter_string.c pystrtod.c dtoa.c
formatter_unicode.c
)
set
(
CMAKE_C_FLAGS
"
${
CMAKE_C_FLAGS
}
-Wno-missing-field-initializers -Wno-tautological-compare -Wno-type-limits"
)
add_library
(
FROM_CPYTHON OBJECT
${
STDMODULE_SRCS
}
${
STDOBJECT_SRCS
}
${
STDPYTHON_SRCS
}
)
from_cpython/Include/abstract.h
View file @
398ee469
...
...
@@ -1184,8 +1184,8 @@ xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx*/
*/
#define PySequence_Fast_ITEMS(sf) \
(PyList_Check(sf) ? (
(PyListObject *)(sf))->ob_item
\
: (
(PyTupleObject *)(sf))->ob_item
)
(PyList_Check(sf) ? (
PyList_Items(sf))
\
: (
PyTuple_Items(sf))
)
/* Return a pointer to the underlying item array for
an object retured by PySequence_Fast */
...
...
from_cpython/Include/listobject.h
View file @
398ee469
...
...
@@ -70,6 +70,9 @@ PyAPI_FUNC(int) PyList_Reverse(PyObject *) PYSTON_NOEXCEPT;
PyAPI_FUNC
(
PyObject
*
)
PyList_AsTuple
(
PyObject
*
)
PYSTON_NOEXCEPT
;
PyAPI_FUNC
(
PyObject
*
)
_PyList_Extend
(
PyListObject
*
,
PyObject
*
)
PYSTON_NOEXCEPT
;
// Pyston addition:
PyAPI_FUNC
(
PyObject
**
)
PyList_Items
(
PyObject
*
)
PYSTON_NOEXCEPT
;
/* Macro, trading safety for speed */
// Pyston changes: these aren't direct macros any more [they potentially could be though]
#define PyList_GET_ITEM(op, i) PyList_GetItem((PyObject*)(op), (i))
...
...
from_cpython/Include/stringobject.h
View file @
398ee469
...
...
@@ -99,6 +99,9 @@ PyAPI_FUNC(void) PyString_InternImmortal(PyObject **) PYSTON_NOEXCEPT;
PyAPI_FUNC
(
PyObject
*
)
PyString_InternFromString
(
const
char
*
)
PYSTON_NOEXCEPT
;
PyAPI_FUNC
(
void
)
_Py_ReleaseInternedStrings
(
void
)
PYSTON_NOEXCEPT
;
// Pyston addition:
PyAPI_FUNC
(
char
)
PyString_GetItem
(
PyObject
*
,
Py_ssize_t
)
PYSTON_NOEXCEPT
;
/* Use only if you know it's a string */
#define PyString_CHECK_INTERNED(op) (((PyStringObject *)(op))->ob_sstate)
...
...
from_cpython/Include/tupleobject.h
View file @
398ee469
...
...
@@ -59,6 +59,9 @@ PyAPI_FUNC(int) _PyTuple_Resize(PyObject **, Py_ssize_t) PYSTON_NOEXCEPT;
PyAPI_FUNC
(
PyObject
*
)
PyTuple_Pack
(
Py_ssize_t
,
...)
PYSTON_NOEXCEPT
;
PyAPI_FUNC
(
void
)
_PyTuple_MaybeUntrack
(
PyObject
*
)
PYSTON_NOEXCEPT
;
// Pyston addition:
PyAPI_FUNC
(
PyObject
**
)
PyTuple_Items
(
PyObject
*
)
PYSTON_NOEXCEPT
;
/* Macro, trading safety for speed */
// Pyston changes: these aren't direct macros any more [they potentially could be though]
#define PyTuple_GET_ITEM(op, i) PyTuple_GetItem(op, i)
...
...
from_cpython/Include/unicodeobject.h
View file @
398ee469
...
...
@@ -414,8 +414,6 @@ extern "C" {
/* --- Unicode Type ------------------------------------------------------- */
// Pyston change: this is not our object format
#if 0
typedef
struct
{
PyObject_HEAD
Py_ssize_t
length
;
/* Length of raw Unicode data in buffer */
...
...
@@ -425,14 +423,8 @@ typedef struct {
string, or NULL; this is used for
implementing the buffer protocol */
}
PyUnicodeObject
;
#endif
struct
_PyUnicodeObject
;
typedef
struct
_PyUnicodeObject
PyUnicodeObject
;
// Pyston change: this is no longer a static object
PyAPI_DATA
(
PyTypeObject
*
)
unicode_cls
;
#define PyUnicode_Type (*unicode_cls)
//PyAPI_DATA(PyTypeObject) PyUnicode_Type;
PyAPI_DATA
(
PyTypeObject
)
PyUnicode_Type
;
// Pyston changes: these aren't direct macros any more [they potentially could be though]
PyAPI_FUNC
(
bool
)
_PyUnicode_Check
(
PyObject
*
)
PYSTON_NOEXCEPT
;
...
...
@@ -443,8 +435,6 @@ PyAPI_FUNC(bool) _PyUnicode_Check(PyObject*) PYSTON_NOEXCEPT;
#endif
#define PyUnicode_CheckExact(op) (Py_TYPE(op) == &PyUnicode_Type)
// Pyston changes: these aren't direct macros any more [they potentially could be though]
#if 0
/* Fast access macros */
#define PyUnicode_GET_SIZE(op) \
(((PyUnicodeObject *)(op))->length)
...
...
@@ -454,11 +444,6 @@ PyAPI_FUNC(bool) _PyUnicode_Check(PyObject*) PYSTON_NOEXCEPT;
(((PyUnicodeObject *)(op))->str)
#define PyUnicode_AS_DATA(op) \
((const char *)((PyUnicodeObject *)(op))->str)
#endif
PyAPI_FUNC
(
Py_ssize_t
)
PyUnicode_GET_SIZE
(
PyObject
*
)
PYSTON_NOEXCEPT
;
PyAPI_FUNC
(
Py_ssize_t
)
PyUnicode_GET_DATA_SIZE
(
PyObject
*
)
PYSTON_NOEXCEPT
;
PyAPI_FUNC
(
Py_UNICODE
*
)
PyUnicode_AS_UNICODE
(
PyObject
*
)
PYSTON_NOEXCEPT
;
PyAPI_FUNC
(
const
char
*
)
PyUnicode_AS_DATA
(
PyObject
*
)
PYSTON_NOEXCEPT
;
/* --- Constants ---------------------------------------------------------- */
...
...
from_cpython/Objects/bytearrayobject.c
View file @
398ee469
...
...
@@ -34,7 +34,8 @@ _getbytevalue(PyObject* arg, int *value)
PyErr_SetString
(
PyExc_ValueError
,
"string must be of size 1"
);
return
0
;
}
*
value
=
Py_CHARMASK
(((
PyBytesObject
*
)
arg
)
->
ob_sval
[
0
]);
// Pyston change, was: *value = Py_CHARMASK(((PyBytesObject*)arg)->ob_sval[0]);
*
value
=
Py_CHARMASK
(
PyString_GetItem
(
arg
,
0
));
return
1
;
}
else
if
(
PyInt_Check
(
arg
)
||
PyLong_Check
(
arg
))
{
...
...
@@ -2893,7 +2894,8 @@ Construct a zero-initialized bytearray of the given length.");
static
PyObject
*
bytearray_iter
(
PyObject
*
seq
);
PyTypeObject
PyByteArray_Type
=
{
PyVarObject_HEAD_INIT
(
&
PyType_Type
,
0
)
// Pyston change, was &PyType_Type:
PyVarObject_HEAD_INIT
(
NULL
,
0
)
"bytearray"
,
sizeof
(
PyByteArrayObject
),
0
,
...
...
@@ -3002,7 +3004,8 @@ static PyMethodDef bytearrayiter_methods[] = {
};
PyTypeObject
PyByteArrayIter_Type
=
{
PyVarObject_HEAD_INIT
(
&
PyType_Type
,
0
)
// Pyston change, was &PyType_Type:
PyVarObject_HEAD_INIT
(
NULL
,
0
)
"bytearray_iterator"
,
/* tp_name */
sizeof
(
bytesiterobject
),
/* tp_basicsize */
0
,
/* tp_itemsize */
...
...
from_cpython/Objects/stringlib/string_format.h
View file @
398ee469
...
...
@@ -1025,8 +1025,7 @@ done:
/************************************************************************/
/* this is the main entry point */
// Pyston change: changed to non-static
/* static */
PyObject
*
static
PyObject
*
do_string_format
(
PyObject
*
self
,
PyObject
*
args
,
PyObject
*
kwargs
)
{
SubString
input
;
...
...
from_cpython/Objects/stringobject.c
View file @
398ee469
...
...
@@ -7,3 +7,12 @@
#define _Py_InsertThousandsGrouping _PyString_InsertThousandsGrouping
#include "stringlib/localeutil.h"
// do_string_format needs to be declared as a static function, since it's used by both stringobject.c
// and unicodeobject.c. We want to access it from str.cpp, though, so just use this little forwarding
// function.
// We could also potentially have tried to modifie string_format.h to choose whether to mark the function
// as static or not.
PyObject
*
_do_string_format
(
PyObject
*
self
,
PyObject
*
args
,
PyObject
*
kwargs
)
{
return
do_string_format
(
self
,
args
,
kwargs
);
}
from_cpython/Objects/unicodeobject.c
View file @
398ee469
...
...
@@ -423,7 +423,7 @@ int _PyUnicode_Resize(PyUnicodeObject **unicode, Py_ssize_t length)
return
-
1
;
}
v
=
*
unicode
;
if
(
v
==
NULL
||
!
PyUnicode_Check
(
v
)
||
Py_REFCNT
(
v
)
!=
1
||
length
<
0
)
{
if
(
v
==
NULL
||
!
PyUnicode_Check
(
v
)
||
/* Pyston change, can't check this: Py_REFCNT(v) != 1 || */
length
<
0
)
{
PyErr_BadInternalCall
();
return
-
1
;
}
...
...
@@ -8140,7 +8140,7 @@ formatfloat(PyObject *v, int flags, int prec, int type)
static
PyObject
*
formatlong
(
PyObject
*
val
,
int
flags
,
int
prec
,
int
type
)
{
char
*
buf
;
c
onst
c
har
*
buf
;
int
i
,
len
;
PyObject
*
str
;
/* temporary string object. */
PyUnicodeObject
*
result
;
...
...
@@ -8833,6 +8833,9 @@ unicode_subtype_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
return
(
PyObject
*
)
pnew
;
}
// Pyston change: Leave this in as a reminder in case we want to go back to using it:
#define Py_TPFLAGS_UNICODE_SUBCLASS (0)
PyDoc_STRVAR
(
unicode_doc
,
"unicode(object='') -> unicode object
\n
\
unicode(string[, encoding[, errors]]) -> unicode object
\n
\
...
...
@@ -8842,7 +8845,8 @@ encoding defaults to the current default string encoding.\n\
errors can be 'strict', 'replace' or 'ignore' and defaults to 'strict'."
);
PyTypeObject
PyUnicode_Type
=
{
PyVarObject_HEAD_INIT
(
&
PyType_Type
,
0
)
// Pyston change, was &Py_Type_Type:
PyVarObject_HEAD_INIT
(
NULL
,
0
)
"unicode"
,
/* tp_name */
sizeof
(
PyUnicodeObject
),
/* tp_size */
0
,
/* tp_itemsize */
...
...
@@ -8874,7 +8878,8 @@ PyTypeObject PyUnicode_Type = {
unicode_methods
,
/* tp_methods */
0
,
/* tp_members */
0
,
/* tp_getset */
&
PyBaseString_Type
,
/* tp_base */
// Pyston change, this was &PyBaseString_Type; we set this explicitly in _PyUnicode_Init:
0
,
/* tp_base */
0
,
/* tp_dict */
0
,
/* tp_descr_get */
0
,
/* tp_descr_set */
...
...
@@ -8901,6 +8906,15 @@ void _PyUnicode_Init(void)
0x2029
,
/* PARAGRAPH SEPARATOR */
};
// Pyston change: we didn't set this above
assert
(
&
PyBaseString_Type
!=
NULL
);
PyUnicode_Type
.
tp_base
=
&
PyBaseString_Type
;
// Pyston change: moved this above the initial call to _PyUnicode_New
// in order to register the static object with the GC:
if
(
PyType_Ready
(
&
PyUnicode_Type
)
<
0
)
Py_FatalError
(
"Can't initialize 'unicode'"
);
/* Init the implementation */
if
(
!
unicode_empty
)
{
unicode_empty
=
_PyUnicode_New
(
0
);
...
...
@@ -8908,9 +8922,6 @@ void _PyUnicode_Init(void)
return
;
}
if
(
PyType_Ready
(
&
PyUnicode_Type
)
<
0
)
Py_FatalError
(
"Can't initialize 'unicode'"
);
/* initialize the linebreak bloom filter */
bloom_linebreak
=
make_bloom_mask
(
linebreak
,
sizeof
(
linebreak
)
/
sizeof
(
linebreak
[
0
])
...
...
src/capi/abstract.cpp
View file @
398ee469
...
...
@@ -27,6 +27,14 @@
namespace
pyston
{
extern
"C"
Py_ssize_t
_PyObject_LengthHint
(
PyObject
*
o
,
Py_ssize_t
defaultvalue
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyBuffer_ToContiguous
(
void
*
buf
,
Py_buffer
*
view
,
Py_ssize_t
len
,
char
fort
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
static
PyObject
*
type_error
(
const
char
*
msg
,
PyObject
*
obj
)
noexcept
{
PyErr_Format
(
PyExc_TypeError
,
msg
,
Py_TYPE
(
obj
)
->
tp_name
);
return
NULL
;
...
...
src/capi/object.cpp
View file @
398ee469
...
...
@@ -26,6 +26,10 @@
namespace
pyston
{
extern
"C"
{
_Py_HashSecret_t
_Py_HashSecret
;
}
extern
"C"
PyObject
*
PyObject_Unicode
(
PyObject
*
v
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
...
...
src/runtime/builtin_modules/builtins.cpp
View file @
398ee469
...
...
@@ -1015,6 +1015,8 @@ void setupBuiltins() {
boxRTFunction
((
void
*
)
vars
,
UNKNOWN
,
1
,
1
,
false
,
false
),
"vars"
,
{
NULL
}));
builtins_module
->
giveAttr
(
"object"
,
object_cls
);
builtins_module
->
giveAttr
(
"str"
,
str_cls
);
assert
(
unicode_cls
);
builtins_module
->
giveAttr
(
"unicode"
,
unicode_cls
);
builtins_module
->
giveAttr
(
"basestring"
,
basestring_cls
);
// builtins_module->giveAttr("unicode", unicode_cls);
builtins_module
->
giveAttr
(
"int"
,
int_cls
);
...
...
src/runtime/builtin_modules/sys.cpp
View file @
398ee469
...
...
@@ -33,6 +33,11 @@ namespace pyston {
BoxedModule
*
sys_module
;
BoxedDict
*
sys_modules_dict
;
extern
"C"
{
// supposed to be exposed through sys.flags
int
Py_BytesWarningFlag
=
0
;
}
Box
*
sysExcInfo
()
{
ExcInfo
*
exc
=
getFrameExcInfo
();
assert
(
exc
->
type
);
...
...
src/runtime/capi.cpp
View file @
398ee469
...
...
@@ -154,11 +154,6 @@ extern "C" PyVarObject* PyObject_InitVar(PyVarObject* op, PyTypeObject* tp, Py_s
return
op
;
}
extern
"C"
void
PyObject_Free
(
void
*
p
)
noexcept
{
gc
::
gc_free
(
p
);
ASSERT
(
0
,
"I think this is good enough but I'm not sure; should test"
);
}
extern
"C"
PyObject
*
PyObject_Format
(
PyObject
*
obj
,
PyObject
*
format_spec
)
noexcept
{
PyObject
*
empty
=
NULL
;
PyObject
*
result
=
NULL
;
...
...
@@ -883,6 +878,18 @@ extern "C" PyObject* PyCallIter_New(PyObject* callable, PyObject* sentinel) noex
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
void
*
PyObject_Malloc
(
size_t
sz
)
noexcept
{
return
gc_compat_malloc
(
sz
);
}
extern
"C"
void
*
PyObject_Realloc
(
void
*
ptr
,
size_t
sz
)
noexcept
{
return
gc_compat_realloc
(
ptr
,
sz
);
}
extern
"C"
void
PyObject_Free
(
void
*
ptr
)
noexcept
{
gc_compat_free
(
ptr
);
}
extern
"C"
void
*
PyMem_Malloc
(
size_t
sz
)
noexcept
{
return
gc_compat_malloc
(
sz
);
}
...
...
@@ -1165,22 +1172,6 @@ extern "C" Py_ssize_t PyNumber_AsSsize_t(PyObject* o, PyObject* exc) noexcept {
return
n
;
}
extern
"C"
Py_ssize_t
PyUnicode_GET_SIZE
(
PyObject
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_ssize_t
PyUnicode_GET_DATA_SIZE
(
PyObject
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_UNICODE
*
PyUnicode_AS_UNICODE
(
PyObject
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
const
char
*
PyUnicode_AS_DATA
(
PyObject
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyBuffer_IsContiguous
(
Py_buffer
*
view
,
char
fort
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
...
...
@@ -1484,6 +1475,10 @@ extern "C" int _PyEval_SliceIndex(PyObject* v, Py_ssize_t* pi) noexcept {
return
1
;
}
extern
"C"
PyObject
*
PyBuffer_FromMemory
(
void
*
ptr
,
Py_ssize_t
size
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
BoxedModule
*
importTestExtension
(
const
std
::
string
&
name
)
{
std
::
string
pathname_name
=
"test/test_extension/"
+
name
+
".pyston.so"
;
const
char
*
pathname
=
pathname_name
.
c_str
();
...
...
src/runtime/list.cpp
View file @
398ee469
...
...
@@ -39,6 +39,16 @@ extern "C" int PyList_Append(PyObject* op, PyObject* newitem) noexcept {
return
0
;
}
extern
"C"
int
PyList_Reverse
(
PyObject
*
v
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
**
PyList_Items
(
PyObject
*
op
)
noexcept
{
RELEASE_ASSERT
(
PyList_Check
(
op
),
""
);
return
&
static_cast
<
BoxedList
*>
(
op
)
->
elts
->
elts
[
0
];
}
extern
"C"
Box
*
listRepr
(
BoxedList
*
self
)
{
LOCK_REGION
(
self
->
lock
.
asRead
());
...
...
src/runtime/str.cpp
View file @
398ee469
...
...
@@ -47,6 +47,11 @@ BoxedString::BoxedString(const std::string& s) : s(s) {
gc
::
registerGCManagedBytes
(
this
->
s
.
size
());
}
extern
"C"
char
PyString_GetItem
(
PyObject
*
op
,
ssize_t
n
)
noexcept
{
RELEASE_ASSERT
(
PyString_Check
(
op
),
""
);
return
static_cast
<
const
BoxedString
*>
(
op
)
->
s
[
n
];
}
extern
"C"
PyObject
*
PyString_FromFormatV
(
const
char
*
format
,
va_list
vargs
)
noexcept
{
va_list
count
;
Py_ssize_t
n
=
0
;
...
...
@@ -1552,13 +1557,13 @@ Box* strPartition(BoxedString* self, BoxedString* sep) {
self
->
s
.
size
()
-
found_idx
-
sep
->
s
.
size
())
});
}
extern
"C"
PyObject
*
do_string_format
(
PyObject
*
self
,
PyObject
*
args
,
PyObject
*
kwargs
);
extern
"C"
PyObject
*
_
do_string_format
(
PyObject
*
self
,
PyObject
*
args
,
PyObject
*
kwargs
);
Box
*
strFormat
(
BoxedString
*
self
,
BoxedTuple
*
args
,
BoxedDict
*
kwargs
)
{
assert
(
args
->
cls
==
tuple_cls
);
assert
(
kwargs
->
cls
==
dict_cls
);
Box
*
rtn
=
do_string_format
(
self
,
args
,
kwargs
);
Box
*
rtn
=
_
do_string_format
(
self
,
args
,
kwargs
);
checkAndThrowCAPIException
();
assert
(
rtn
);
return
rtn
;
...
...
src/runtime/tuple.cpp
View file @
398ee469
...
...
@@ -68,6 +68,12 @@ Box* tupleGetitemInt(BoxedTuple* self, BoxedInt* slice) {
return
tupleGetitemUnboxed
(
self
,
slice
->
n
);
}
extern
"C"
PyObject
**
PyTuple_Items
(
PyObject
*
op
)
noexcept
{
RELEASE_ASSERT
(
PyTuple_Check
(
op
),
""
);
return
&
static_cast
<
BoxedTuple
*>
(
op
)
->
elts
[
0
];
}
extern
"C"
PyObject
*
PyTuple_GetItem
(
PyObject
*
op
,
Py_ssize_t
i
)
noexcept
{
RELEASE_ASSERT
(
PyTuple_Check
(
op
),
""
);
RELEASE_ASSERT
(
i
>=
0
,
""
);
// unlike tuple.__getitem__, PyTuple_GetItem doesn't do index wrapping
...
...
src/runtime/types.cpp
View file @
398ee469
...
...
@@ -64,6 +64,7 @@ extern "C" void initarray();
extern
"C"
void
initzlib
();
extern
"C"
void
init_codecs
();
extern
"C"
void
init_socket
();
extern
"C"
void
_PyUnicode_Init
();
namespace
pyston
{
...
...
@@ -518,7 +519,7 @@ extern "C" void closureGCHandler(GCVisitor* v, Box* b) {
extern
"C"
{
BoxedClass
*
object_cls
,
*
type_cls
,
*
none_cls
,
*
bool_cls
,
*
int_cls
,
*
float_cls
,
*
str_cls
=
NULL
,
*
function_cls
,
*
instancemethod_cls
,
*
list_cls
,
*
slice_cls
,
*
module_cls
,
*
dict_cls
,
*
tuple_cls
,
*
file_cls
,
*
member_cls
,
*
closure_cls
,
*
generator_cls
,
*
complex_cls
,
*
basestring_cls
,
*
unicode_cls
,
*
property_cls
,
*
file_cls
,
*
member_cls
,
*
closure_cls
,
*
generator_cls
,
*
complex_cls
,
*
basestring_cls
,
*
property_cls
,
*
staticmethod_cls
,
*
classmethod_cls
,
*
attrwrapper_cls
,
*
pyston_getset_cls
,
*
capi_getset_cls
,
*
builtin_function_or_method_cls
;
...
...
@@ -1217,8 +1218,6 @@ void setupRuntime() {
gc
::
enableGC
();
unicode_cls
=
new
BoxedHeapClass
(
basestring_cls
,
NULL
,
0
,
sizeof
(
BoxedUnicode
),
false
,
"unicode"
);
// It wasn't safe to add __base__ attributes until object+type+str are set up, so do that now:
type_cls
->
giveAttr
(
"__base__"
,
object_cls
);
basestring_cls
->
giveAttr
(
"__base__"
,
object_cls
);
...
...
@@ -1336,7 +1335,7 @@ void setupRuntime() {
setupIter
();
setupClassobj
();
setupSuper
();
setupUnicode
();
_PyUnicode_Init
();
setupDescr
();
setupTraceback
();
...
...
src/runtime/types.h
View file @
398ee469
...
...
@@ -62,7 +62,6 @@ void teardownFile();
void
setupCAPI
();
void
teardownCAPI
();
void
setupGenerator
();
void
setupUnicode
();
void
setupDescr
();
void
teardownDescr
();
...
...
@@ -81,9 +80,11 @@ extern "C" {
extern
BoxedClass
*
object_cls
,
*
type_cls
,
*
bool_cls
,
*
int_cls
,
*
long_cls
,
*
float_cls
,
*
str_cls
,
*
function_cls
,
*
none_cls
,
*
instancemethod_cls
,
*
list_cls
,
*
slice_cls
,
*
module_cls
,
*
dict_cls
,
*
tuple_cls
,
*
file_cls
,
*
enumerate_cls
,
*
xrange_cls
,
*
member_cls
,
*
method_cls
,
*
closure_cls
,
*
generator_cls
,
*
complex_cls
,
*
basestring_cls
,
*
unicode_cls
,
*
property_cls
,
*
staticmethod_cls
,
*
classmethod_cls
,
*
attrwrapper_cls
,
*
pyston
_getset_cls
,
*
capi_getset_cls
,
*
builtin_function_or_method_cls
;
*
property_cls
,
*
staticmethod_cls
,
*
classmethod_cls
,
*
attrwrapper_cls
,
*
pyston_getset_cls
,
*
capi
_getset_cls
,
*
builtin_function_or_method_cls
;
}
#define unicode_cls (&PyUnicode_Type)
extern
"C"
{
extern
Box
*
None
,
*
NotImplemented
,
*
True
,
*
False
;
}
...
...
src/runtime/unicode.cpp
deleted
100644 → 0
View file @
f4b1b16a
// Copyright (c) 2014-2015 Dropbox, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "runtime/types.h"
namespace
pyston
{
// capi stuff
static
std
::
string
unicode_default_encoding
=
"ascii"
;
extern
"C"
const
char
*
PyUnicode_GetDefaultEncoding
(
void
)
noexcept
{
return
unicode_default_encoding
.
c_str
();
}
extern
"C"
int
PyUnicode_SetDefaultEncoding
(
const
char
*
encoding
)
noexcept
{
unicode_default_encoding
=
encoding
;
return
0
;
}
extern
"C"
int
PyUnicode_ClearFreeList
()
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_FromUnicode
(
const
Py_UNICODE
*
u
,
Py_ssize_t
size
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_FromStringAndSize
(
const
char
*
u
,
Py_ssize_t
size
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_FromString
(
const
char
*
u
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_FromFormat
(
const
char
*
format
,
...)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_FromFormatV
(
const
char
*
format
,
va_list
vargs
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_UNICODE
*
PyUnicode_AsUnicode
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_ssize_t
PyUnicode_GetSize
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_FromEncodedObject
(
PyObject
*
obj
,
const
char
*
encoding
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_FromObject
(
PyObject
*
obj
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_FromWideChar
(
const
wchar_t
*
w
,
Py_ssize_t
size
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_ssize_t
PyUnicode_AsWideChar
(
PyUnicodeObject
*
unicode
,
wchar_t
*
w
,
Py_ssize_t
size
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Decode
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
encoding
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Encode
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
const
char
*
encoding
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsEncodedObject
(
PyObject
*
unicode
,
const
char
*
encoding
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsEncodedString
(
PyObject
*
unicode
,
const
char
*
encoding
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUTF8
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUTF8Stateful
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
,
Py_ssize_t
*
consumed
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeUTF8
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsUTF8String
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUTF32
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
,
int
*
byteorder
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUTF32Stateful
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
,
int
*
byteorder
,
Py_ssize_t
*
consumed
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeUTF32
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
const
char
*
errors
,
int
byteorder
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsUTF32String
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUTF16
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
,
int
*
byteorder
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUTF16Stateful
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
,
int
*
byteorder
,
Py_ssize_t
*
consumed
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeUTF16
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
const
char
*
errors
,
int
byteorder
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsUTF16String
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUTF7
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUTF7Stateful
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
,
Py_ssize_t
*
consumed
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeUTF7
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
int
base64SetO
,
int
base64WhiteSpace
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeUnicodeEscape
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeUnicodeEscape
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsUnicodeEscapeString
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeRawUnicodeEscape
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeRawUnicodeEscape
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsRawUnicodeEscapeString
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeLatin1
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeLatin1
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsLatin1String
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeASCII
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeASCII
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsASCIIString
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeCharmap
(
const
char
*
s
,
Py_ssize_t
size
,
PyObject
*
mapping
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeCharmap
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
PyObject
*
mapping
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsCharmapString
(
PyObject
*
unicode
,
PyObject
*
mapping
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_TranslateCharmap
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
PyObject
*
table
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeMBCS
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_DecodeMBCSStateful
(
const
char
*
s
,
int
size
,
const
char
*
errors
,
int
*
consumed
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_EncodeMBCS
(
const
Py_UNICODE
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_AsMBCSString
(
PyObject
*
unicode
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Concat
(
PyObject
*
left
,
PyObject
*
right
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Split
(
PyObject
*
s
,
PyObject
*
sep
,
Py_ssize_t
maxsplit
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Splitlines
(
PyObject
*
s
,
int
keepend
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Translate
(
PyObject
*
str
,
PyObject
*
table
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Join
(
PyObject
*
separator
,
PyObject
*
seq
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_ssize_t
PyUnicode_Tailmatch
(
PyObject
*
str
,
PyObject
*
substr
,
Py_ssize_t
start
,
Py_ssize_t
end
,
int
direction
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_ssize_t
PyUnicode_Find
(
PyObject
*
str
,
PyObject
*
substr
,
Py_ssize_t
start
,
Py_ssize_t
end
,
int
direction
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_ssize_t
PyUnicode_Count
(
PyObject
*
str
,
PyObject
*
substr
,
Py_ssize_t
start
,
Py_ssize_t
end
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Replace
(
PyObject
*
str
,
PyObject
*
substr
,
PyObject
*
replstr
,
Py_ssize_t
maxcount
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyUnicode_Compare
(
PyObject
*
left
,
PyObject
*
right
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_RichCompare
(
PyObject
*
left
,
PyObject
*
right
,
int
op
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_Format
(
PyObject
*
format
,
PyObject
*
args
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
PyUnicode_Contains
(
PyObject
*
container
,
PyObject
*
element
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
_PyUnicode_AsDefaultEncodedString
(
PyObject
*
,
const
char
*
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
void
_PyUnicode_Fini
()
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
void
_PyUnicode_Init
()
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsAlpha
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsDecimalDigit
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsDigit
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsLinebreak
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsLowercase
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsNumeric
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsTitlecase
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsUppercase
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_IsWhitespace
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_ToDecimalDigit
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
int
_PyUnicode_ToDigit
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_UNICODE
_PyUnicode_ToLowercase
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
double
_PyUnicode_ToNumeric
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_UNICODE
_PyUnicode_ToTitlecase
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
Py_UNICODE
_PyUnicode_ToUppercase
(
Py_UNICODE
ch
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
_PyUnicode_DecodeUnicodeInternal
(
const
char
*
s
,
Py_ssize_t
size
,
const
char
*
errors
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
extern
"C"
PyObject
*
PyUnicode_BuildEncodingMap
(
PyObject
*
string
)
noexcept
{
Py_FatalError
(
"unimplemented"
);
}
// From CPython, unicodeobject.c
// Used by Py_UNICODE_ISSPACE in unicodeobject.h
/* Fast detection of the most frequent whitespace characters */
extern
"C"
const
unsigned
char
_Py_ascii_whitespace
[]
=
{
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
/* case 0x0009: * CHARACTER TABULATION */
/* case 0x000A: * LINE FEED */
/* case 0x000B: * LINE TABULATION */
/* case 0x000C: * FORM FEED */
/* case 0x000D: * CARRIAGE RETURN */
0
,
1
,
1
,
1
,
1
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
/* case 0x001C: * FILE SEPARATOR */
/* case 0x001D: * GROUP SEPARATOR */
/* case 0x001E: * RECORD SEPARATOR */
/* case 0x001F: * UNIT SEPARATOR */
0
,
0
,
0
,
0
,
1
,
1
,
1
,
1
,
/* case 0x0020: * SPACE */
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
};
void
setupUnicode
()
{
unicode_cls
->
freeze
();
}
void
teardownUnicode
()
{
}
}
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