0
0
mirror of https://github.com/python/cpython.git synced 2024-12-01 03:01:36 +01:00
cpython/Objects/stringlib
Victor Stinner 6099a03202 Issue #13624: Write a specialized UTF-8 encoder to allow more optimization
The main bottleneck was the PyUnicode_READ() macro.
2011-12-18 14:22:26 +01:00
..
asciilib.h stringlib: remove unused STRINGLIB_FILL 2011-11-20 19:30:15 +01:00
codecs.h Issue #13624: Write a specialized UTF-8 encoder to allow more optimization 2011-12-18 14:22:26 +01:00
count.h
ctype.h
eq.h
fastsearch.h Fix typo 2011-10-17 19:21:04 +02:00
find_max_char.h Issue #13155: Optimize finding the optimal character width of an unicode string 2011-10-13 00:02:27 +02:00
find.h Issue #13623: Fix a performance regression introduced by issue #12170 in 2011-12-18 01:17:41 +01:00
localeutil.h
partition.h
README.txt
split.h
stringdefs.h stringlib: remove unused STRINGLIB_FILL 2011-11-20 19:30:15 +01:00
transmogrify.h
ucs1lib.h stringlib: remove unused STRINGLIB_FILL 2011-11-20 19:30:15 +01:00
ucs2lib.h stringlib: remove unused STRINGLIB_FILL 2011-11-20 19:30:15 +01:00
ucs4lib.h stringlib: remove unused STRINGLIB_FILL 2011-11-20 19:30:15 +01:00
undef.h Fix fastsearch for UCS2 and UCS4 2011-10-11 23:22:22 +02:00
unicode_format.h Replace PyUnicode_FromUnicode(NULL, 0) by PyUnicode_New(0, 0) 2011-12-01 03:18:59 +01:00
unicodedefs.h stringlib: remove unused STRINGLIB_FILL 2011-11-20 19:30:15 +01:00

bits shared by the stringobject and unicodeobject implementations (and
possibly other modules, in a not too distant future).

the stuff in here is included into relevant places; see the individual
source files for details.

--------------------------------------------------------------------
the following defines used by the different modules:

STRINGLIB_CHAR

    the type used to hold a character (char or Py_UNICODE)

STRINGLIB_EMPTY

    a PyObject representing the empty string, only to be used if
    STRINGLIB_MUTABLE is 0

Py_ssize_t STRINGLIB_LEN(PyObject*)

    returns the length of the given string object (which must be of the
    right type)

PyObject* STRINGLIB_NEW(STRINGLIB_CHAR*, Py_ssize_t)

    creates a new string object

STRINGLIB_CHAR* STRINGLIB_STR(PyObject*)

    returns the pointer to the character data for the given string
    object (which must be of the right type)

int STRINGLIB_CHECK_EXACT(PyObject *)

    returns true if the object is an instance of our type, not a subclass

STRINGLIB_MUTABLE

    must be 0 or 1 to tell the cpp macros in stringlib code if the object
    being operated on is mutable or not