Commit 3497f944 authored by Christian Heimes's avatar Christian Heimes

First step of the C API rename:

renamed Include/bytesobject.h to Include/bytearrayobject.h
renamed Include/stringobject.h to Include/bytesobject.h
added Include/stringobject.h with aliases
parent b4701e63
...@@ -94,6 +94,7 @@ ...@@ -94,6 +94,7 @@
/* #include "memoryobject.h" */ /* #include "memoryobject.h" */
#include "bufferobject.h" #include "bufferobject.h"
#include "bytesobject.h" #include "bytesobject.h"
#include "bytearrayobject.h"
#include "tupleobject.h" #include "tupleobject.h"
#include "listobject.h" #include "listobject.h"
#include "dictobject.h" #include "dictobject.h"
......
/* Bytes object interface */
#ifndef Py_BYTESOBJECT_H
#define Py_BYTESOBJECT_H
#ifdef __cplusplus
extern "C" {
#endif
#include <stdarg.h>
/* Type PyByteArrayObject represents a mutable array of bytes.
* The Python API is that of a sequence;
* the bytes are mapped to ints in [0, 256).
* Bytes are not characters; they may be used to encode characters.
* The only way to go between bytes and str/unicode is via encoding
* and decoding.
* For the convenience of C programmers, the bytes type is considered
* to contain a char pointer, not an unsigned char pointer.
*/
/* Object layout */
typedef struct {
PyObject_VAR_HEAD
/* XXX(nnorwitz): should ob_exports be Py_ssize_t? */
int ob_exports; /* how many buffer exports */
Py_ssize_t ob_alloc; /* How many bytes allocated */
char *ob_bytes;
} PyByteArrayObject;
/* Type object */
PyAPI_DATA(PyTypeObject) PyByteArray_Type;
PyAPI_DATA(PyTypeObject) PyByteArrayIter_Type;
/* Type check macros */
#define PyByteArray_Check(self) PyObject_TypeCheck(self, &PyByteArray_Type)
#define PyByteArray_CheckExact(self) (Py_TYPE(self) == &PyByteArray_Type)
/* Direct API functions */
PyAPI_FUNC(PyObject *) PyByteArray_FromObject(PyObject *);
PyAPI_FUNC(PyObject *) PyByteArray_Concat(PyObject *, PyObject *);
PyAPI_FUNC(PyObject *) PyByteArray_FromStringAndSize(const char *, Py_ssize_t);
PyAPI_FUNC(Py_ssize_t) PyByteArray_Size(PyObject *);
PyAPI_FUNC(char *) PyByteArray_AsString(PyObject *);
PyAPI_FUNC(int) PyByteArray_Resize(PyObject *, Py_ssize_t);
/* Macros, trading safety for speed */
#define PyByteArray_AS_STRING(self) (assert(PyByteArray_Check(self)),((PyByteArrayObject *)(self))->ob_bytes)
#define PyByteArray_GET_SIZE(self) (assert(PyByteArray_Check(self)),Py_SIZE(self))
#ifdef __cplusplus
}
#endif
#endif /* !Py_BYTESOBJECT_H */
/* Bytes object interface */
#ifndef Py_BYTESOBJECT_H /* String object interface */
#define Py_BYTESOBJECT_H
#ifndef Py_STRINGOBJECT_H
#define Py_STRINGOBJECT_H
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
#include <stdarg.h> #include <stdarg.h>
/* Type PyBytesObject represents a mutable array of bytes. /*
* The Python API is that of a sequence; Type PyStringObject represents a character string. An extra zero byte is
* the bytes are mapped to ints in [0, 256). reserved at the end to ensure it is zero-terminated, but a size is
* Bytes are not characters; they may be used to encode characters. present so strings with null bytes in them can be represented. This
* The only way to go between bytes and str/unicode is via encoding is an immutable object type.
* and decoding.
* For the convenience of C programmers, the bytes type is considered There are functions to create new string objects, to test
* to contain a char pointer, not an unsigned char pointer. an object for string-ness, and to get the
*/ string value. The latter function returns a null pointer
if the object is not of the proper type.
/* Object layout */ There is a variant that takes an explicit size as well as a
variant that assumes a zero-terminated string. Note that none of the
functions should be applied to nil objects.
*/
/* Caching the hash (ob_shash) saves recalculation of a string's hash value.
Interning strings (ob_sstate) tries to ensure that only one string
object with a given value exists, so equality tests can be one pointer
comparison. This is generally restricted to strings that "look like"
Python identifiers, although the intern() builtin can be used to force
interning of any string.
Together, these sped the interpreter by up to 20%. */
typedef struct { typedef struct {
PyObject_VAR_HEAD PyObject_VAR_HEAD
/* XXX(nnorwitz): should ob_exports be Py_ssize_t? */ long ob_shash;
int ob_exports; /* how many buffer exports */ int ob_sstate;
Py_ssize_t ob_alloc; /* How many bytes allocated */ char ob_sval[1];
char *ob_bytes;
} PyBytesObject; /* Invariants:
* ob_sval contains space for 'ob_size+1' elements.
/* Type object */ * ob_sval[ob_size] == 0.
PyAPI_DATA(PyTypeObject) PyBytes_Type; * ob_shash is the hash of the string or -1 if not computed yet.
PyAPI_DATA(PyTypeObject) PyBytesIter_Type; * ob_sstate != 0 iff the string object is in stringobject.c's
* 'interned' dictionary; in this case the two references
/* Type check macros */ * from 'interned' to this object are *not counted* in ob_refcnt.
#define PyBytes_Check(self) PyObject_TypeCheck(self, &PyBytes_Type) */
#define PyBytes_CheckExact(self) (Py_TYPE(self) == &PyBytes_Type) } PyStringObject;
/* Direct API functions */ #define SSTATE_NOT_INTERNED 0
PyAPI_FUNC(PyObject *) PyBytes_FromObject(PyObject *); #define SSTATE_INTERNED_MORTAL 1
PyAPI_FUNC(PyObject *) PyBytes_Concat(PyObject *, PyObject *); #define SSTATE_INTERNED_IMMORTAL 2
PyAPI_FUNC(PyObject *) PyBytes_FromStringAndSize(const char *, Py_ssize_t);
PyAPI_FUNC(Py_ssize_t) PyBytes_Size(PyObject *); PyAPI_DATA(PyTypeObject) PyBaseString_Type;
PyAPI_FUNC(char *) PyBytes_AsString(PyObject *); PyAPI_DATA(PyTypeObject) PyString_Type;
PyAPI_FUNC(int) PyBytes_Resize(PyObject *, Py_ssize_t);
#define PyString_Check(op) \
/* Macros, trading safety for speed */ PyType_FastSubclass(Py_TYPE(op), Py_TPFLAGS_STRING_SUBCLASS)
#define PyBytes_AS_STRING(self) (assert(PyBytes_Check(self)),((PyBytesObject *)(self))->ob_bytes) #define PyString_CheckExact(op) (Py_TYPE(op) == &PyString_Type)
#define PyBytes_GET_SIZE(self) (assert(PyBytes_Check(self)),Py_SIZE(self))
PyAPI_FUNC(PyObject *) PyString_FromStringAndSize(const char *, Py_ssize_t);
PyAPI_FUNC(PyObject *) PyString_FromString(const char *);
PyAPI_FUNC(PyObject *) PyString_FromFormatV(const char*, va_list)
Py_GCC_ATTRIBUTE((format(printf, 1, 0)));
PyAPI_FUNC(PyObject *) PyString_FromFormat(const char*, ...)
Py_GCC_ATTRIBUTE((format(printf, 1, 2)));
PyAPI_FUNC(Py_ssize_t) PyString_Size(PyObject *);
PyAPI_FUNC(char *) PyString_AsString(PyObject *);
PyAPI_FUNC(PyObject *) PyString_Repr(PyObject *, int);
PyAPI_FUNC(void) PyString_Concat(PyObject **, PyObject *);
PyAPI_FUNC(void) PyString_ConcatAndDel(PyObject **, PyObject *);
PyAPI_FUNC(int) _PyString_Resize(PyObject **, Py_ssize_t);
PyAPI_FUNC(int) _PyString_Eq(PyObject *, PyObject*);
PyAPI_FUNC(PyObject *) PyString_Format(PyObject *, PyObject *);
PyAPI_FUNC(PyObject *) _PyString_FormatLong(PyObject*, int, int,
int, char**, int*);
PyAPI_FUNC(PyObject *) PyString_DecodeEscape(const char *, Py_ssize_t,
const char *, Py_ssize_t,
const char *);
PyAPI_FUNC(void) PyString_InternInPlace(PyObject **);
PyAPI_FUNC(void) PyString_InternImmortal(PyObject **);
PyAPI_FUNC(PyObject *) PyString_InternFromString(const char *);
PyAPI_FUNC(void) _Py_ReleaseInternedStrings(void);
/* Use only if you know it's a string */
#define PyString_CHECK_INTERNED(op) (((PyStringObject *)(op))->ob_sstate)
/* Macro, trading safety for speed */
#define PyString_AS_STRING(op) (((PyStringObject *)(op))->ob_sval)
#define PyString_GET_SIZE(op) Py_SIZE(op)
/* _PyString_Join(sep, x) is like sep.join(x). sep must be PyStringObject*,
x must be an iterable object. */
PyAPI_FUNC(PyObject *) _PyString_Join(PyObject *sep, PyObject *x);
/* --- Generic Codecs ----------------------------------------------------- */
/* Create an object by decoding the encoded string s of the
given size. */
PyAPI_FUNC(PyObject*) PyString_Decode(
const char *s, /* encoded string */
Py_ssize_t size, /* size of buffer */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Encodes a char buffer of the given size and returns a
Python object. */
PyAPI_FUNC(PyObject*) PyString_Encode(
const char *s, /* string char buffer */
Py_ssize_t size, /* number of chars to encode */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Encodes a string object and returns the result as Python
object. */
PyAPI_FUNC(PyObject*) PyString_AsEncodedObject(
PyObject *str, /* string object */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Encodes a string object and returns the result as Python string
object.
If the codec returns an Unicode object, the object is converted
back to a string using the default encoding.
DEPRECATED - use PyString_AsEncodedObject() instead. */
PyAPI_FUNC(PyObject*) PyString_AsEncodedString(
PyObject *str, /* string object */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Decodes a string object and returns the result as Python
object. */
PyAPI_FUNC(PyObject*) PyString_AsDecodedObject(
PyObject *str, /* string object */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Decodes a string object and returns the result as Python string
object.
If the codec returns an Unicode object, the object is converted
back to a string using the default encoding.
DEPRECATED - use PyString_AsDecodedObject() instead. */
PyAPI_FUNC(PyObject*) PyString_AsDecodedString(
PyObject *str, /* string object */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Provides access to the internal data buffer and size of a string
object or the default encoded version of an Unicode object. Passing
NULL as *len parameter will force the string buffer to be
0-terminated (passing a string with embedded NULL characters will
cause an exception). */
PyAPI_FUNC(int) PyString_AsStringAndSize(
register PyObject *obj, /* string or Unicode object */
register char **s, /* pointer to buffer variable */
register Py_ssize_t *len /* pointer to length variable or NULL
(only possible for 0-terminated
strings) */
);
/* Using the current locale, insert the thousands grouping
into the string pointed to by buffer. For the argument descriptions,
see Objects/stringlib/localeutil.h */
PyAPI_FUNC(int) _PyString_InsertThousandsGrouping(char *buffer,
Py_ssize_t len,
char *plast,
Py_ssize_t buf_size,
Py_ssize_t *count,
int append_zero_char);
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif
#endif /* !Py_BYTESOBJECT_H */ #endif /* !Py_STRINGOBJECT_H */
...@@ -124,7 +124,7 @@ PyAPI_FUNC(void) _PyImportHooks_Init(void); ...@@ -124,7 +124,7 @@ PyAPI_FUNC(void) _PyImportHooks_Init(void);
PyAPI_FUNC(int) _PyFrame_Init(void); PyAPI_FUNC(int) _PyFrame_Init(void);
PyAPI_FUNC(int) _PyInt_Init(void); PyAPI_FUNC(int) _PyInt_Init(void);
PyAPI_FUNC(void) _PyFloat_Init(void); PyAPI_FUNC(void) _PyFloat_Init(void);
PyAPI_FUNC(int) PyBytes_Init(void); PyAPI_FUNC(int) PyByteArray_Init(void);
/* Various internal finalizers */ /* Various internal finalizers */
PyAPI_FUNC(void) _PyExc_Fini(void); PyAPI_FUNC(void) _PyExc_Fini(void);
...@@ -140,7 +140,7 @@ PyAPI_FUNC(void) PyString_Fini(void); ...@@ -140,7 +140,7 @@ PyAPI_FUNC(void) PyString_Fini(void);
PyAPI_FUNC(void) PyInt_Fini(void); PyAPI_FUNC(void) PyInt_Fini(void);
PyAPI_FUNC(void) PyFloat_Fini(void); PyAPI_FUNC(void) PyFloat_Fini(void);
PyAPI_FUNC(void) PyOS_FiniInterrupts(void); PyAPI_FUNC(void) PyOS_FiniInterrupts(void);
PyAPI_FUNC(void) PyBytes_Fini(void); PyAPI_FUNC(void) PyByteArray_Fini(void);
/* Stuff with no proper home (yet) */ /* Stuff with no proper home (yet) */
PyAPI_FUNC(char *) PyOS_Readline(FILE *, FILE *, char *); PyAPI_FUNC(char *) PyOS_Readline(FILE *, FILE *, char *);
......
#define PyBytesObject PyStringObject
/* String object interface */ #define PyBytes_Type PyString_Type
#ifndef Py_STRINGOBJECT_H #define PyBytes_Check PyString_Check
#define Py_STRINGOBJECT_H #define PyBytes_CheckExact PyString_CheckExact
#ifdef __cplusplus #define PyBytes_CHECK_INTERNED PyString_CHECK_INTERNED
extern "C" { #define PyBytes_AS_STRING PyString_AS_STRING
#endif #define PyBytes_GET_SIZE PyString_GET_SIZE
#define Py_TPFLAGS_BYTES_SUBCLASS Py_TPFLAGS_STRING_SUBCLASS
#include <stdarg.h>
#define PyBytes_FromStringAndSize PyString_FromStringAndSize
/* #define PyBytes_FromString PyString_FromString
Type PyStringObject represents a character string. An extra zero byte is #define PyBytes_FromFormatV PyString_FromFormatV
reserved at the end to ensure it is zero-terminated, but a size is #define PyBytes_FromFormat PyString_FromFormat
present so strings with null bytes in them can be represented. This #define PyBytes_Size PyString_Size
is an immutable object type. #define PyBytes_AsString PyString_AsString
#define PyBytes_Repr PyString_Repr
There are functions to create new string objects, to test #define PyBytes_Concat PyString_Concat
an object for string-ness, and to get the #define PyBytes_ConcatAndDel PyString_ConcatAndDel
string value. The latter function returns a null pointer #define _PyBytes_Resize _PyString_Resize
if the object is not of the proper type. #define _PyBytes_Eq _PyString_Eq
There is a variant that takes an explicit size as well as a #define PyBytes_Format PyString_Format
variant that assumes a zero-terminated string. Note that none of the #define _PyBytes_FormatLong _PyString_FormatLong
functions should be applied to nil objects. #define PyBytes_DecodeEscape PyString_DecodeEscape
*/ #define PyBytes_InternInPlace PyString_InternInPlace
#define PyBytes_InternImmortal PyString_InternImmortal
/* Caching the hash (ob_shash) saves recalculation of a string's hash value. #define PyBytes_InternFromString PyString_InternFromString
Interning strings (ob_sstate) tries to ensure that only one string #define _PyBytes_Join _PyString_Join
object with a given value exists, so equality tests can be one pointer #define PyBytes_Decode PyString_Decode
comparison. This is generally restricted to strings that "look like" #define PyBytes_Encode PyString_Encode
Python identifiers, although the intern() builtin can be used to force #define PyBytes_AsEncodedObject PyString_AsEncodedObject
interning of any string. #define PyBytes_AsEncodedString PyString_AsEncodedString
Together, these sped the interpreter by up to 20%. */ #define PyBytes_AsDecodedObject PyString_AsDecodedObject
#define PyBytes_AsDecodedString PyString_AsDecodedString
typedef struct { #define PyBytes_AsStringAndSize PyString_AsStringAndSize
PyObject_VAR_HEAD #define _PyBytes_InsertThousandsGrouping _PyString_InsertThousandsGrouping
long ob_shash;
int ob_sstate;
char ob_sval[1];
/* Invariants:
* ob_sval contains space for 'ob_size+1' elements.
* ob_sval[ob_size] == 0.
* ob_shash is the hash of the string or -1 if not computed yet.
* ob_sstate != 0 iff the string object is in stringobject.c's
* 'interned' dictionary; in this case the two references
* from 'interned' to this object are *not counted* in ob_refcnt.
*/
} PyStringObject;
#define SSTATE_NOT_INTERNED 0
#define SSTATE_INTERNED_MORTAL 1
#define SSTATE_INTERNED_IMMORTAL 2
PyAPI_DATA(PyTypeObject) PyBaseString_Type;
PyAPI_DATA(PyTypeObject) PyString_Type;
#define PyString_Check(op) \
PyType_FastSubclass(Py_TYPE(op), Py_TPFLAGS_STRING_SUBCLASS)
#define PyString_CheckExact(op) (Py_TYPE(op) == &PyString_Type)
PyAPI_FUNC(PyObject *) PyString_FromStringAndSize(const char *, Py_ssize_t);
PyAPI_FUNC(PyObject *) PyString_FromString(const char *);
PyAPI_FUNC(PyObject *) PyString_FromFormatV(const char*, va_list)
Py_GCC_ATTRIBUTE((format(printf, 1, 0)));
PyAPI_FUNC(PyObject *) PyString_FromFormat(const char*, ...)
Py_GCC_ATTRIBUTE((format(printf, 1, 2)));
PyAPI_FUNC(Py_ssize_t) PyString_Size(PyObject *);
PyAPI_FUNC(char *) PyString_AsString(PyObject *);
PyAPI_FUNC(PyObject *) PyString_Repr(PyObject *, int);
PyAPI_FUNC(void) PyString_Concat(PyObject **, PyObject *);
PyAPI_FUNC(void) PyString_ConcatAndDel(PyObject **, PyObject *);
PyAPI_FUNC(int) _PyString_Resize(PyObject **, Py_ssize_t);
PyAPI_FUNC(int) _PyString_Eq(PyObject *, PyObject*);
PyAPI_FUNC(PyObject *) PyString_Format(PyObject *, PyObject *);
PyAPI_FUNC(PyObject *) _PyString_FormatLong(PyObject*, int, int,
int, char**, int*);
PyAPI_FUNC(PyObject *) PyString_DecodeEscape(const char *, Py_ssize_t,
const char *, Py_ssize_t,
const char *);
PyAPI_FUNC(void) PyString_InternInPlace(PyObject **);
PyAPI_FUNC(void) PyString_InternImmortal(PyObject **);
PyAPI_FUNC(PyObject *) PyString_InternFromString(const char *);
PyAPI_FUNC(void) _Py_ReleaseInternedStrings(void);
/* Use only if you know it's a string */
#define PyString_CHECK_INTERNED(op) (((PyStringObject *)(op))->ob_sstate)
/* Macro, trading safety for speed */
#define PyString_AS_STRING(op) (((PyStringObject *)(op))->ob_sval)
#define PyString_GET_SIZE(op) Py_SIZE(op)
/* _PyString_Join(sep, x) is like sep.join(x). sep must be PyStringObject*,
x must be an iterable object. */
PyAPI_FUNC(PyObject *) _PyString_Join(PyObject *sep, PyObject *x);
/* --- Generic Codecs ----------------------------------------------------- */
/* Create an object by decoding the encoded string s of the
given size. */
PyAPI_FUNC(PyObject*) PyString_Decode(
const char *s, /* encoded string */
Py_ssize_t size, /* size of buffer */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Encodes a char buffer of the given size and returns a
Python object. */
PyAPI_FUNC(PyObject*) PyString_Encode(
const char *s, /* string char buffer */
Py_ssize_t size, /* number of chars to encode */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Encodes a string object and returns the result as Python
object. */
PyAPI_FUNC(PyObject*) PyString_AsEncodedObject(
PyObject *str, /* string object */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Encodes a string object and returns the result as Python string
object.
If the codec returns an Unicode object, the object is converted
back to a string using the default encoding.
DEPRECATED - use PyString_AsEncodedObject() instead. */
PyAPI_FUNC(PyObject*) PyString_AsEncodedString(
PyObject *str, /* string object */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Decodes a string object and returns the result as Python
object. */
PyAPI_FUNC(PyObject*) PyString_AsDecodedObject(
PyObject *str, /* string object */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Decodes a string object and returns the result as Python string
object.
If the codec returns an Unicode object, the object is converted
back to a string using the default encoding.
DEPRECATED - use PyString_AsDecodedObject() instead. */
PyAPI_FUNC(PyObject*) PyString_AsDecodedString(
PyObject *str, /* string object */
const char *encoding, /* encoding */
const char *errors /* error handling */
);
/* Provides access to the internal data buffer and size of a string
object or the default encoded version of an Unicode object. Passing
NULL as *len parameter will force the string buffer to be
0-terminated (passing a string with embedded NULL characters will
cause an exception). */
PyAPI_FUNC(int) PyString_AsStringAndSize(
register PyObject *obj, /* string or Unicode object */
register char **s, /* pointer to buffer variable */
register Py_ssize_t *len /* pointer to length variable or NULL
(only possible for 0-terminated
strings) */
);
/* Using the current locale, insert the thousands grouping
into the string pointed to by buffer. For the argument descriptions,
see Objects/stringlib/localeutil.h */
PyAPI_FUNC(int) _PyString_InsertThousandsGrouping(char *buffer,
Py_ssize_t len,
char *plast,
Py_ssize_t buf_size,
Py_ssize_t *count,
int append_zero_char);
#ifdef __cplusplus
}
#endif
#endif /* !Py_STRINGOBJECT_H */
This diff is collapsed.
...@@ -1986,7 +1986,7 @@ _Py_ReadyTypes(void) ...@@ -1986,7 +1986,7 @@ _Py_ReadyTypes(void)
if (PyType_Ready(&PyString_Type) < 0) if (PyType_Ready(&PyString_Type) < 0)
Py_FatalError("Can't initialize 'str'"); Py_FatalError("Can't initialize 'str'");
if (PyType_Ready(&PyBytes_Type) < 0) if (PyType_Ready(&PyByteArray_Type) < 0)
Py_FatalError("Can't initialize 'bytes'"); Py_FatalError("Can't initialize 'bytes'");
if (PyType_Ready(&PyList_Type) < 0) if (PyType_Ready(&PyList_Type) < 0)
......
...@@ -961,8 +961,8 @@ string_concat(register PyStringObject *a, register PyObject *bb) ...@@ -961,8 +961,8 @@ string_concat(register PyStringObject *a, register PyObject *bb)
if (PyUnicode_Check(bb)) if (PyUnicode_Check(bb))
return PyUnicode_Concat((PyObject *)a, bb); return PyUnicode_Concat((PyObject *)a, bb);
#endif #endif
if (PyBytes_Check(bb)) if (PyByteArray_Check(bb))
return PyBytes_Concat((PyObject *)a, bb); return PyByteArray_Concat((PyObject *)a, bb);
PyErr_Format(PyExc_TypeError, PyErr_Format(PyExc_TypeError,
"cannot concatenate 'str' and '%.200s' objects", "cannot concatenate 'str' and '%.200s' objects",
Py_TYPE(bb)->tp_name); Py_TYPE(bb)->tp_name);
......
...@@ -1084,7 +1084,7 @@ PyObject *PyUnicode_FromEncodedObject(register PyObject *obj, ...@@ -1084,7 +1084,7 @@ PyObject *PyUnicode_FromEncodedObject(register PyObject *obj,
s = PyString_AS_STRING(obj); s = PyString_AS_STRING(obj);
len = PyString_GET_SIZE(obj); len = PyString_GET_SIZE(obj);
} }
else if (PyBytes_Check(obj)) { else if (PyByteArray_Check(obj)) {
/* Python 2.x specific */ /* Python 2.x specific */
PyErr_Format(PyExc_TypeError, PyErr_Format(PyExc_TypeError,
"decoding bytearray is not supported"); "decoding bytearray is not supported");
......
...@@ -1498,10 +1498,10 @@ builtin_ord(PyObject *self, PyObject* obj) ...@@ -1498,10 +1498,10 @@ builtin_ord(PyObject *self, PyObject* obj)
ord = (long)((unsigned char)*PyString_AS_STRING(obj)); ord = (long)((unsigned char)*PyString_AS_STRING(obj));
return PyInt_FromLong(ord); return PyInt_FromLong(ord);
} }
} else if (PyBytes_Check(obj)) { } else if (PyByteArray_Check(obj)) {
size = PyBytes_GET_SIZE(obj); size = PyByteArray_GET_SIZE(obj);
if (size == 1) { if (size == 1) {
ord = (long)((unsigned char)*PyBytes_AS_STRING(obj)); ord = (long)((unsigned char)*PyByteArray_AS_STRING(obj));
return PyInt_FromLong(ord); return PyInt_FromLong(ord);
} }
...@@ -2618,7 +2618,7 @@ _PyBuiltin_Init(void) ...@@ -2618,7 +2618,7 @@ _PyBuiltin_Init(void)
SETBUILTIN("basestring", &PyBaseString_Type); SETBUILTIN("basestring", &PyBaseString_Type);
SETBUILTIN("bool", &PyBool_Type); SETBUILTIN("bool", &PyBool_Type);
/* SETBUILTIN("memoryview", &PyMemoryView_Type); */ /* SETBUILTIN("memoryview", &PyMemoryView_Type); */
SETBUILTIN("bytearray", &PyBytes_Type); SETBUILTIN("bytearray", &PyByteArray_Type);
SETBUILTIN("bytes", &PyString_Type); SETBUILTIN("bytes", &PyString_Type);
SETBUILTIN("buffer", &PyBuffer_Type); SETBUILTIN("buffer", &PyBuffer_Type);
SETBUILTIN("classmethod", &PyClassMethod_Type); SETBUILTIN("classmethod", &PyClassMethod_Type);
......
...@@ -169,7 +169,7 @@ Py_InitializeEx(int install_sigs) ...@@ -169,7 +169,7 @@ Py_InitializeEx(int install_sigs)
if (!_PyInt_Init()) if (!_PyInt_Init())
Py_FatalError("Py_Initialize: can't init ints"); Py_FatalError("Py_Initialize: can't init ints");
if (!PyBytes_Init()) if (!PyByteArray_Init())
Py_FatalError("Py_Initialize: can't init bytearray"); Py_FatalError("Py_Initialize: can't init bytearray");
_PyFloat_Init(); _PyFloat_Init();
...@@ -451,7 +451,7 @@ Py_Finalize(void) ...@@ -451,7 +451,7 @@ Py_Finalize(void)
PyList_Fini(); PyList_Fini();
PySet_Fini(); PySet_Fini();
PyString_Fini(); PyString_Fini();
PyBytes_Fini(); PyByteArray_Fini();
PyInt_Fini(); PyInt_Fini();
PyFloat_Fini(); PyFloat_Fini();
PyDict_Fini(); PyDict_Fini();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment