diff options
Diffstat (limited to 'Objects/intobject.c')
| -rw-r--r-- | Objects/intobject.c | 91 | 
1 files changed, 91 insertions, 0 deletions
| diff --git a/Objects/intobject.c b/Objects/intobject.c index 611aedf9f4..4b5dc55632 100644 --- a/Objects/intobject.c +++ b/Objects/intobject.c @@ -169,6 +169,51 @@ PyInt_AsLong(register PyObject *op)  		}  		else  		{ +			Py_DECREF(io); +			PyErr_SetString(PyExc_TypeError, +					"nb_int should return int object"); +			return -1; +		} +	} + +	val = PyInt_AS_LONG(io); +	Py_DECREF(io); + +	return val; +} + +unsigned long +PyInt_AsUnsignedLongMask(register PyObject *op) +{ +	PyNumberMethods *nb; +	PyIntObject *io; +	unsigned long val; + +	if (op && PyInt_Check(op)) +		return PyInt_AS_LONG((PyIntObject*) op); +	if (op && PyLong_Check(op)) +		return PyLong_AsUnsignedLongMask(op); + +	if (op == NULL || (nb = op->ob_type->tp_as_number) == NULL || +	    nb->nb_int == NULL) { +		PyErr_SetString(PyExc_TypeError, "an integer is required"); +		return -1; +	} + +	io = (PyIntObject*) (*nb->nb_int) (op); +	if (io == NULL) +		return -1; +	if (!PyInt_Check(io)) { +		if (PyLong_Check(io)) { +			val = PyLong_AsUnsignedLongMask((PyObject *)io); +			Py_DECREF(io); +			if (PyErr_Occurred()) +				return -1; +			return val; +		} +		else +		{ +			Py_DECREF(io);  			PyErr_SetString(PyExc_TypeError,  					"nb_int should return int object");  			return -1; @@ -181,6 +226,52 @@ PyInt_AsLong(register PyObject *op)  	return val;  } +#ifdef HAVE_LONG_LONG +unsigned PY_LONG_LONG +PyInt_AsUnsignedLongLongMask(register PyObject *op) +{ +	PyNumberMethods *nb; +	PyIntObject *io; +	unsigned PY_LONG_LONG val; + +	if (op && PyInt_Check(op)) +		return PyInt_AS_LONG((PyIntObject*) op); +	if (op && PyLong_Check(op)) +		return PyLong_AsUnsignedLongLongMask(op); + +	if (op == NULL || (nb = op->ob_type->tp_as_number) == NULL || +	    nb->nb_int == NULL) { +		PyErr_SetString(PyExc_TypeError, "an integer is required"); +		return -1; +	} + +	io = (PyIntObject*) (*nb->nb_int) (op); +	if (io == NULL) +		return -1; +	if (!PyInt_Check(io)) { +		if (PyLong_Check(io)) { +			val = PyLong_AsUnsignedLongLongMask((PyObject *)io); +			Py_DECREF(io); +			if (PyErr_Occurred()) +				return -1; +			return val; +		} +		else +		{ +			Py_DECREF(io); +			PyErr_SetString(PyExc_TypeError, +					"nb_int should return int object"); +			return -1; +		} +	} + +	val = PyInt_AS_LONG(io); +	Py_DECREF(io); + +	return val; +} +#endif +  PyObject *  PyInt_FromString(char *s, char **pend, int base)  { | 
