cpython/Objects/stringlib
Amaury Forgeot d'Arc f2e9368021 Merged revisions 66631 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk

........
  r66631 | amaury.forgeotdarc | 2008-09-27 00:34:08 +0200 (sam., 27 sept. 2008) | 7 lines

  #3967: Correct a crash in count() and find() methods of string-like objects.
  For example:
     "".count("xxxx", sys.maxint, 0)

  Reviewed by Benjamin Peterson.
  Will port to 2.5 and 3.0.
........
2008-09-26 22:48:41 +00:00
..
README.txt For PEP3137: Adds missing methods to the mutable PyBytes object (soon 2007-10-16 06:31:30 +00:00
count.h Merged revisions 66631 via svnmerge from 2008-09-26 22:48:41 +00:00
ctype.h For PEP3137: Adds missing methods to the mutable PyBytes object (soon 2007-10-16 06:31:30 +00:00
eq.h Fixed issue #1564: The set implementation should special-case PyUnicode instead of PyString 2007-12-10 15:50:56 +00:00
fastsearch.h
find.h Merged revisions 66631 via svnmerge from 2008-09-26 22:48:41 +00:00
formatter.h Merged revisions 66006 via svnmerge from 2008-08-24 05:48:10 +00:00
localeutil.h Merged revisions 64491 via svnmerge from 2008-06-24 01:06:47 +00:00
partition.h Four months of trunk changes (including a few releases...) 2006-12-13 04:49:30 +00:00
string_format.h #2630: Implement PEP 3138. 2008-06-11 18:37:52 +00:00
stringdefs.h #2630: Implement PEP 3138. 2008-06-11 18:37:52 +00:00
transmogrify.h Merging the py3k-pep3137 branch back into the py3k branch. 2007-11-06 21:34:58 +00:00
unicodedefs.h #2630: Implement PEP 3138. 2008-06-11 18:37:52 +00:00

README.txt

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.