diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2005-03-03 23:00:26 +0000 |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2005-03-03 23:00:26 +0000 |
commit | 1edf657ffa21ac594cf308c215a48bfb03cee769 (patch) | |
tree | a65e13f1ad74132c5450890601d7f930e5af88d3 | |
parent | 874a88863fe14c5d29c319dfc8eea665d9b91e13 (diff) | |
download | cpython-1edf657ffa21ac594cf308c215a48bfb03cee769.tar.gz |
Patch #1115086: support PY_LONGLONG in structmember.
-rw-r--r-- | Include/structmember.h | 4 | ||||
-rw-r--r-- | Misc/NEWS | 2 | ||||
-rw-r--r-- | Python/structmember.c | 32 |
3 files changed, 38 insertions, 0 deletions
diff --git a/Include/structmember.h b/Include/structmember.h index 015ca19c85..96d2331b04 100644 --- a/Include/structmember.h +++ b/Include/structmember.h @@ -65,6 +65,10 @@ typedef struct PyMemberDef { #define T_OBJECT_EX 16 /* Like T_OBJECT, but raises AttributeError when the value is NULL, instead of converting to None. */ +#ifdef HAVE_LONG_LONG +#define T_LONGLONG 17 +#define T_ULONGLONG 18 +#endif /* HAVE_LONG_LONG */ /* Flags */ #define READONLY 1 @@ -10,6 +10,8 @@ What's New in Python 2.5 alpha 1? Core and builtins ----------------- +- Patch #1115086: Support PY_LONGLONG in structmember. + - Bug #1155938: new style classes did not check that __init__() was returning None. diff --git a/Python/structmember.c b/Python/structmember.c index bbaaca8136..1574c95cf8 100644 --- a/Python/structmember.c +++ b/Python/structmember.c @@ -118,6 +118,14 @@ PyMember_GetOne(char *addr, PyMemberDef *l) PyErr_SetString(PyExc_AttributeError, l->name); Py_XINCREF(v); break; +#ifdef HAVE_LONG_LONG + case T_LONGLONG: + v = PyLong_FromLongLong(*(PY_LONG_LONG *)addr); + break; + case T_ULONGLONG: + v = PyLong_FromUnsignedLongLong(*(unsigned PY_LONG_LONG *)addr); + break; +#endif /* HAVE_LONG_LONG */ default: PyErr_SetString(PyExc_SystemError, "bad memberdescr type"); v = NULL; @@ -246,6 +254,30 @@ PyMember_SetOne(char *addr, PyMemberDef *l, PyObject *v) return -1; } break; +#ifdef HAVE_LONG_LONG + case T_LONGLONG: + if (!PyLong_Check(v)) { + PyErr_BadArgument(); + return -1; + } else { + *(PY_LONG_LONG*)addr = PyLong_AsLongLong(v); + if ((*addr == -1) && PyErr_Occurred()) { + return -1; + } + } + break; + case T_ULONGLONG: + if (!PyLong_Check(v)) { + PyErr_BadArgument(); + return -1; + } else { + *(unsigned PY_LONG_LONG*)addr = PyLong_AsUnsignedLongLong(v); + if ((*addr == -1) && PyErr_Occurred()) { + return -1; + } + } + break; +#endif /* HAVE_LONG_LONG */ default: PyErr_Format(PyExc_SystemError, "bad memberdescr type for %s", l->name); |