diff options
| author | Martin v. Löwis <martin@v.loewis.de> | 2007-06-10 09:51:05 +0000 | 
|---|---|---|
| committer | Martin v. Löwis <martin@v.loewis.de> | 2007-06-10 09:51:05 +0000 | 
| commit | 5b222135f8d2492713994f2cb003980e87ce6a72 (patch) | |
| tree | 3ac3a6a1d7805360ed779e884ca6c4b3f000321f /Objects/classobject.c | |
| parent | 38e43c25eede3fa77d90ac8183cc0335f4861f4a (diff) | |
| download | cpython-git-5b222135f8d2492713994f2cb003980e87ce6a72.tar.gz | |
Make identifiers str (not str8) objects throughout.
This affects the parser, various object implementations,
and all places that put identifiers into C string literals.
In testing, a number of crashes occurred as code would
fail when the recursion limit was reached (such as the
Unicode interning dictionary having key/value pairs where
key is not value). To solve these, I added an overflowed
flag, which allows for 50 more recursions after the
limit was reached and the exception was raised, and
a recursion_critical flag, which indicates that recursion
absolutely must be allowed, i.e. that a certain call
must not cause a stack overflow exception.
There are still some places where both str and str8 are
accepted as identifiers; these should eventually be
removed.
Diffstat (limited to 'Objects/classobject.c')
| -rw-r--r-- | Objects/classobject.c | 10 | 
1 files changed, 5 insertions, 5 deletions
| diff --git a/Objects/classobject.c b/Objects/classobject.c index b7711d56d7..3cf64de870 100644 --- a/Objects/classobject.c +++ b/Objects/classobject.c @@ -100,7 +100,7 @@ method_get_doc(PyMethodObject *im, void *context)  {  	static PyObject *docstr;  	if (docstr == NULL) { -		docstr= PyString_InternFromString("__doc__"); +		docstr= PyUnicode_InternFromString("__doc__");  		if (docstr == NULL)  			return NULL;  	} @@ -235,12 +235,12 @@ method_repr(PyMethodObject *a)  			return NULL;  		PyErr_Clear();  	} -	else if (!PyString_Check(funcname)) { +	else if (!PyUnicode_Check(funcname)) {  		Py_DECREF(funcname);  		funcname = NULL;  	}  	else -		sfuncname = PyString_AS_STRING(funcname); +		sfuncname = PyUnicode_AsString(funcname);  	if (klass == NULL)  		klassname = NULL;  	else { @@ -250,12 +250,12 @@ method_repr(PyMethodObject *a)  				return NULL;  			PyErr_Clear();  		} -		else if (!PyString_Check(klassname)) { +		else if (!PyUnicode_Check(klassname)) {  			Py_DECREF(klassname);  			klassname = NULL;  		}  		else -			sklassname = PyString_AS_STRING(klassname); +			sklassname = PyUnicode_AsString(klassname);  	}  	if (self == NULL)  		result = PyUnicode_FromFormat("<unbound method %s.%s>", | 
