mirror of https://github.com/python/cpython
Make Python compile with --disable-unicode.
This commit is contained in:
parent
aed6c66aa8
commit
dfe5dc8455
|
@ -3220,8 +3220,10 @@ inherit_special(PyTypeObject *type, PyTypeObject *base)
|
|||
type->tp_flags |= Py_TPFLAGS_LONG_SUBCLASS;
|
||||
else if (PyType_IsSubtype(base, &PyString_Type))
|
||||
type->tp_flags |= Py_TPFLAGS_STRING_SUBCLASS;
|
||||
#ifdef Py_USING_UNICODE
|
||||
else if (PyType_IsSubtype(base, &PyUnicode_Type))
|
||||
type->tp_flags |= Py_TPFLAGS_UNICODE_SUBCLASS;
|
||||
#endif
|
||||
else if (PyType_IsSubtype(base, &PyTuple_Type))
|
||||
type->tp_flags |= Py_TPFLAGS_TUPLE_SUBCLASS;
|
||||
else if (PyType_IsSubtype(base, &PyList_Type))
|
||||
|
|
|
@ -1533,6 +1533,7 @@ PyTokenizer_Get(struct tok_state *tok, char **p_start, char **p_end)
|
|||
return result;
|
||||
}
|
||||
|
||||
#ifdef Py_USING_UNICODE
|
||||
/* This function is only called from parsetok. However, it cannot live
|
||||
there, as it must be empty for PGEN, and we can check for PGEN only
|
||||
in this file. */
|
||||
|
@ -1593,6 +1594,7 @@ PyTokenizer_RestoreEncoding(struct tok_state* tok, int len, int *offset)
|
|||
}
|
||||
#endif
|
||||
|
||||
#endif /* defined(Py_USING_UNICODE) */
|
||||
|
||||
|
||||
#ifdef Py_DEBUG
|
||||
|
|
|
@ -58,8 +58,10 @@ extern struct tok_state *PyTokenizer_FromString(const char *);
|
|||
extern struct tok_state *PyTokenizer_FromFile(FILE *, char *, char *);
|
||||
extern void PyTokenizer_Free(struct tok_state *);
|
||||
extern int PyTokenizer_Get(struct tok_state *, char **, char **);
|
||||
#ifdef Py_USING_UNICODE
|
||||
extern char * PyTokenizer_RestoreEncoding(struct tok_state* tok,
|
||||
int len, int *offset);
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
|
|
@ -1246,6 +1246,7 @@ ast_for_atom(struct compiling *c, const node *n)
|
|||
case STRING: {
|
||||
PyObject *str = parsestrplus(c, n);
|
||||
if (!str) {
|
||||
#ifdef Py_USING_UNICODE
|
||||
if (PyErr_ExceptionMatches(PyExc_UnicodeError)){
|
||||
PyObject *type, *value, *tback, *errstr;
|
||||
PyErr_Fetch(&type, &value, &tback);
|
||||
|
@ -1263,6 +1264,7 @@ ast_for_atom(struct compiling *c, const node *n)
|
|||
Py_DECREF(value);
|
||||
Py_XDECREF(tback);
|
||||
}
|
||||
#endif
|
||||
return NULL;
|
||||
}
|
||||
PyArena_AddPyObject(c->c_arena, str);
|
||||
|
|
Loading…
Reference in New Issue