cpython/Objects/stringlib
Serhiy Storchaka 894263ba80
bpo-24214: Fixed the UTF-8 and UTF-16 incremental decoders. (GH-14304)
* The UTF-8 incremental decoders fails now fast if encounter
  a sequence that can't be handled by the error handler.
* The UTF-16 incremental decoders with the surrogatepass error
  handler decodes now a lone low surrogate with final=False.
2019-06-25 11:54:18 +03:00
..
clinic bpo-36127: Argument Clinic: inline parsing code for keyword parameters. (GH-12058) 2019-03-14 10:32:22 +02:00
README.txt
asciilib.h
codecs.h bpo-24214: Fixed the UTF-8 and UTF-16 incremental decoders. (GH-14304) 2019-06-25 11:54:18 +03:00
count.h
ctype.h bpo-33012: Fix invalid function cast warnings with gcc 8 for METH_NOARGS. (GH-6030) 2018-04-29 21:59:33 +03:00
eq.h bpo-31338 (#3374) 2017-09-14 18:13:16 -07:00
fastsearch.h Fix couple of dead code paths (GH-7418) 2019-05-17 19:46:22 -04:00
find.h
find_max_char.h
join.h
localeutil.h bpo-33954: Fix _PyUnicode_InsertThousandsGrouping() (GH-10623) 2018-11-26 13:40:01 +01:00
partition.h
replace.h
split.h
stringdefs.h
transmogrify.h bpo-20180: complete AC conversion of Objects/stringlib/transmogrify.h (GH-8039) 2018-07-06 13:17:38 +03:00
ucs1lib.h
ucs2lib.h
ucs4lib.h
undef.h
unicode_format.h Improve exception message for str.format (GH-12675) 2019-06-01 10:14:00 -07:00
unicodedefs.h

README.txt

bits shared by the bytesobject 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