mirror of
https://github.com/python/cpython.git
synced 2025-01-23 17:44:35 +08:00
98297ee781
No detailed change log; just check out the change log for the py3k-pep3137 branch. The most obvious changes: - str8 renamed to bytes (PyString at the C level); - bytes renamed to buffer (PyBytes at the C level); - PyString and PyUnicode are no longer compatible. I.e. we now have an immutable bytes type and a mutable bytes type. The behavior of PyString was modified quite a bit, to make it more bytes-like. Some changes are still on the to-do list. |
||
---|---|---|
.. | ||
count.h | ||
ctype.h | ||
fastsearch.h | ||
find.h | ||
formatter.h | ||
partition.h | ||
README.txt | ||
string_format.h | ||
stringdefs.h | ||
transmogrify.h | ||
unicodedefs.h |
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 int STRINGLIB_CMP(STRINGLIB_CHAR*, STRINGLIB_CHAR*, Py_ssize_t) compares two strings. returns 0 if they match, and non-zero if not. 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.