1 /* this is sort of a hack. there's at least one place (formatting 2 floats) where some stringlib code takes a different path if it's 3 compiled as unicode. */ 4 #define STRINGLIB_IS_UNICODE 1 5 6 #define FASTSEARCH ucs4lib_fastsearch 7 #define STRINGLIB(F) ucs4lib_##F 8 #define STRINGLIB_OBJECT PyUnicodeObject 9 #define STRINGLIB_SIZEOF_CHAR 4 10 #define STRINGLIB_MAX_CHAR 0x10FFFFu 11 #define STRINGLIB_CHAR Py_UCS4 12 #define STRINGLIB_TYPE_NAME "unicode" 13 #define STRINGLIB_PARSE_CODE "U" 14 #define STRINGLIB_EMPTY unicode_empty 15 #define STRINGLIB_ISSPACE Py_UNICODE_ISSPACE 16 #define STRINGLIB_ISLINEBREAK BLOOM_LINEBREAK 17 #define STRINGLIB_ISDECIMAL Py_UNICODE_ISDECIMAL 18 #define STRINGLIB_TODECIMAL Py_UNICODE_TODECIMAL 19 #define STRINGLIB_STR PyUnicode_4BYTE_DATA 20 #define STRINGLIB_LEN PyUnicode_GET_LENGTH 21 #define STRINGLIB_NEW _PyUnicode_FromUCS4 22 #define STRINGLIB_CHECK PyUnicode_Check 23 #define STRINGLIB_CHECK_EXACT PyUnicode_CheckExact 24 25 #define STRINGLIB_TOSTR PyObject_Str 26 #define STRINGLIB_TOASCII PyObject_ASCII 27 28 #define _Py_InsertThousandsGrouping _PyUnicode_ucs4_InsertThousandsGrouping 29 30