The following APIs are capable of handling Unicode objects and strings on input (we refer to them as strings in the descriptions) and return Unicode objects or integers as appropriate.
They all return NULL or -1 if an exception occurs.
| PyObject *left, PyObject *right) | 
| PyObject *s, PyObject *sep, int maxsplit) | 
| PyObject *s, int keepend) | 
| PyObject *str, PyObject *table, const char *errors) | 
The mapping table must map Unicode ordinal integers to Unicode ordinal integers or None (causing deletion of the character).
Mapping tables need only provide the __getitem__() interface; dictionaries and sequences work well. Unmapped character ordinals (ones which cause a LookupError) are left untouched and are copied as-is.
errors has the usual meaning for codecs. It may be NULL which indicates to use the default error handling.
| PyObject *separator, PyObject *seq) | 
| PyObject *str, PyObject *substr, int start, int end, int direction) | 
-1 if an error occurred.                         
| PyObject *str, PyObject *substr, int start, int end, int direction) | 
-1 indicates that no
  match was found, and -2 indicates that an error occurred and
  an exception has been set.
| PyObject *str, PyObject *substr, int start, int end) | 
str[start:end].  Returns -1 if an
  error occurred.
| PyObject *str, PyObject *substr, PyObject *replstr, int maxcount) | 
| PyObject *left, PyObject *right) | 
| PyObject *format, PyObject *args) | 
format % args.  The
  args argument must be a tuple.
| PyObject *container, PyObject *element) | 
element has to coerce to a one element Unicode
  string. -1 is returned if there was an error.
See About this document... for information on suggesting changes.