diff options
| author | Neal Norwitz <nnorwitz@gmail.com> | 2002-07-28 16:44:23 +0000 | 
|---|---|---|
| committer | Neal Norwitz <nnorwitz@gmail.com> | 2002-07-28 16:44:23 +0000 | 
| commit | 88fe4ff5a962dfd2e1889c5d5c1a04c00b8264ba (patch) | |
| tree | 05d2e9b3c79646242af9f55ec93fb31d81ae7d17 /Objects/stringobject.c | |
| parent | 673c0a2247e6c1bacdd87df1bc82e8b042933f4b (diff) | |
| download | cpython-git-88fe4ff5a962dfd2e1889c5d5c1a04c00b8264ba.tar.gz | |
Fix the problem of not raising a TypeError exception when doing:
    '%g' % '1'
    '%d' % '1'
Add a test for these conditions
Fix the test so that if not exception is raise, this is a failure
Diffstat (limited to 'Objects/stringobject.c')
| -rw-r--r-- | Objects/stringobject.c | 16 | 
1 files changed, 8 insertions, 8 deletions
| diff --git a/Objects/stringobject.c b/Objects/stringobject.c index 83421a944c..c40bc18579 100644 --- a/Objects/stringobject.c +++ b/Objects/stringobject.c @@ -3120,11 +3120,11 @@ formatfloat(char *buf, size_t buflen, int flags,  	   worst case length = 3 + 10 (len of INT_MAX) + 1 = 14 (use 20)*/  	char fmt[20];  	double x; -	v = PyNumber_Float(v); -	if (!v) +	x = PyFloat_AsDouble(v); +	if (x == -1.0 && PyErr_Occurred()) { +		PyErr_SetString(PyExc_TypeError, "float argument required");  		return -1; -	x = PyFloat_AS_DOUBLE(v); -	Py_DECREF(v); +	}  	if (prec < 0)  		prec = 6;  	if (type == 'f' && fabs(x)/1e25 >= 1e25) @@ -3299,11 +3299,11 @@ formatint(char *buf, size_t buflen, int flags,  	char fmt[64];	/* plenty big enough! */  	long x; -	v = PyNumber_Int(v); -	if (!v) +	x = PyInt_AsLong(v); +	if (x == -1 && PyErr_Occurred()) { +		PyErr_SetString(PyExc_TypeError, "int argument required");  		return -1; -	x = PyInt_AS_LONG(v); -	Py_DECREF(v); +	}  	if (prec < 0)  		prec = 1; | 
