[Python-checkins] r59854 - in python/trunk: Misc/NEWS Modules/_cursesmodule.c

andrew.kuchling python-checkins at python.org
Tue Jan 8 15:56:03 CET 2008


Author: andrew.kuchling
Date: Tue Jan 8 15:56:02 2008
New Revision: 59854
Modified:
 python/trunk/Misc/NEWS
 python/trunk/Modules/_cursesmodule.c
Log:
Patch 1114: fix compilation of curses module on 64-bit AIX, and any other LP64 platforms where attr_t isn't a C long
Modified: python/trunk/Misc/NEWS
==============================================================================
--- python/trunk/Misc/NEWS	(original)
+++ python/trunk/Misc/NEWS	Tue Jan 8 15:56:02 2008
@@ -1060,6 +1060,10 @@
 
 - Bug #1548092: fix curses.tparm seg fault on invalid input.
 
+- Patch #1114: fix curses module compilation on 64-bit AIX, & possibly
+ other 64-bit LP64 platforms where attr_t is not the same size as a long. 
+ (Contributed by Luke Mewburn.)
+
 - Bug #1550714: fix SystemError from itertools.tee on negative value for n.
 
 - Fixed a few bugs on cjkcodecs:
Modified: python/trunk/Modules/_cursesmodule.c
==============================================================================
--- python/trunk/Modules/_cursesmodule.c	(original)
+++ python/trunk/Modules/_cursesmodule.c	Tue Jan 8 15:56:02 2008
@@ -315,9 +315,6 @@
 Window_NoArg2TupleReturnFunction(getmaxyx, int, "ii")
 Window_NoArg2TupleReturnFunction(getparyx, int, "ii")
 
-Window_OneArgNoReturnFunction(wattron, attr_t, "l;attr")
-Window_OneArgNoReturnFunction(wattroff, attr_t, "l;attr")
-Window_OneArgNoReturnFunction(wattrset, attr_t, "l;attr")
 Window_OneArgNoReturnFunction(clearok, int, "i;True(1) or False(0)")
 Window_OneArgNoReturnFunction(idlok, int, "i;True(1) or False(0)")
 #if defined(__NetBSD__)
@@ -372,6 +369,7 @@
 PyObject *temp;
 chtype ch = 0;
 attr_t attr = A_NORMAL;
+ long lattr;
 
 switch (PyTuple_Size(args)) {
 case 1:
@@ -379,8 +377,9 @@
 	 return NULL;
 break;
 case 2:
- if (!PyArg_ParseTuple(args, "Ol;ch or int,attr", &temp, &attr))
+ if (!PyArg_ParseTuple(args, "Ol;ch or int,attr", &temp, &lattr))
 return NULL;
+ attr = lattr;
 break;
 case 3:
 if (!PyArg_ParseTuple(args,"iiO;y,x,ch or int", &y, &x, &temp))
@@ -389,8 +388,9 @@
 break;
 case 4:
 if (!PyArg_ParseTuple(args,"iiOl;y,x,ch or int, attr", 
-		 &y, &x, &temp, &attr))
+		 &y, &x, &temp, &lattr))
 return NULL;
+ attr = lattr;
 use_xy = TRUE;
 break;
 default:
@@ -418,6 +418,7 @@
 int x, y;
 char *str;
 attr_t attr = A_NORMAL , attr_old = A_NORMAL;
+ long lattr;
 int use_xy = FALSE, use_attr = FALSE;
 
 switch (PyTuple_Size(args)) {
@@ -426,8 +427,9 @@
 return NULL;
 break;
 case 2:
- if (!PyArg_ParseTuple(args,"sl;str,attr", &str, &attr))
+ if (!PyArg_ParseTuple(args,"sl;str,attr", &str, &lattr))
 return NULL;
+ attr = lattr;
 use_attr = TRUE;
 break;
 case 3:
@@ -436,8 +438,9 @@
 use_xy = TRUE;
 break;
 case 4:
- if (!PyArg_ParseTuple(args,"iisl;int,int,str,attr", &y, &x, &str, &attr))
+ if (!PyArg_ParseTuple(args,"iisl;int,int,str,attr", &y, &x, &str, &lattr))
 return NULL;
+ attr = lattr;
 use_xy = use_attr = TRUE;
 break;
 default:
@@ -464,6 +467,7 @@
 int rtn, x, y, n;
 char *str;
 attr_t attr = A_NORMAL , attr_old = A_NORMAL;
+ long lattr;
 int use_xy = FALSE, use_attr = FALSE;
 
 switch (PyTuple_Size(args)) {
@@ -472,8 +476,9 @@
 return NULL;
 break;
 case 3:
- if (!PyArg_ParseTuple(args,"sil;str,n,attr", &str, &n, &attr))
+ if (!PyArg_ParseTuple(args,"sil;str,n,attr", &str, &n, &lattr))
 return NULL;
+ attr = lattr;
 use_attr = TRUE;
 break;
 case 4:
@@ -482,8 +487,9 @@
 use_xy = TRUE;
 break;
 case 5:
- if (!PyArg_ParseTuple(args,"iisil;y,x,str,n,attr", &y, &x, &str, &n, &attr))
+ if (!PyArg_ParseTuple(args,"iisil;y,x,str,n,attr", &y, &x, &str, &n, &lattr))
 return NULL;
+ attr = lattr;
 use_xy = use_attr = TRUE;
 break;
 default:
@@ -510,6 +516,7 @@
 PyObject *temp;
 chtype bkgd;
 attr_t attr = A_NORMAL;
+ long lattr;
 
 switch (PyTuple_Size(args)) {
 case 1:
@@ -517,8 +524,9 @@
 return NULL;
 break;
 case 2:
- if (!PyArg_ParseTuple(args,"Ol;ch or int,attr", &temp, &attr))
+ if (!PyArg_ParseTuple(args,"Ol;ch or int,attr", &temp, &lattr))
 return NULL;
+ attr = lattr;
 break;
 default:
 PyErr_SetString(PyExc_TypeError, "bkgd requires 1 or 2 arguments");
@@ -534,11 +542,39 @@
 }
 
 static PyObject *
+PyCursesWindow_AttrOff(PyCursesWindowObject *self, PyObject *args)
+{
+ long lattr;
+ if (!PyArg_ParseTuple(args,"l;attr", &lattr))
+ return NULL;
+ return PyCursesCheckERR(wattroff(self->win, (attr_t)lattr), "attroff");
+}
+
+static PyObject *
+PyCursesWindow_AttrOn(PyCursesWindowObject *self, PyObject *args)
+{
+ long lattr;
+ if (!PyArg_ParseTuple(args,"l;attr", &lattr))
+ return NULL;
+ return PyCursesCheckERR(wattron(self->win, (attr_t)lattr), "attron");
+}
+
+static PyObject *
+PyCursesWindow_AttrSet(PyCursesWindowObject *self, PyObject *args)
+{
+ long lattr;
+ if (!PyArg_ParseTuple(args,"l;attr", &lattr))
+ return NULL;
+ return PyCursesCheckERR(wattrset(self->win, (attr_t)lattr), "attrset");
+}
+
+static PyObject *
 PyCursesWindow_BkgdSet(PyCursesWindowObject *self, PyObject *args)
 {
 PyObject *temp;
 chtype bkgd;
 attr_t attr = A_NORMAL;
+ long lattr;
 
 switch (PyTuple_Size(args)) {
 case 1:
@@ -546,8 +582,9 @@
 return NULL;
 break;
 case 2:
- if (!PyArg_ParseTuple(args,"Ol;ch or int,attr", &temp, &attr))
+ if (!PyArg_ParseTuple(args,"Ol;ch or int,attr", &temp, &lattr))
 return NULL;
+ attr = lattr;
 break;
 default:
 PyErr_SetString(PyExc_TypeError, "bkgdset requires 1 or 2 arguments");
@@ -735,6 +772,7 @@
 PyObject *temp;
 chtype ch;
 attr_t attr = A_NORMAL;
+ long lattr;
 
 switch (PyTuple_Size(args)) {
 case 1:
@@ -742,8 +780,9 @@
 return NULL;
 break;
 case 2:
- if (!PyArg_ParseTuple(args,"Ol;ch or int,attr", &temp, &attr))
+ if (!PyArg_ParseTuple(args,"Ol;ch or int,attr", &temp, &lattr))
 return NULL;
+ attr = lattr;
 break;
 default:
 PyErr_SetString(PyExc_TypeError, "echochar requires 1 or 2 arguments");
@@ -909,6 +948,7 @@
 chtype ch;
 int n, x, y, code = OK;
 attr_t attr = A_NORMAL;
+ long lattr;
 
 switch (PyTuple_Size(args)) {
 case 2:
@@ -916,8 +956,9 @@
 return NULL;
 break;
 case 3:
- if (!PyArg_ParseTuple(args, "Oil;ch or int,n,attr", &temp, &n, &attr))
+ if (!PyArg_ParseTuple(args, "Oil;ch or int,n,attr", &temp, &n, &lattr))
 return NULL;
+ attr = lattr;
 break;
 case 4:
 if (!PyArg_ParseTuple(args, "iiOi;y,x,ch or int,n", &y, &x, &temp, &n))
@@ -926,8 +967,9 @@
 break;
 case 5:
 if (!PyArg_ParseTuple(args, "iiOil; y,x,ch or int,n,attr", 
-		 &y, &x, &temp, &n, &attr))
+		 &y, &x, &temp, &n, &lattr))
 return NULL;
+ attr = lattr;
 code = wmove(self->win, y, x);
 break;
 default:
@@ -953,6 +995,7 @@
 PyObject *temp;
 chtype ch = 0;
 attr_t attr = A_NORMAL;
+ long lattr;
 
 switch (PyTuple_Size(args)) {
 case 1:
@@ -960,8 +1003,9 @@
 return NULL;
 break;
 case 2:
- if (!PyArg_ParseTuple(args, "Ol;ch or int,attr", &temp, &attr))
+ if (!PyArg_ParseTuple(args, "Ol;ch or int,attr", &temp, &lattr))
 return NULL;
+ attr = lattr;
 break;
 case 3:
 if (!PyArg_ParseTuple(args,"iiO;y,x,ch or int", &y, &x, &temp))
@@ -969,8 +1013,9 @@
 use_xy = TRUE;
 break;
 case 4:
- if (!PyArg_ParseTuple(args,"iiOl;y,x,ch or int, attr", &y, &x, &temp, &attr))
+ if (!PyArg_ParseTuple(args,"iiOl;y,x,ch or int, attr", &y, &x, &temp, &lattr))
 return NULL;
+ attr = lattr;
 use_xy = TRUE;
 break;
 default:
@@ -1055,6 +1100,7 @@
 int x, y;
 char *str;
 attr_t attr = A_NORMAL , attr_old = A_NORMAL;
+ long lattr;
 int use_xy = FALSE, use_attr = FALSE;
 
 switch (PyTuple_Size(args)) {
@@ -1063,8 +1109,9 @@
 return NULL;
 break;
 case 2:
- if (!PyArg_ParseTuple(args,"sl;str,attr", &str, &attr))
+ if (!PyArg_ParseTuple(args,"sl;str,attr", &str, &lattr))
 return NULL;
+ attr = lattr;
 use_attr = TRUE;
 break;
 case 3:
@@ -1073,8 +1120,9 @@
 use_xy = TRUE;
 break;
 case 4:
- if (!PyArg_ParseTuple(args,"iisl;y,x,str,attr", &y, &x, &str, &attr))
+ if (!PyArg_ParseTuple(args,"iisl;y,x,str,attr", &y, &x, &str, &lattr))
 return NULL;
+ attr = lattr;
 use_xy = use_attr = TRUE;
 break;
 default:
@@ -1101,6 +1149,7 @@
 int rtn, x, y, n;
 char *str;
 attr_t attr = A_NORMAL , attr_old = A_NORMAL;
+ long lattr;
 int use_xy = FALSE, use_attr = FALSE;
 
 switch (PyTuple_Size(args)) {
@@ -1109,8 +1158,9 @@
 return NULL;
 break;
 case 3:
- if (!PyArg_ParseTuple(args,"sil;str,n,attr", &str, &n, &attr))
+ if (!PyArg_ParseTuple(args,"sil;str,n,attr", &str, &n, &lattr))
 return NULL;
+ attr = lattr;
 use_attr = TRUE;
 break;
 case 4:
@@ -1119,8 +1169,9 @@
 use_xy = TRUE;
 break;
 case 5:
- if (!PyArg_ParseTuple(args,"iisil;y,x,str,n,attr", &y, &x, &str, &n, &attr))
+ if (!PyArg_ParseTuple(args,"iisil;y,x,str,n,attr", &y, &x, &str, &n, &lattr))
 return NULL;
+ attr = lattr;
 use_xy = use_attr = TRUE;
 break;
 default:
@@ -1436,6 +1487,7 @@
 chtype ch;
 int n, x, y, code = OK;
 attr_t attr = A_NORMAL;
+ long lattr;
 
 switch (PyTuple_Size(args)) {
 case 2:
@@ -1443,8 +1495,9 @@
 return NULL;
 break;
 case 3:
- if (!PyArg_ParseTuple(args, "Oil;ch or int,n,attr", &temp, &n, &attr))
+ if (!PyArg_ParseTuple(args, "Oil;ch or int,n,attr", &temp, &n, &lattr))
 return NULL;
+ attr = lattr;
 break;
 case 4:
 if (!PyArg_ParseTuple(args, "iiOi;y,x,ch or int,n", &y, &x, &temp, &n))
@@ -1453,8 +1506,9 @@
 break;
 case 5:
 if (!PyArg_ParseTuple(args, "iiOil; y,x,ch or int,n,attr", 
-		 &y, &x, &temp, &n, &attr))
+		 &y, &x, &temp, &n, &lattr))
 return NULL;
+ attr = lattr;
 code = wmove(self->win, y, x);
 break;
 default:
@@ -1477,9 +1531,9 @@
 	{"addch", (PyCFunction)PyCursesWindow_AddCh, METH_VARARGS},
 	{"addnstr", (PyCFunction)PyCursesWindow_AddNStr, METH_VARARGS},
 	{"addstr", (PyCFunction)PyCursesWindow_AddStr, METH_VARARGS},
-	{"attroff", (PyCFunction)PyCursesWindow_wattroff, METH_VARARGS},
-	{"attron", (PyCFunction)PyCursesWindow_wattron, METH_VARARGS},
-	{"attrset", (PyCFunction)PyCursesWindow_wattrset, METH_VARARGS},
+	{"attroff", (PyCFunction)PyCursesWindow_AttrOff, METH_VARARGS},
+	{"attron", (PyCFunction)PyCursesWindow_AttrOn, METH_VARARGS},
+	{"attrset", (PyCFunction)PyCursesWindow_AttrSet, METH_VARARGS},
 	{"bkgd", (PyCFunction)PyCursesWindow_Bkgd, METH_VARARGS},
 	{"chgat", (PyCFunction)PyCursesWindow_ChgAt, METH_VARARGS},
 	{"bkgdset", (PyCFunction)PyCursesWindow_BkgdSet, METH_VARARGS},


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /