summaryrefslogtreecommitdiffstats
path: root/Modules/_cursesmodule.c
diff options
context:
space:
mode:
authorAndrew M. Kuchling <amk@amk.ca>2000-05-23 16:18:03 (GMT)
committerAndrew M. Kuchling <amk@amk.ca>2000-05-23 16:18:03 (GMT)
commit22b88ce6bf8974b0d3852a36b511e0d047a996fe (patch)
tree630ff24ec1c6231477c50344c96ef9dfc674401a /Modules/_cursesmodule.c
parentcaee2fe35d36d496c37453e7642e481b689299b2 (diff)
downloadcpython-22b88ce6bf8974b0d3852a36b511e0d047a996fe.zip
cpython-22b88ce6bf8974b0d3852a36b511e0d047a996fe.tar.gz
cpython-22b88ce6bf8974b0d3852a36b511e0d047a996fe.tar.bz2
Oliver Andrich's ncurses-specific curses module, version 1.5b1
Diffstat (limited to 'Modules/_cursesmodule.c')
-rw-r--r--Modules/_cursesmodule.c2555
1 files changed, 1607 insertions, 948 deletions
diff --git a/Modules/_cursesmodule.c b/Modules/_cursesmodule.c
index d654b29..935f6c8 100644
--- a/Modules/_cursesmodule.c
+++ b/Modules/_cursesmodule.c
@@ -1,226 +1,83 @@
-/***********************************************************
-Copyright 1994 by Lance Ellinghouse,
-Cathedral City, California Republic, United States of America.
-
- All Rights Reserved
-
-Permission to use, copy, modify, and distribute this software and its
-documentation for any purpose and without fee is hereby granted,
-provided that the above copyright notice appear in all copies and that
-both that copyright notice and this permission notice appear in
-supporting documentation, and that the name of Lance Ellinghouse
-not be used in advertising or publicity pertaining to distribution
-of the software without specific, written prior permission.
-
-LANCE ELLINGHOUSE DISCLAIMS ALL WARRANTIES WITH REGARD TO
-THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
-FITNESS, IN NO EVENT SHALL LANCE ELLINGHOUSE BE LIABLE FOR ANY SPECIAL,
-INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING
-FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
-NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
-WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-
-******************************************************************/
-
-/******************************************************************
-This is a curses implementation. I have tried to be as complete
-as possible. If there are functions you need that are not included,
-please let me know and/or send me some diffs.
-
-There are 3 basic types exported by this module:
- 1) Screen - This is not currently used
- 2) Window - This is the basic type. This is equivalent to "WINDOW *".
- 3) Pad - This is similar to Window, but works with Pads as defined
- in curses.
-
-Most of the routines can be looked up using the curses man page.
-
-Here is a list of the currently supported methods and attributes
-in the curses module:
-
-Return Value Func/Attr Description
---------------------------------------------------------------------------
-StringObject version A string representing the current
- version of this module.
-WindowObject initscr() This initializes the screen for use
-None endwin() Closes down the screen and returns
- things as they were before calling
- initscr()
-True/FalseObject isendwin() Has endwin() been called?
-None doupdate() Updates screen
-WindowObject newwin(nlines,ncols,begin_y,begin_x)
- newwin(begin_y,begin_x)
- newwin() creates and returns
- a new window.
-None beep() Beep the screen if possible
-None flash() Flash the screen if possible
-None ungetch(int) Push the int back so next getch()
- will return it.
- Note: argument is an INT, not a CHAR
-None flushinp() Flush all input buffers
-None cbreak() Enter cbreak mode
-None nocbreak() Leave cbreak mode
-None echo() Enter echo mode
-None noecho() Leave echo mode
-None nl() Enter nl mode
-None nonl() Leave nl mode
-None raw() Enter raw mode
-None noraw() Leave raw mode
-None intrflush(int) Set or reset interruptable flush
- mode, int=1 if set, 0 if notset.
-None meta(int) Allow 8 bit or 7 bit chars.
- int=1 is 8 bit, int=0 is 7 bit
-StringObject keyname(int) return the text representation
- of a KEY_ value. (see below)
-
-Here is a list of the currently supported methods and attributes
-in the WindowObject:
-
-Return Value Func/Attr Description
---------------------------------------------------------------------------
-None refresh() Do refresh
-None nooutrefresh() Mark for refresh but wait
-None mvwin(new_y,new_x) Move Window
-None move(new_y,new_x) Move Cursor
-WindowObject subwin(nlines,ncols,begin_y,begin_x)
- subwin(begin_y,begin_x)
-None addch(y,x,ch,attr)
- addch(y,x,ch)
- addch(ch,attr)
- addch(ch)
-None insch(y,x,ch,attr)
- insch(y,x,ch)
- insch(ch,attr)
- insch(ch)
-None delch(y,x)
- delch()
-None echochar(ch,attr)
- echochar(ch)
-None addstr(y,x,str,attr)
- addstr(y,x,str)
- addstr(str,attr)
- addstr(str)
-None attron(attr)
-None attroff(attr)
-None attrset(sttr)
-None standend()
-None standout()
-None border(ls,rs,ts,bs,tl,tr,bl,br) (accepts 0-8 INT args)
-None box(vertch,horch) vertch and horch are INTS
- box()
-None hline(y,x,ch,n)
- hline(ch,n)
-None vline(y,x,ch,n)
- vline(ch,n)
-None erase()
-None deleteln()
-None insertln()
-(y,x) getyx()
-(y,x) getbegyx()
-(y,x) getmaxyx()
-None clear()
-None clrtobot()
-None clrtoeol()
-None scroll()
- scroll(nlines)
-None touchwin()
-None touchline(start,count)
-IntObject getch(y,x)
- getch()
-StringObject getstr(y,x)
- getstr()
-IntObject inch(y,x)
- inch()
-None clearok(int) int=0 or int=1
-None idlok(int) int=0 or int=1
-None leaveok(int) int=0 or int=1
-None scrollok(int) int=0 or int=1
-None setscrreg(top,bottom)
-None keypad(int) int=0 or int=1
-None nodelay(int) int=0 or int=1
-None notimeout(int) int=0 or int=1
-******************************************************************/
-
-
-/* curses module */
+/*
+ * This is a curses implementation for Python.
+ *
+ * Based on a prior work by Lance Ellinghaus
+ * (version 1.2 of this module
+ * Copyright 1994 by Lance Ellinghouse,
+ * Cathedral City, California Republic, United States of America.)
+ * Updated, fixed and heavily extended by Oliver Andrich
+ *
+ * Copyright 1996,1997 by Oliver Andrich,
+ * Koblenz, Germany
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining
+ * a copy of this source file to use, copy, modify, merge, or publish it
+ * subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included
+ * in all copies or in any new file that contains a substantial portion of
+ * this file.
+ *
+ * THE AUTHOR MAKES NO REPRESENTATIONS ABOUT THE SUITABILITY OF
+ * THE SOFTWARE FOR ANY PURPOSE. IT IS PROVIDED "AS IS" WITHOUT
+ * EXPRESS OR IMPLIED WARRANTY. THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES
+ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NON-INFRINGEMENT OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE
+ * AUTHOR BE LIABLE TO YOU OR ANY OTHER PARTY FOR ANY SPECIAL,
+ * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
+ * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE, STRICT LIABILITY OR
+ * ANY OTHER ACTION ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+ * PERFORMANCE OF THIS SOFTWARE.
+ */
-#include "Python.h"
+/* CVS: $Id$ */
-#ifdef HAVE_NCURSES_H
-/* Now let's hope there aren't systems that have a broken ncurses.h */
-#include <ncurses.h>
-#else
-#include <curses.h>
-#endif
+/* Release Number */
-typedef struct {
- PyObject_HEAD
- SCREEN *scr;
-} PyCursesScreenObject;
+char *PyCursesVersion = "1.5b1";
-typedef struct {
- PyObject_HEAD
- WINDOW *win;
- WINDOW *parent;
-} PyCursesWindowObject;
+/* Includes */
-typedef struct {
- PyObject_HEAD
- WINDOW *pad;
-} PyCursesPadObject;
+#include "Python.h"
+#include <curses.h>
-#if 0
-staticforward PyTypeObject PyCursesScreen_Type;
-#endif
-staticforward PyTypeObject PyCursesWindow_Type;
-#if 0
-staticforward PyTypeObject PyCursesPad_Type;
+#ifdef __sgi__
+ /* No attr_t type is available */
+typedef chtype attr_t;
#endif
-#define PyCursesScreen_Check(v) ((v)->ob_type == &PyCursesScreen_Type)
-#define PyCursesWindow_Check(v) ((v)->ob_type == &PyCursesWindow_Type)
-#define PyCursesPad_Check(v) ((v)->ob_type == &PyCursesPad_Type)
+/* Definition of exception curses.error */
-/* Defines */
-static PyObject *PyCursesError; /* For exception curses.error */
+static PyObject *PyCursesError;
-/* Catch-all error messages */
+/* general error messages */
static char *catchall_ERR = "curses function returned ERR";
static char *catchall_NULL = "curses function returned NULL";
-/* Tells whether initscr() has been called to initialise curses */
+/* Tells whether initscr() has been called to initialise curses. */
static int initialised = FALSE;
+/* Tells whether start_color() has been called to initialise colorusage. */
+static int initialisedcolors = FALSE;
+
+/* Utility Macros */
#define ARG_COUNT(X) \
(((X) == NULL) ? 0 : (PyTuple_Check(X) ? PyTuple_Size(X) : 1))
-/******************************************************************
-
-Change Log:
-
-Version 1.2: 95/02/23 (Steve Clift)
- Fixed several potential core-dumping bugs.
- Reworked arg parsing where variable arg lists are used.
- Generate exceptions when ERR or NULL is returned by curses functions.
- Changed return types to match SysV Curses manual descriptions.
- Added keypad() to window method list.
- Added border(), hline() and vline() window methods.
-
-Version 1.1: 94/08/31:
- Minor fixes given by Guido.
- Changed 'ncurses' to 'curses'
- Changed '__version__' to 'version'
- Added PyErr_Clear() where needed
- Moved ACS_* attribute initialization to PyCurses_InitScr() to fix
- crash on SGI
+#define PyCursesInitialised \
+ if (initialised != TRUE) { \
+ PyErr_SetString(PyCursesError, \
+ "must call initscr() first"); \
+ return NULL; }
-Version 1.0: 94/08/30:
- This is the first release of this software.
- Released to the Internet via python-list@cwi.nl
+#define PyCursesInitialisedColor \
+ if (initialisedcolors != TRUE) { \
+ PyErr_SetString(PyCursesError, \
+ "must call start_color() first"); \
+ return NULL; }
-******************************************************************/
-
-static char *PyCursesVersion = "1.2";
+/* Utility Functions */
/*
* Check the return code from a curses function and return None
@@ -249,51 +106,162 @@ PyCursesCheckERR(code, fname)
}
}
-
-static int
-PyCursesInitialised()
+int
+PyCurses_ConvertToChtype(obj, ch)
+ PyObject *obj;
+ chtype *ch;
{
- if (initialised == TRUE)
- return 1;
- else {
- PyErr_SetString(PyCursesError, "must call initscr() first");
+ if (PyInt_Check(obj)) {
+ *ch = (chtype) PyInt_AsLong(obj);
+ } else if(PyString_Check(obj) &
+ (PyString_Size(obj) == 1)) {
+ *ch = (chtype) *PyString_AsString(obj);
+ } else {
return 0;
}
+ return 1;
}
+/*****************************************************************************
+ The Window Object
+******************************************************************************/
-/* ------------- SCREEN routines --------------- */
+/* Definition of the window object and window type */
-#ifdef NOT_YET
-static PyObject *
-PyCursesScreen_New(arg)
- PyObject * arg;
-{
- char *term_type;
- PyFileObject *in_fo;
- PyFileObject *out_fo;
- PyCursesScreenObject *xp;
- xp = PyObject_New(PyCursesScreenObject, &PyCursesScreen_Type);
- if (xp == NULL)
- return NULL;
- return (PyObject *)xp;
-}
-#endif
+typedef struct {
+ PyObject_HEAD
+ WINDOW *win;
+} PyCursesWindowObject;
+PyTypeObject PyCursesWindow_Type;
+
+#define PyCursesWindow_Check(v) ((v)->ob_type == &PyCursesWindow_Type)
+
+/* Function Prototype Macros - They are ugly but very, very useful. ;-)
+
+ X - function name
+ TYPE - parameter Type
+ ERGSTR - format string for construction of the return value
+ PARSESTR - format string for argument parsing
+ */
+
+#define Window_NoArgNoReturnFunction(X) \
+static PyObject *PyCursesWindow_ ## X (self, arg) \
+ PyCursesWindowObject * self; PyObject * arg; \
+{ if (!PyArg_NoArgs(arg)) return NULL; \
+ return PyCursesCheckERR(X(self->win), # X); }
+
+#define Window_NoArgTrueFalseFunction(X) \
+static PyObject * PyCursesWindow_ ## X (self,arg) \
+ PyCursesWindowObject * self; PyObject * arg; \
+{ \
+ if (!PyArg_NoArgs(arg)) return NULL; \
+ if (X (self->win) == FALSE) { Py_INCREF(Py_False); return Py_False; } \
+ else { Py_INCREF(Py_True); return Py_True; } }
+
+#define Window_NoArgNoReturnVoidFunction(X) \
+static PyObject * PyCursesWindow_ ## X (self,arg) \
+ PyCursesWindowObject * self; \
+ PyObject * arg; \
+{ \
+ if (!PyArg_NoArgs(arg)) return NULL; \
+ X(self->win); Py_INCREF(Py_None); return Py_None; }
+
+#define Window_NoArg2TupleReturnFunction(X, TYPE, ERGSTR) \
+static PyObject * PyCursesWindow_ ## X (self, arg) \
+ PyCursesWindowObject *self; \
+ PyObject * arg; \
+{ \
+ TYPE arg1, arg2; \
+ if (!PyArg_NoArgs(arg)) return NULL; \
+ X(self->win,arg1,arg2); return Py_BuildValue(ERGSTR, arg1, arg2); }
+
+#define Window_OneArgNoReturnVoidFunction(X, TYPE, PARSESTR) \
+static PyObject * PyCursesWindow_ ## X (self, arg) \
+ PyCursesWindowObject *self; \
+ PyObject * arg; \
+{ \
+ TYPE arg1; \
+ if (!PyArg_Parse(arg, PARSESTR, &arg1)) return NULL; \
+ X(self->win,arg1); Py_INCREF(Py_None); return Py_None; }
+
+#define Window_OneArgNoReturnFunction(X, TYPE, PARSESTR) \
+static PyObject * PyCursesWindow_ ## X (self, arg) \
+ PyCursesWindowObject *self; \
+ PyObject * arg; \
+{ \
+ TYPE arg1; \
+ if (!PyArg_Parse(arg,PARSESTR, &arg1)) return NULL; \
+ return PyCursesCheckERR(X(self->win, arg1), # X); }
+
+#define Window_TwoArgNoReturnFunction(X, TYPE, PARSESTR) \
+static PyObject * PyCursesWindow_ ## X (self, arg) \
+ PyCursesWindowObject *self; \
+ PyObject * arg; \
+{ \
+ TYPE arg1, arg2; \
+ if (!PyArg_Parse(arg,PARSESTR, &arg1, &arg2)) return NULL; \
+ return PyCursesCheckERR(X(self->win, arg1, arg2), # X); }
/* ------------- WINDOW routines --------------- */
+Window_NoArgNoReturnFunction(untouchwin)
+Window_NoArgNoReturnFunction(touchwin)
+Window_NoArgNoReturnFunction(redrawwin)
+Window_NoArgNoReturnFunction(winsertln)
+Window_NoArgNoReturnFunction(werase)
+Window_NoArgNoReturnFunction(wdeleteln)
+
+Window_NoArgTrueFalseFunction(is_wintouched)
+
+Window_NoArgNoReturnVoidFunction(wsyncup)
+Window_NoArgNoReturnVoidFunction(wsyncdown)
+Window_NoArgNoReturnVoidFunction(wstandend)
+Window_NoArgNoReturnVoidFunction(wstandout)
+Window_NoArgNoReturnVoidFunction(wcursyncup)
+Window_NoArgNoReturnVoidFunction(wclrtoeol)
+Window_NoArgNoReturnVoidFunction(wclrtobot)
+Window_NoArgNoReturnVoidFunction(wclear)
+
+Window_OneArgNoReturnVoidFunction(idcok, int, "i;True(1) or False(0)")
+Window_OneArgNoReturnVoidFunction(immedok, int, "i;True(1) or False(0)")
+
+Window_NoArg2TupleReturnFunction(getyx, int, "(ii)")
+Window_NoArg2TupleReturnFunction(getbegyx, int, "(ii)")
+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)")
+Window_OneArgNoReturnFunction(keypad, int, "i;True(1) or False(0)")
+Window_OneArgNoReturnFunction(leaveok, int, "i;True(1) or False(0)")
+Window_OneArgNoReturnFunction(nodelay, int, "i;True(1) or False(0)")
+Window_OneArgNoReturnFunction(notimeout, int, "i;True(1) or False(0)")
+Window_OneArgNoReturnFunction(scrollok, int, "i;True(1) or False(0)")
+Window_OneArgNoReturnFunction(winsdelln, int, "i;cnt")
+Window_OneArgNoReturnFunction(syncok, int, "i;True(1) or False(0)")
+
+Window_TwoArgNoReturnFunction(mvwin, int, "(ii);y,x")
+Window_TwoArgNoReturnFunction(mvderwin, int, "(ii);y,x")
+Window_TwoArgNoReturnFunction(wmove, int, "(ii);y,x")
+#ifndef __sgi__
+Window_TwoArgNoReturnFunction(wresize, int, "(ii);lines,columns")
+#endif
+
+/* Allocation and Deallocation of Window Objects */
+
static PyObject *
PyCursesWindow_New(win)
WINDOW *win;
{
PyCursesWindowObject *wo;
- wo = PyObject_New(PyCursesWindowObject, &PyCursesWindow_Type);
- if (wo == NULL)
- return NULL;
+ wo = PyObject_NEW(PyCursesWindowObject, &PyCursesWindow_Type);
+ if (wo == NULL) return NULL;
wo->win = win;
- wo->parent = (WINDOW *)NULL;
return (PyObject *)wo;
}
@@ -301,186 +269,249 @@ static void
PyCursesWindow_Dealloc(wo)
PyCursesWindowObject *wo;
{
- if (wo->win != stdscr)
- delwin(wo->win);
- PyObject_Del(wo);
+ if (wo->win != stdscr) delwin(wo->win);
+ PyMem_DEL(wo);
}
-static PyObject *
-PyCursesWindow_Refresh(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- if (!PyArg_NoArgs(arg))
- return NULL;
- return PyCursesCheckERR(wrefresh(self->win), "wrefresh");
-}
+/* Addch, Addstr, Addnstr */
static PyObject *
-PyCursesWindow_NoOutRefresh(self,arg)
+PyCursesWindow_AddCh(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg))
+ int rtn, x, y, use_xy = FALSE;
+ PyObject *temp;
+ chtype ch = 0;
+ attr_t attr = A_NORMAL;
+
+ switch (ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg, "O;ch or int", &temp))
+ return NULL;
+ break;
+ case 2:
+ if (!PyArg_Parse(arg, "(Ol);ch or int,attr", &temp, &attr))
+ return NULL;
+ break;
+ case 3:
+ if (!PyArg_Parse(arg,"(iiO);y,x,ch or int", &y, &x, &temp))
+ return NULL;
+ use_xy = TRUE;
+ break;
+ case 4:
+ if (!PyArg_Parse(arg,"(iiOl);y,x,ch or int, attr",
+ &y, &x, &temp, &attr))
+ return NULL;
+ use_xy = TRUE;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "addch requires 1 or 4 arguments");
return NULL;
- return PyCursesCheckERR(wnoutrefresh(self->win), "wnoutrefresh");
-}
+ }
-static PyObject *
-PyCursesWindow_MoveWin(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- int x, y;
- if (!PyArg_Parse(arg,"(ii);y,x", &y, &x))
+ if (!PyCurses_ConvertToChtype(temp, &ch)) {
+ PyErr_SetString(PyExc_TypeError, "argument 1 or 3 must be a ch or an int");
return NULL;
- return PyCursesCheckERR(mvwin(self->win,y,x), "mvwin");
+ }
+
+ if (use_xy == TRUE)
+ rtn = mvwaddch(self->win,y,x, ch | attr);
+ else {
+ rtn = waddch(self->win, ch | attr);
+ }
+ return PyCursesCheckERR(rtn, "addch");
}
static PyObject *
-PyCursesWindow_Move(self,arg)
+PyCursesWindow_AddStr(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
+ int rtn;
int x, y;
- if (!PyArg_Parse(arg,"(ii);y,x", &y, &x))
+ char *str;
+ attr_t attr = A_NORMAL , attr_old = A_NORMAL;
+ int use_xy = FALSE, use_attr = FALSE;
+
+ switch (ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg,"s;str", &str))
+ return NULL;
+ break;
+ case 2:
+ if (!PyArg_Parse(arg,"(sl);str,attr", &str, &attr))
+ return NULL;
+ use_attr = TRUE;
+ break;
+ case 3:
+ if (!PyArg_Parse(arg,"(iis);int,int,str", &y, &x, &str))
+ return NULL;
+ use_xy = TRUE;
+ break;
+ case 4:
+ if (!PyArg_Parse(arg,"(iisl);int,int,str,attr", &y, &x, &str, &attr))
+ return NULL;
+ use_xy = use_attr = TRUE;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "addstr requires 1 to 4 arguments");
return NULL;
- return PyCursesCheckERR(wmove(self->win,y,x), "wmove");
+ }
+
+ if (use_attr == TRUE) {
+ attr_old = getattrs(self->win);
+ wattrset(self->win,attr);
+ }
+ if (use_xy == TRUE)
+ rtn = mvwaddstr(self->win,y,x,str);
+ else
+ rtn = waddstr(self->win,str);
+ if (use_attr == TRUE)
+ wattrset(self->win,attr_old);
+ return PyCursesCheckERR(rtn, "addstr");
}
static PyObject *
-PyCursesWindow_SubWin(self,arg)
+PyCursesWindow_AddNStr(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- WINDOW *win;
- PyCursesWindowObject *rtn_win;
- int nlines, ncols, begin_y, begin_x;
+ int rtn, x, y, n;
+ char *str;
+ attr_t attr = A_NORMAL , attr_old = A_NORMAL;
+ int use_xy = FALSE, use_attr = FALSE;
- nlines = 0;
- ncols = 0;
switch (ARG_COUNT(arg)) {
case 2:
- if (!PyArg_Parse(arg,"(ii);begin_y,begin_x",&begin_y,&begin_x))
+ if (!PyArg_Parse(arg,"(si);str,n", &str, &n))
return NULL;
break;
+ case 3:
+ if (!PyArg_Parse(arg,"(sil);str,n,attr", &str, &n, &attr))
+ return NULL;
+ use_attr = TRUE;
+ break;
case 4:
- if (!PyArg_Parse(arg, "(iiii);nlines,ncols,begin_y,begin_x",
- &nlines,&ncols,&begin_y,&begin_x))
+ if (!PyArg_Parse(arg,"(iisi);y,x,str,n", &y, &x, &str, &n))
+ return NULL;
+ use_xy = TRUE;
+ break;
+ case 5:
+ if (!PyArg_Parse(arg,"(iisil);y,x,str,n,attr", &y, &x, &str, &n, &attr))
return NULL;
+ use_xy = use_attr = TRUE;
break;
default:
- PyErr_SetString(PyExc_TypeError, "subwin requires 2 or 4 arguments");
+ PyErr_SetString(PyExc_TypeError, "addnstr requires 2 to 5 arguments");
return NULL;
}
- win = subwin(self->win,nlines,ncols,begin_y,begin_x);
- if (win == NULL) {
- PyErr_SetString(PyCursesError, catchall_NULL);
- return NULL;
+
+ if (use_attr == TRUE) {
+ attr_old = getattrs(self->win);
+ wattrset(self->win,attr);
}
- rtn_win = (PyCursesWindowObject *)PyCursesWindow_New(win);
- rtn_win->parent = self->win;
- return (PyObject *)rtn_win;
+ if (use_xy == TRUE)
+ rtn = mvwaddnstr(self->win,y,x,str,n);
+ else
+ rtn = waddnstr(self->win,str,n);
+ if (use_attr == TRUE)
+ wattrset(self->win,attr_old);
+ return PyCursesCheckERR(rtn, "addnstr");
}
static PyObject *
-PyCursesWindow_AddCh(self,arg)
+PyCursesWindow_Bkgd(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int rtn;
- int x, y;
- int ch;
- int attr, attr_old = 0;
- int use_xy = FALSE, use_attr = FALSE;
+ PyObject *temp;
+ chtype bkgd;
+ attr_t attr = A_NORMAL;
switch (ARG_COUNT(arg)) {
case 1:
- if (!PyArg_Parse(arg, "i;ch", &ch))
+ if (!PyArg_Parse(arg, "O;ch or int", &temp))
return NULL;
break;
case 2:
- if (!PyArg_Parse(arg,"(ii);ch,attr", &ch, &attr))
- return NULL;
- use_attr = TRUE;
- break;
- case 3:
- if (!PyArg_Parse(arg,"(iii);y,x,ch", &y, &x, &ch))
+ if (!PyArg_Parse(arg,"(Ol);ch or int,attr", &temp, &attr))
return NULL;
- use_xy = TRUE;
- break;
- case 4:
- if (!PyArg_Parse(arg,"(iiii);y,x,ch,attr", &y, &x, &ch, &attr))
- return NULL;
- use_xy = use_attr = TRUE;
break;
default:
- PyErr_SetString(PyExc_TypeError, "addch requires 1 to 4 arguments");
+ PyErr_SetString(PyExc_TypeError, "bkgd requires 1 or 2 arguments");
return NULL;
}
- if (use_attr == TRUE) {
- attr_old = getattrs(self->win);
- wattrset(self->win,attr);
+ if (!PyCurses_ConvertToChtype(temp, &bkgd)) {
+ PyErr_SetString(PyExc_TypeError, "argument 1 or 3 must be a ch or an int");
+ return NULL;
}
- if (use_xy == TRUE)
- rtn = mvwaddch(self->win,y,x,ch);
- else
- rtn = waddch(self->win,ch);
- if (use_attr == TRUE)
- wattrset(self->win,attr_old);
- return PyCursesCheckERR(rtn, "[mv]waddch");
+ return PyCursesCheckERR(wbkgd(self->win, bkgd | A_NORMAL), "bkgd");
}
static PyObject *
-PyCursesWindow_InsCh(self,arg)
+PyCursesWindow_BkgdSet(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int rtn;
- int x, y;
- int ch;
- int attr, attr_old = 0;
- int use_xy = TRUE, use_attr = FALSE;
+ PyObject *temp;
+ chtype bkgd;
+ attr_t attr = A_NORMAL;
switch (ARG_COUNT(arg)) {
case 1:
- if (!PyArg_Parse(arg, "i;ch", &ch))
+ if (!PyArg_Parse(arg, "O;ch or int", &temp))
return NULL;
break;
case 2:
- if (!PyArg_Parse(arg,"(ii);ch,attr", &ch, &attr))
- return NULL;
- use_attr = TRUE;
- break;
- case 3:
- if (!PyArg_Parse(arg,"(iii);y,x,ch", &y, &x, &ch))
- return NULL;
- use_xy = TRUE;
- break;
- case 4:
- if (!PyArg_Parse(arg,"(iiii);y,x,ch,attr", &y, &x, &ch, &attr))
+ if (!PyArg_Parse(arg,"(Ol);ch or int,attr", &temp, &attr))
return NULL;
- use_xy = use_attr = TRUE;
break;
default:
- PyErr_SetString(PyExc_TypeError, "insch requires 1 to 4 arguments");
+ PyErr_SetString(PyExc_TypeError, "bkgdset requires 1 or 2 arguments");
return NULL;
}
- if (use_attr == TRUE) {
- attr_old = getattrs(self->win);
- wattrset(self->win,attr);
+ if (!PyCurses_ConvertToChtype(temp, &bkgd)) {
+ PyErr_SetString(PyExc_TypeError, "argument 1 or 3 must be a ch or an int");
+ return NULL;
}
- if (use_xy == TRUE)
- rtn = mvwinsch(self->win,y,x,ch);
- else
- rtn = winsch(self->win,ch);
- if (use_attr == TRUE)
- wattrset(self->win,attr_old);
- return PyCursesCheckERR(rtn, "[mv]winsch");
+ wbkgdset(self->win, bkgd | attr);
+ return PyCursesCheckERR(0, "bkgdset");
+}
+
+static PyObject *
+PyCursesWindow_Border(self, args)
+ PyCursesWindowObject *self;
+ PyObject *args;
+{
+ chtype ls, rs, ts, bs, tl, tr, bl, br;
+ ls = rs = ts = bs = tl = tr = bl = br = 0;
+ if (!PyArg_Parse(args,"|llllllll;ls,rs,ts,bs,tl,tr,bl,br",
+ &ls, &rs, &ts, &bs, &tl, &tr, &bl, &br))
+ return NULL;
+ wborder(self->win, ls, rs, ts, bs, tl, tr, bl, br);
+ Py_INCREF(Py_None);
+ return Py_None;
+}
+
+static PyObject *
+PyCursesWindow_Box(self,arg)
+ PyCursesWindowObject *self;
+ PyObject * arg;
+{
+ chtype ch1=0,ch2=0;
+ if (!PyArg_NoArgs(arg)) {
+ PyErr_Clear();
+ if (!PyArg_Parse(arg,"(ll);vertint,horint", &ch1, &ch2))
+ return NULL;
+ }
+ box(self->win,ch1,ch2);
+ Py_INCREF(Py_None);
+ return Py_None;
}
static PyObject *
@@ -504,512 +535,550 @@ PyCursesWindow_DelCh(self,arg)
PyErr_SetString(PyExc_TypeError, "delch requires 0 or 2 arguments");
return NULL;
}
-
return PyCursesCheckERR(rtn, "[mv]wdelch");
}
static PyObject *
-PyCursesWindow_EchoChar(self,arg)
+PyCursesWindow_DerWin(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int rtn;
- int ch;
- int attr, attr_old;
+ WINDOW *win;
+ int nlines, ncols, begin_y, begin_x;
+ nlines = 0;
+ ncols = 0;
switch (ARG_COUNT(arg)) {
- case 1:
- if (!PyArg_Parse(arg,"i;ch", &ch))
+ case 2:
+ if (!PyArg_Parse(arg,"(ii);begin_y,begin_x",&begin_y,&begin_x))
return NULL;
- rtn = wechochar(self->win,ch);
break;
- case 2:
- if (!PyArg_Parse(arg,"(ii);ch,attr", &ch, &attr))
+ case 4:
+ if (!PyArg_Parse(arg, "(iiii);nlines,ncols,begin_y,begin_x",
+ &nlines,&ncols,&begin_y,&begin_x))
return NULL;
- attr_old = getattrs(self->win);
- wattrset(self->win,attr);
- rtn = wechochar(self->win,ch);
- wattrset(self->win,attr_old);
break;
default:
- PyErr_SetString(PyExc_TypeError, "echochar requires 1 or 2 arguments");
+ PyErr_SetString(PyExc_TypeError, "derwin requires 2 or 4 arguments");
+ return NULL;
+ }
+
+ win = derwin(self->win,nlines,ncols,begin_y,begin_x);
+
+ if (win == NULL) {
+ PyErr_SetString(PyCursesError, catchall_NULL);
return NULL;
}
- return PyCursesCheckERR(rtn, "wechochar");
+ return (PyObject *)PyCursesWindow_New(win);
}
static PyObject *
-PyCursesWindow_AddStr(self,arg)
+PyCursesWindow_EchoChar(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int rtn;
- int x, y;
- char *str;
- int attr, attr_old = 0;
- int use_xy = FALSE, use_attr = FALSE;
+ PyObject *temp;
+ chtype ch;
+ attr_t attr = A_NORMAL;
switch (ARG_COUNT(arg)) {
case 1:
- if (!PyArg_Parse(arg,"s;str", &str))
+ if (!PyArg_Parse(arg,"O;ch or int", &temp))
return NULL;
break;
case 2:
- if (!PyArg_Parse(arg,"(si);str,attr", &str, &attr))
+ if (!PyArg_Parse(arg,"(Ol);ch or int,attr", &temp, &attr))
return NULL;
- use_attr = TRUE;
- break;
- case 3:
- if (!PyArg_Parse(arg,"(iis);y,x,str", &y, &x, &str))
- return NULL;
- use_xy = TRUE;
- break;
- case 4:
- if (!PyArg_Parse(arg,"(iisi);y,x,str,attr", &y, &x, &str, &attr))
- return NULL;
- use_xy = use_attr = TRUE;
break;
default:
- PyErr_SetString(PyExc_TypeError, "addstr requires 1 to 4 arguments");
+ PyErr_SetString(PyExc_TypeError, "echochar requires 1 or 2 arguments");
+
+
return NULL;
}
- if (use_attr == TRUE) {
- attr_old = getattrs(self->win);
- wattrset(self->win,attr);
+ if (!PyCurses_ConvertToChtype(temp, &ch)) {
+ PyErr_SetString(PyExc_TypeError, "argument 1 must be a ch or an int");
+ return NULL;
}
- if (use_xy == TRUE)
- rtn = mvwaddstr(self->win,y,x,str);
+
+ if (self->win->_flags & _ISPAD)
+ return PyCursesCheckERR(pechochar(self->win, ch | attr),
+ "echochar");
else
- rtn = waddstr(self->win,str);
- if (use_attr == TRUE)
- wattrset(self->win,attr_old);
-
- return PyCursesCheckERR(rtn, "[mv]waddstr");
+ return PyCursesCheckERR(wechochar(self->win, ch | attr),
+ "echochar");
}
static PyObject *
-PyCursesWindow_AttrOn(self,arg)
+PyCursesWindow_GetBkgd(self, arg)
PyCursesWindowObject *self;
- PyObject * arg;
+ PyObject *arg;
{
- int ch;
- if (!PyArg_Parse(arg,"i;attr", &ch))
- return NULL;
- wattron(self->win,ch);
- Py_INCREF(Py_None);
- return Py_None;
+ if (!PyArg_NoArgs(arg))
+ return NULL;
+ return PyInt_FromLong((long) getbkgd(self->win));
}
static PyObject *
-PyCursesWindow_AttrOff(self,arg)
+PyCursesWindow_GetCh(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int ch;
- if (!PyArg_Parse(arg,"i;attr", &ch))
- return NULL;
- wattroff(self->win,ch);
- Py_INCREF(Py_None);
- return Py_None;
-}
+ int x, y;
+ chtype rtn;
-static PyObject *
-PyCursesWindow_AttrSet(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- int ch;
- if (!PyArg_Parse(arg,"i;attr", &ch))
+ switch (ARG_COUNT(arg)) {
+ case 0:
+ rtn = wgetch(self->win);
+ break;
+ case 2:
+ if (!PyArg_Parse(arg,"(ii);y,x",&y,&x))
return NULL;
- wattrset(self->win,ch);
- Py_INCREF(Py_None);
- return Py_None;
+ rtn = mvwgetch(self->win,y,x);
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "getch requires 0 or 2 arguments");
+ return NULL;
+ }
+ return PyInt_FromLong(rtn);
}
static PyObject *
-PyCursesWindow_StandEnd(self,arg)
+PyCursesWindow_GetKey(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg))
- return NULL;
- wstandend(self->win);
- Py_INCREF(Py_None);
- return Py_None;
-}
+ int x, y;
+ chtype rtn;
-static PyObject *
-PyCursesWindow_StandOut(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- if (!PyArg_NoArgs(arg))
+ switch (ARG_COUNT(arg)) {
+ case 0:
+ rtn = wgetch(self->win);
+ break;
+ case 2:
+ if (!PyArg_Parse(arg,"(ii);y,x",&y,&x))
return NULL;
- wstandout(self->win);
- Py_INCREF(Py_None);
- return Py_None;
-}
-
-static PyObject *
-PyCursesWindow_Border(self, args)
- PyCursesWindowObject *self;
- PyObject *args;
-{
- int ls, rs, ts, bs, tl, tr, bl, br;
- ls = rs = ts = bs = tl = tr = bl = br = 0;
- if (!PyArg_ParseTuple(args,"|iiiiiiii;ls,rs,ts,bs,tl,tr,bl,br",
- &ls, &rs, &ts, &bs, &tl, &tr, &bl, &br))
+ rtn = mvwgetch(self->win,y,x);
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "getch requires 0 or 2 arguments");
return NULL;
- wborder(self->win, ls, rs, ts, bs, tl, tr, bl, br);
- Py_INCREF(Py_None);
- return Py_None;
+ }
+ if (rtn<=255)
+ return Py_BuildValue("c", rtn);
+ else
+ return PyString_FromString((char *)keyname(rtn));
}
static PyObject *
-PyCursesWindow_Box(self,arg)
+PyCursesWindow_GetStr(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int ch1=0,ch2=0;
- if (!PyArg_NoArgs(arg)) {
- PyErr_Clear();
- if (!PyArg_Parse(arg,"(ii);vertch,horch", &ch1, &ch2))
- return NULL;
- }
- box(self->win,ch1,ch2);
- Py_INCREF(Py_None);
- return Py_None;
-}
+ int x, y, n;
+ char rtn[1024]; /* This should be big enough.. I hope */
+ int rtn2;
-static PyObject *
-PyCursesWindow_Hline(self, args)
- PyCursesWindowObject *self;
- PyObject *args;
-{
- int ch, n, x, y, code = OK;
- switch (ARG_COUNT(args)) {
+ switch (ARG_COUNT(arg)) {
+ case 0:
+ rtn2 = wgetstr(self->win,rtn);
+ break;
+ case 1:
+ if (!PyArg_Parse(arg,"i;n", &n))
+ return NULL;
+ rtn2 = wgetnstr(self->win,rtn,n);
+ break;
case 2:
- if (!PyArg_Parse(args, "(ii);ch,n", &ch, &n))
+ if (!PyArg_Parse(arg,"(ii);y,x",&y,&x))
return NULL;
+ rtn2 = mvwgetstr(self->win,y,x,rtn);
break;
- case 4:
- if (!PyArg_Parse(args, "(iiii);y,x,ch,n", &y, &x, &ch, &n))
+ case 3:
+ if (!PyArg_Parse(arg,"(iii);y,x,n", &y, &x, &n))
return NULL;
- code = wmove(self->win, y, x);
+#ifdef __sgi__
+ /* Untested */
+ rtn2 = wmove(self->win,y,x)==ERR ? ERR :
+ wgetnstr(self->win, rtn, n);
+#else
+ rtn2 = mvwgetnstr(self->win, y, x, rtn, n);
+#endif
break;
default:
- PyErr_SetString(PyExc_TypeError, "hline requires 2 or 4 arguments");
+ PyErr_SetString(PyExc_TypeError, "getstr requires 0 to 2 arguments");
return NULL;
}
- if (code != ERR)
- whline(self->win, ch, n);
- return PyCursesCheckERR(code, "wmove");
+ if (rtn2 == ERR)
+ rtn[0] = 0;
+ return PyString_FromString(rtn);
}
static PyObject *
-PyCursesWindow_Vline(self, args)
+PyCursesWindow_Hline(self, args)
PyCursesWindowObject *self;
PyObject *args;
{
- int ch, n, x, y, code = OK;
+ PyObject *temp;
+ chtype ch;
+ int n, x, y, code = OK;
+ attr_t attr = A_NORMAL;
+
switch (ARG_COUNT(args)) {
case 2:
- if (!PyArg_Parse(args, "(ii);ch,n", &ch, &n))
+ if (!PyArg_Parse(args, "(Oi);ch or int,n", &temp, &n))
+ return NULL;
+ break;
+ case 3:
+ if (!PyArg_Parse(args, "(Oil);ch or int,n,attr", &temp, &n, &attr))
return NULL;
break;
case 4:
- if (!PyArg_Parse(args, "(iiii);y,x,ch,n", &y, &x, &ch, &n))
+ if (!PyArg_Parse(args, "(iiOi);y,x,ch o int,n", &y, &x, &temp, &n))
return NULL;
code = wmove(self->win, y, x);
break;
+ case 5:
+ if (!PyArg_Parse(args, "(iiOil); y,x,ch or int,n,attr",
+ &y, &x, &temp, &n, &attr))
+ return NULL;
+ code = wmove(self->win, y, x);
default:
- PyErr_SetString(PyExc_TypeError, "vline requires 2 or 4 arguments");
+ PyErr_SetString(PyExc_TypeError, "hline requires 2 or 5 arguments");
return NULL;
}
- if (code != ERR)
- wvline(self->win, ch, n);
- return PyCursesCheckERR(code, "wmove");
-}
-static PyObject *
-PyCursesWindow_Erase(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- if (!PyArg_NoArgs(arg))
- return NULL;
- werase(self->win);
- Py_INCREF(Py_None);
- return Py_None;
-}
-
-static PyObject *
-PyCursesWindow_DeleteLine(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- if (!PyArg_NoArgs(arg))
- return NULL;
- return PyCursesCheckERR(wdeleteln(self->win), "wdeleteln");
-}
-
-static PyObject *
-PyCursesWindow_InsertLine(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- if (!PyArg_NoArgs(arg))
+ if (code != ERR) {
+ if (!PyCurses_ConvertToChtype(temp, &ch)) {
+ PyErr_SetString(PyExc_TypeError,
+ "argument 1 or 3 must be a ch or an int");
return NULL;
- return PyCursesCheckERR(winsertln(self->win), "winsertln");
+ }
+ return PyCursesCheckERR(whline(self->win, ch | attr, n), "hline");
+ } else
+ return PyCursesCheckERR(code, "wmove");
}
static PyObject *
-PyCursesWindow_GetYX(self,arg)
+PyCursesWindow_InsCh(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int x, y;
- if (!PyArg_NoArgs(arg))
+ int rtn, x, y, use_xy = FALSE;
+ PyObject *temp;
+ chtype ch = 0;
+ attr_t attr = A_NORMAL;
+
+ switch (ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg, "O;ch or int", &temp))
return NULL;
- getyx(self->win,y,x);
- return Py_BuildValue("(ii)", y, x);
-}
-
-static PyObject *
-PyCursesWindow_GetBegYX(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- int x, y;
- if (!PyArg_NoArgs(arg))
+ break;
+ case 2:
+ if (!PyArg_Parse(arg, "(Ol);ch or int,attr", &temp, &attr))
return NULL;
- getbegyx(self->win,y,x);
- return Py_BuildValue("(ii)", y, x);
-}
-
-static PyObject *
-PyCursesWindow_GetMaxYX(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- int x, y;
- if (!PyArg_NoArgs(arg))
+ break;
+ case 3:
+ if (!PyArg_Parse(arg,"(iiO);y,x,ch or int", &y, &x, &temp))
return NULL;
- getmaxyx(self->win,y,x);
- return Py_BuildValue("(ii)", y, x);
-}
-
-static PyObject *
-PyCursesWindow_Clear(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- if (!PyArg_NoArgs(arg))
+ use_xy = TRUE;
+ break;
+ case 4:
+ if (!PyArg_Parse(arg,"(iiOl);y,x,ch or int, attr", &y, &x, &temp, &attr))
return NULL;
- wclear(self->win);
- Py_INCREF(Py_None);
- return Py_None;
-}
+ use_xy = TRUE;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "insch requires 1 or 4 arguments");
+ return NULL;
+ }
-static PyObject *
-PyCursesWindow_ClearToBottom(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- if (!PyArg_NoArgs(arg))
- return NULL;
- wclrtobot(self->win);
- Py_INCREF(Py_None);
- return Py_None;
+ if (!PyCurses_ConvertToChtype(temp, &ch)) {
+ PyErr_SetString(PyExc_TypeError,
+ "argument 1 or 3 must be a ch or an int");
+ return NULL;
+ }
+
+ if (use_xy == TRUE)
+ rtn = mvwinsch(self->win,y,x, ch | attr);
+ else {
+ rtn = winsch(self->win, ch | attr);
+ }
+ return PyCursesCheckERR(rtn, "insch");
}
static PyObject *
-PyCursesWindow_ClearToEOL(self,arg)
+PyCursesWindow_InCh(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg))
- return NULL;
- wclrtoeol(self->win);
- Py_INCREF(Py_None);
- return Py_None;
-}
+ int x, y, rtn;
-static PyObject *
-PyCursesWindow_Scroll(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- int nlines;
- int use_nlines = FALSE;
switch (ARG_COUNT(arg)) {
case 0:
+ rtn = winch(self->win);
break;
- case 1:
- if (!PyArg_Parse(arg, "i;nlines", &nlines))
+ case 2:
+ if (!PyArg_Parse(arg,"(ii);y,x",&y,&x))
return NULL;
- use_nlines = TRUE;
+ rtn = mvwinch(self->win,y,x);
break;
default:
- PyErr_SetString(PyExc_TypeError, "scroll requires 0 or 1 arguments");
+ PyErr_SetString(PyExc_TypeError, "inch requires 0 or 2 arguments");
return NULL;
}
- if (use_nlines)
- return PyCursesCheckERR(wscrl(self->win, nlines), "scroll");
- else
- return PyCursesCheckERR(scroll(self->win), "scroll");
-}
-
-static PyObject *
-PyCursesWindow_TouchWin(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- if (!PyArg_NoArgs(arg))
- return NULL;
- return PyCursesCheckERR(touchwin(self->win), "touchwin");
-}
-
-static PyObject *
-PyCursesWindow_TouchLine(self,arg)
- PyCursesWindowObject *self;
- PyObject * arg;
-{
- int st, cnt;
- if (!PyArg_Parse(arg,"(ii);start,count",&st,&cnt))
- return NULL;
- return PyCursesCheckERR(touchline(self->win,st,cnt), "touchline");
+ return PyInt_FromLong((long) rtn);
}
static PyObject *
-PyCursesWindow_GetCh(self,arg)
+PyCursesWindow_InStr(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int x, y;
- int rtn;
+ int x, y, n;
+ char rtn[1024]; /* This should be big enough.. I hope */
+ int rtn2;
switch (ARG_COUNT(arg)) {
case 0:
- rtn = wgetch(self->win);
+ rtn2 = winstr(self->win,rtn);
+ break;
+ case 1:
+ if (!PyArg_Parse(arg,"i;n", &n))
+ return NULL;
+ rtn2 = winnstr(self->win,rtn,n);
break;
case 2:
if (!PyArg_Parse(arg,"(ii);y,x",&y,&x))
return NULL;
- rtn = mvwgetch(self->win,y,x);
+ rtn2 = mvwinstr(self->win,y,x,rtn);
+ break;
+ case 3:
+ if (!PyArg_Parse(arg, "(iii);y,x,n", &y, &x, &n))
+ return NULL;
+ rtn2 = mvwinnstr(self->win, y, x, rtn, n);
break;
default:
- PyErr_SetString(PyExc_TypeError, "getch requires 0 or 2 arguments");
+ PyErr_SetString(PyExc_TypeError, "instr requires 0 or 3 arguments");
return NULL;
}
-
- return PyInt_FromLong((long) rtn);
+ if (rtn2 == ERR)
+ rtn[0] = 0;
+ return PyString_FromString(rtn);
}
static PyObject *
-PyCursesWindow_GetStr(self,arg)
+PyCursesWindow_InsStr(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
+ int rtn;
int x, y;
- char rtn[1024]; /* This should be big enough.. I hope */
- int rtn2;
+ char *str;
+ attr_t attr = A_NORMAL , attr_old = A_NORMAL;
+ int use_xy = FALSE, use_attr = FALSE;
switch (ARG_COUNT(arg)) {
- case 0:
- rtn2 = wgetstr(self->win,rtn);
+ case 1:
+ if (!PyArg_Parse(arg,"s;str", &str))
+ return NULL;
break;
case 2:
- if (!PyArg_Parse(arg,"(ii);y,x",&y,&x))
+ if (!PyArg_Parse(arg,"(sl);str,attr", &str, &attr))
return NULL;
- rtn2 = mvwgetstr(self->win,y,x,rtn);
+ use_attr = TRUE;
+ break;
+ case 3:
+ if (!PyArg_Parse(arg,"(iis);y,x,str", &y, &x, &str))
+ return NULL;
+ use_xy = TRUE;
+ break;
+ case 4:
+ if (!PyArg_Parse(arg,"(iisl);y,x,str,attr", &y, &x, &str, &attr))
+ return NULL;
+ use_xy = use_attr = TRUE;
break;
default:
- PyErr_SetString(PyExc_TypeError, "getstr requires 0 or 2 arguments");
+ PyErr_SetString(PyExc_TypeError, "insstr requires 1 to 4 arguments");
return NULL;
}
- if (rtn2 == ERR)
- rtn[0] = 0;
- return PyString_FromString(rtn);
+ if (use_attr == TRUE) {
+ attr_old = getattrs(self->win);
+ wattrset(self->win,attr);
+ }
+ if (use_xy == TRUE)
+ rtn = mvwinsstr(self->win,y,x,str);
+ else
+ rtn = winsstr(self->win,str);
+ if (use_attr == TRUE)
+ wattrset(self->win,attr_old);
+ return PyCursesCheckERR(rtn, "insstr");
}
static PyObject *
-PyCursesWindow_InCh(self,arg)
+PyCursesWindow_InsNStr(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int x, y, rtn;
+ int rtn, x, y, n;
+ char *str;
+ attr_t attr = A_NORMAL , attr_old = A_NORMAL;
+ int use_xy = FALSE, use_attr = FALSE;
switch (ARG_COUNT(arg)) {
- case 0:
- rtn = winch(self->win);
- break;
case 2:
- if (!PyArg_Parse(arg,"(ii);y,x",&y,&x))
+ if (!PyArg_Parse(arg,"(si);str,n", &str, &n))
return NULL;
- rtn = mvwinch(self->win,y,x);
+ break;
+ case 3:
+ if (!PyArg_Parse(arg,"(sil);str,n,attr", &str, &n, &attr))
+ return NULL;
+ use_attr = TRUE;
+ break;
+ case 4:
+ if (!PyArg_Parse(arg,"(iisi);y,x,str,n", &y, &x, &str, &n))
+ return NULL;
+ use_xy = TRUE;
+ break;
+ case 5:
+ if (!PyArg_Parse(arg,"(iisil);y,x,str,n,attr", &y, &x, &str, &n, &attr))
+ return NULL;
+ use_xy = use_attr = TRUE;
break;
default:
- PyErr_SetString(PyExc_TypeError, "inch requires 0 or 2 arguments");
+ PyErr_SetString(PyExc_TypeError, "insnstr requires 2 to 5 arguments");
return NULL;
}
- return PyInt_FromLong((long) rtn);
+ if (use_attr == TRUE) {
+ attr_old = getattrs(self->win);
+ wattrset(self->win,attr);
+ }
+ if (use_xy == TRUE)
+ rtn = mvwinsnstr(self->win,y,x,str,n);
+ else
+ rtn = winsnstr(self->win,str,n);
+ if (use_attr == TRUE)
+ wattrset(self->win,attr_old);
+ return PyCursesCheckERR(rtn, "insnstr");
}
static PyObject *
-PyCursesWindow_ClearOk(self,arg)
- PyCursesWindowObject *self;
+PyCursesWindow_Is_LineTouched(self,arg)
+ PyCursesWindowObject * self;
PyObject * arg;
{
- int val;
- if (!PyArg_Parse(arg,"i;True(1) or False(0)",&val))
+ int line, erg;
+ if (!PyArg_Parse(arg,"i;line", &line))
return NULL;
- clearok(self->win,val);
- Py_INCREF(Py_None);
- return Py_None;
+ erg = is_linetouched(self->win, line);
+ if (erg == ERR) {
+ PyErr_SetString(PyExc_TypeError,
+ "is_linetouched: line number outside of boundaries");
+ return NULL;
+ } else
+ if (erg == FALSE) {
+ Py_INCREF(Py_False);
+ return Py_False;
+ } else {
+ Py_INCREF(Py_True);
+ return Py_True;
+ }
}
static PyObject *
-PyCursesWindow_IdlOk(self,arg)
+PyCursesWindow_NoOutRefresh(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int val;
- if (!PyArg_Parse(arg,"i;True(1) or False(0)",&val))
+ int pminrow,pmincol,sminrow,smincol,smaxrow,smaxcol;
+
+ if (self->win->_flags & _ISPAD) {
+ switch(ARG_COUNT(arg)) {
+ case 6:
+ if (!PyArg_Parse(arg,
+ "(iiiiii);" \
+ "pminrow,pmincol,sminrow,smincol,smaxrow,smaxcol",
+ &pminrow, &pmincol, &sminrow,
+ &smincol, &smaxrow, &smaxcol))
+ return NULL;
+ return PyCursesCheckERR(pnoutrefresh(self->win,
+ pminrow, pmincol, sminrow,
+ smincol, smaxrow, smaxcol),
+ "pnoutrefresh");
+ default:
+ PyErr_SetString(PyCursesError,
+ "noutrefresh was called for a pad;" \
+ "requires 6 arguments");
+ return NULL;
+ }
+ } else {
+ if (!PyArg_NoArgs(arg))
+ return NULL;
+ return PyCursesCheckERR(wnoutrefresh(self->win), "wnoutrefresh");
+ }
+}
+
+static PyObject *
+PyCursesWindow_PutWin(self, arg)
+ PyCursesWindowObject *self;
+ PyObject *arg;
+{
+ PyObject *temp;
+
+ if (!PyArg_Parse(arg, "O;fileobj", &temp))
return NULL;
- idlok(self->win,val);
- Py_INCREF(Py_None);
- return Py_None;
+ if (!PyFile_Check(temp)) {
+ PyErr_SetString(PyExc_TypeError, "argument must be a file object");
+ return NULL;
+ }
+ return PyCursesCheckERR(putwin(self->win, PyFile_AsFile(temp)),
+ "putwin");
}
static PyObject *
-PyCursesWindow_LeaveOk(self,arg)
+PyCursesWindow_RedrawLine(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int val;
- if (!PyArg_Parse(arg,"i;True(1) or False(0)",&val))
+ int beg, num;
+ if (!PyArg_Parse(arg,"(ii);beg,num", &beg, &num))
return NULL;
- leaveok(self->win,val);
- Py_INCREF(Py_None);
- return Py_None;
+ return PyCursesCheckERR(wredrawln(self->win,beg,num), "redrawln");
}
static PyObject *
-PyCursesWindow_ScrollOk(self,arg)
+PyCursesWindow_Refresh(self,arg)
PyCursesWindowObject *self;
PyObject * arg;
{
- int val;
- if (!PyArg_Parse(arg,"i;True(1) or False(0)",&val))
- return NULL;
- scrollok(self->win,val);
- Py_INCREF(Py_None);
- return Py_None;
+ int pminrow,pmincol,sminrow,smincol,smaxrow,smaxcol;
+
+ if (self->win->_flags & _ISPAD) {
+ switch(ARG_COUNT(arg)) {
+ case 6:
+ if (!PyArg_Parse(arg,
+ "(iiiiii);" \
+ "pminrow,pmincol,sminrow,smincol,smaxrow,smaxcol",
+ &pminrow, &pmincol, &sminrow,
+ &smincol, &smaxrow, &smaxcol))
+ return NULL;
+ return PyCursesCheckERR(prefresh(self->win,
+ pminrow, pmincol, sminrow,
+ smincol, smaxrow, smaxcol),
+ "prefresh");
+ default:
+ PyErr_SetString(PyCursesError,
+ "refresh was called for a pad; requires 6 arguments");
+ return NULL;
+ }
+ } else {
+ if (!PyArg_NoArgs(arg))
+ return NULL;
+ return PyCursesCheckERR(wrefresh(self->win), "wrefresh");
+ }
}
static PyObject *
@@ -1024,87 +1093,191 @@ PyCursesWindow_SetScrollRegion(self,arg)
}
static PyObject *
-PyCursesWindow_KeyPad(self,arg)
- PyCursesWindowObject * self;
+PyCursesWindow_SubWin(self,arg)
+ PyCursesWindowObject *self;
PyObject * arg;
{
- int ch;
- if (!PyArg_Parse(arg,"i;True(1), False(0)",&ch))
+ WINDOW *win;
+ int nlines, ncols, begin_y, begin_x;
+
+ if (!PyArg_Parse(arg, "(iiii);nlines,ncols,begin_y,begin_x",
+ &nlines,&ncols,&begin_y,&begin_x))
return NULL;
- keypad(self->win,ch);
- Py_INCREF(Py_None);
- return Py_None;
+
+ if (self->win->_flags & _ISPAD)
+ win = subpad(self->win, nlines, ncols, begin_y, begin_x);
+ else
+ win = subwin(self->win,nlines,ncols,begin_y,begin_x);
+
+ if (win == NULL) {
+ PyErr_SetString(PyCursesError, catchall_NULL);
+ return NULL;
+ }
+
+ return (PyObject *)PyCursesWindow_New(win);
}
static PyObject *
-PyCursesWindow_NoDelay(self,arg)
- PyCursesWindowObject * self;
+PyCursesWindow_Scroll(self,arg)
+ PyCursesWindowObject *self;
PyObject * arg;
{
- int ch;
- if (!PyArg_Parse(arg,"i;True(1), False(0)",&ch))
+ int lines;
+ switch(ARG_COUNT(arg)) {
+ case 0:
+ return PyCursesCheckERR(scroll(self->win), "scroll");
+ break;
+ case 1:
+ if (!PyArg_Parse(arg, "i;lines", &lines))
+ return NULL;
+ return PyCursesCheckERR(wscrl(self->win, lines), "scroll");
+ default:
+ PyErr_SetString(PyExc_TypeError, "scroll requires 0 or 1 arguments");
return NULL;
- nodelay(self->win,ch);
- Py_INCREF(Py_None);
- return Py_None;
+ }
}
static PyObject *
-PyCursesWindow_NoTimeout(self,arg)
- PyCursesWindowObject * self;
+PyCursesWindow_TouchLine(self,arg)
+ PyCursesWindowObject *self;
PyObject * arg;
{
- int ch;
- if (!PyArg_Parse(arg,"i;True(1), False(0)",&ch))
+ int st, cnt, val;
+ switch (ARG_COUNT(arg)) {
+ case 2:
+ if (!PyArg_Parse(arg,"(ii);start,count",&st,&cnt))
+ return NULL;
+ return PyCursesCheckERR(touchline(self->win,st,cnt), "touchline");
+ break;
+ case 3:
+ if (!PyArg_Parse(arg, "(iii);start,count,val", &st, &cnt, &val))
+ return NULL;
+ return PyCursesCheckERR(wtouchln(self->win, st, cnt, val), "touchline");
+ default:
+ PyErr_SetString(PyExc_TypeError, "touchline requires 2 or 3 arguments");
return NULL;
- notimeout(self->win,ch);
- Py_INCREF(Py_None);
- return Py_None;
+ }
+}
+
+static PyObject *
+PyCursesWindow_Vline(self, args)
+ PyCursesWindowObject *self;
+ PyObject *args;
+{
+ PyObject *temp;
+ chtype ch;
+ int n, x, y, code = OK;
+ attr_t attr = A_NORMAL;
+
+ switch (ARG_COUNT(args)) {
+ case 2:
+ if (!PyArg_Parse(args, "(Oi);ch or int,n", &temp, &n))
+ return NULL;
+ break;
+ case 3:
+ if (!PyArg_Parse(args, "(Oil);ch or int,n,attr", &temp, &n, &attr))
+ return NULL;
+ break;
+ case 4:
+ if (!PyArg_Parse(args, "(iiOi);y,x,ch o int,n", &y, &x, &temp, &n))
+ return NULL;
+ code = wmove(self->win, y, x);
+ break;
+ case 5:
+ if (!PyArg_Parse(args, "(iiOil); y,x,ch or int,n,attr",
+ &y, &x, &temp, &n, &attr))
+ return NULL;
+ code = wmove(self->win, y, x);
+ default:
+ PyErr_SetString(PyExc_TypeError, "vline requires 2 or 5 arguments");
+ return NULL;
+ }
+
+ if (code != ERR) {
+ if (!PyCurses_ConvertToChtype(temp, &ch)) {
+ PyErr_SetString(PyExc_TypeError,
+ "argument 1 or 3 must be a ch or an int");
+ return NULL;
+ }
+ return PyCursesCheckERR(whline(self->win, ch | attr, n), "vline");
+ } else
+ return PyCursesCheckERR(code, "wmove");
}
static PyMethodDef PyCursesWindow_Methods[] = {
- {"refresh", (PyCFunction)PyCursesWindow_Refresh},
- {"nooutrefresh", (PyCFunction)PyCursesWindow_NoOutRefresh},
- {"mvwin", (PyCFunction)PyCursesWindow_MoveWin},
- {"move", (PyCFunction)PyCursesWindow_Move},
- {"subwin", (PyCFunction)PyCursesWindow_SubWin},
{"addch", (PyCFunction)PyCursesWindow_AddCh},
- {"insch", (PyCFunction)PyCursesWindow_InsCh},
- {"delch", (PyCFunction)PyCursesWindow_DelCh},
- {"echochar", (PyCFunction)PyCursesWindow_EchoChar},
+ {"addnstr", (PyCFunction)PyCursesWindow_AddNStr},
{"addstr", (PyCFunction)PyCursesWindow_AddStr},
- {"attron", (PyCFunction)PyCursesWindow_AttrOn},
- {"attroff", (PyCFunction)PyCursesWindow_AttrOff},
- {"attrset", (PyCFunction)PyCursesWindow_AttrSet},
- {"standend", (PyCFunction)PyCursesWindow_StandEnd},
- {"standout", (PyCFunction)PyCursesWindow_StandOut},
+ {"attron", (PyCFunction)PyCursesWindow_wattron},
+ {"attr_on", (PyCFunction)PyCursesWindow_wattron},
+ {"attroff", (PyCFunction)PyCursesWindow_wattroff},
+ {"attr_off", (PyCFunction)PyCursesWindow_wattroff},
+ {"attrset", (PyCFunction)PyCursesWindow_wattrset},
+ {"attr_set", (PyCFunction)PyCursesWindow_wattrset},
+ {"bkgd", (PyCFunction)PyCursesWindow_Bkgd},
+ {"bkgdset", (PyCFunction)PyCursesWindow_BkgdSet},
{"border", (PyCFunction)PyCursesWindow_Border, METH_VARARGS},
{"box", (PyCFunction)PyCursesWindow_Box},
- {"hline", (PyCFunction)PyCursesWindow_Hline},
- {"vline", (PyCFunction)PyCursesWindow_Vline},
- {"erase", (PyCFunction)PyCursesWindow_Erase},
- {"deleteln", (PyCFunction)PyCursesWindow_DeleteLine},
- {"insertln", (PyCFunction)PyCursesWindow_InsertLine},
- {"getyx", (PyCFunction)PyCursesWindow_GetYX},
- {"getbegyx", (PyCFunction)PyCursesWindow_GetBegYX},
- {"getmaxyx", (PyCFunction)PyCursesWindow_GetMaxYX},
- {"clear", (PyCFunction)PyCursesWindow_Clear},
- {"clrtobot", (PyCFunction)PyCursesWindow_ClearToBottom},
- {"clrtoeol", (PyCFunction)PyCursesWindow_ClearToEOL},
- {"scroll", (PyCFunction)PyCursesWindow_Scroll},
- {"touchwin", (PyCFunction)PyCursesWindow_TouchWin},
- {"touchline", (PyCFunction)PyCursesWindow_TouchLine},
+ {"clear", (PyCFunction)PyCursesWindow_wclear},
+ {"clearok", (PyCFunction)PyCursesWindow_clearok},
+ {"clrtobot", (PyCFunction)PyCursesWindow_wclrtobot},
+ {"clrtoeol", (PyCFunction)PyCursesWindow_wclrtoeol},
+ {"cursyncup", (PyCFunction)PyCursesWindow_wcursyncup},
+ {"delch", (PyCFunction)PyCursesWindow_DelCh},
+ {"deleteln", (PyCFunction)PyCursesWindow_wdeleteln},
+ {"derwin", (PyCFunction)PyCursesWindow_DerWin},
+ {"echochar", (PyCFunction)PyCursesWindow_EchoChar},
+ {"erase", (PyCFunction)PyCursesWindow_werase},
+ {"getbegyx", (PyCFunction)PyCursesWindow_getbegyx},
+ {"getbkgd", (PyCFunction)PyCursesWindow_GetBkgd},
{"getch", (PyCFunction)PyCursesWindow_GetCh},
+ {"getkey", (PyCFunction)PyCursesWindow_GetKey},
+ {"getmaxyx", (PyCFunction)PyCursesWindow_getmaxyx},
+ {"getparyx", (PyCFunction)PyCursesWindow_getparyx},
{"getstr", (PyCFunction)PyCursesWindow_GetStr},
+ {"getyx", (PyCFunction)PyCursesWindow_getyx},
+ {"hline", (PyCFunction)PyCursesWindow_Hline},
+ {"idlok", (PyCFunction)PyCursesWindow_idlok},
+ {"idcok", (PyCFunction)PyCursesWindow_idcok},
+ {"immedok", (PyCFunction)PyCursesWindow_immedok},
{"inch", (PyCFunction)PyCursesWindow_InCh},
- {"clearok", (PyCFunction)PyCursesWindow_ClearOk},
- {"idlok", (PyCFunction)PyCursesWindow_IdlOk},
- {"leaveok", (PyCFunction)PyCursesWindow_LeaveOk},
- {"scrollok", (PyCFunction)PyCursesWindow_ScrollOk},
+ {"insch", (PyCFunction)PyCursesWindow_InsCh},
+ {"insdelln", (PyCFunction)PyCursesWindow_winsdelln},
+ {"insertln", (PyCFunction)PyCursesWindow_winsertln},
+ {"insnstr", (PyCFunction)PyCursesWindow_InsNStr},
+ {"insstr", (PyCFunction)PyCursesWindow_InsStr},
+ {"instr", (PyCFunction)PyCursesWindow_InStr},
+ {"is_linetouched", (PyCFunction)PyCursesWindow_Is_LineTouched},
+ {"is_wintouched", (PyCFunction)PyCursesWindow_is_wintouched},
+ {"keypad", (PyCFunction)PyCursesWindow_keypad},
+ {"leaveok", (PyCFunction)PyCursesWindow_leaveok},
+ {"move", (PyCFunction)PyCursesWindow_wmove},
+ {"mvwin", (PyCFunction)PyCursesWindow_mvwin},
+ {"mvderwin", (PyCFunction)PyCursesWindow_mvderwin},
+ {"nodelay", (PyCFunction)PyCursesWindow_nodelay},
+ {"noutrefresh", (PyCFunction)PyCursesWindow_NoOutRefresh},
+ {"notimeout", (PyCFunction)PyCursesWindow_notimeout},
+ {"putwin", (PyCFunction)PyCursesWindow_PutWin},
+ {"redrawwin", (PyCFunction)PyCursesWindow_redrawwin},
+ {"redrawln", (PyCFunction)PyCursesWindow_RedrawLine},
+ {"refresh", (PyCFunction)PyCursesWindow_Refresh},
+#ifndef __sgi__
+ {"resize", (PyCFunction)PyCursesWindow_wresize},
+#endif
+ {"scroll", (PyCFunction)PyCursesWindow_Scroll},
+ {"scrollok", (PyCFunction)PyCursesWindow_scrollok},
{"setscrreg", (PyCFunction)PyCursesWindow_SetScrollRegion},
- {"keypad", (PyCFunction)PyCursesWindow_KeyPad},
- {"nodelay", (PyCFunction)PyCursesWindow_NoDelay},
- {"notimeout", (PyCFunction)PyCursesWindow_NoTimeout},
+ {"standend", (PyCFunction)PyCursesWindow_wstandend},
+ {"standout", (PyCFunction)PyCursesWindow_wstandout},
+ {"subpad", (PyCFunction)PyCursesWindow_SubWin},
+ {"subwin", (PyCFunction)PyCursesWindow_SubWin},
+ {"syncdown", (PyCFunction)PyCursesWindow_wsyncdown},
+ {"syncok", (PyCFunction)PyCursesWindow_syncok},
+ {"syncup", (PyCFunction)PyCursesWindow_wsyncup},
+ {"touchline", (PyCFunction)PyCursesWindow_TouchLine},
+ {"touchwin", (PyCFunction)PyCursesWindow_touchwin},
+ {"untouchwin", (PyCFunction)PyCursesWindow_untouchwin},
+ {"vline", (PyCFunction)PyCursesWindow_Vline},
{NULL, NULL} /* sentinel */
};
@@ -1116,48 +1289,9 @@ PyCursesWindow_GetAttr(self, name)
return Py_FindMethod(PyCursesWindow_Methods, (PyObject *)self, name);
}
-
-/* --------------- PAD routines ---------------- */
-
-#ifdef NOT_YET
-static PyObject *
-PyCursesPad_New(pad)
- WINDOW *pad;
-{
- PyCursesPadObject *po;
- po = PyObject_New(PyCursesPadObject, &PyCursesPad_Type);
- if (po == NULL)
- return NULL;
- po->pad = pad;
- return (PyObject *)po;
-}
-#endif
-
-
/* -------------------------------------------------------*/
-#if 0
-static PyTypeObject PyCursesScreen_Type = {
- PyObject_HEAD_INIT(&PyType_Type)
- 0, /*ob_size*/
- "curses screen", /*tp_name*/
- sizeof(PyCursesScreenObject), /*tp_basicsize*/
- 0, /*tp_itemsize*/
- /* methods */
- (destructor)0 /*PyCursesScreen_Dealloc*/, /*tp_dealloc*/
- 0, /*tp_print*/
- (getattrfunc)0, /*tp_getattr*/
- (setattrfunc)0, /*tp_setattr*/
- 0, /*tp_compare*/
- 0, /*tp_repr*/
- 0, /*tp_as_number*/
- 0, /*tp_as_sequence*/
- 0, /*tp_as_mapping*/
- 0, /*tp_hash*/
-};
-#endif
-
-static PyTypeObject PyCursesWindow_Type = {
+PyTypeObject PyCursesWindow_Type = {
PyObject_HEAD_INIT(&PyType_Type)
0, /*ob_size*/
"curses window", /*tp_name*/
@@ -1176,370 +1310,796 @@ static PyTypeObject PyCursesWindow_Type = {
0, /*tp_hash*/
};
-#if 0
-static PyTypeObject PyCursesPad_Type = {
- PyObject_HEAD_INIT(&PyType_Type)
- 0, /*ob_size*/
- "curses pad", /*tp_name*/
- sizeof(PyCursesPadObject), /*tp_basicsize*/
- 0, /*tp_itemsize*/
- /* methods */
- (destructor)0 /*PyCursesPad_Dealloc*/, /*tp_dealloc*/
- 0, /*tp_print*/
- (getattrfunc)0, /*tp_getattr*/
- (setattrfunc)0, /*tp_setattr*/
- 0, /*tp_compare*/
- 0, /*tp_repr*/
- 0, /*tp_as_number*/
- 0, /*tp_as_sequence*/
- 0, /*tp_as_mapping*/
- 0, /*tp_hash*/
-};
-#endif
-
-
-/* -------------------------------------------------------*/
+/*********************************************************************
+ Global Functions
+**********************************************************************/
static PyObject *ModDict;
-static PyObject *
-PyCurses_InitScr(self, args)
+/* Function Prototype Macros - They are ugly but very, very useful. ;-)
+
+ X - function name
+ TYPE - parameter Type
+ ERGSTR - format string for construction of the return value
+ PARSESTR - format string for argument parsing
+ */
+
+#define NoArgNoReturnFunction(X) \
+static PyObject *PyCurses_ ## X (self, arg) \
+ PyObject * self; \
+ PyObject * arg; \
+{ \
+ PyCursesInitialised \
+ if (!PyArg_NoArgs(arg)) return NULL; \
+ return PyCursesCheckERR(X(), # X); }
+
+#define NoArgOrFlagNoReturnFunction(X) \
+static PyObject *PyCurses_ ## X (self, arg) \
+ PyObject * self; \
+ PyObject * arg; \
+{ \
+ int flag = 0; \
+ PyCursesInitialised \
+ switch(ARG_COUNT(arg)) { \
+ case 0: \
+ return PyCursesCheckERR(X(), # X); \
+ case 1: \
+ if (!PyArg_Parse(arg, "i;True(1) or False(0)", &flag)) return NULL; \
+ if (flag) return PyCursesCheckERR(X(), # X); \
+ else return PyCursesCheckERR(no ## X (), # X); \
+ default: \
+ PyErr_SetString(PyExc_TypeError, # X " requires 0 or 1 argument"); \
+ return NULL; } }
+
+#define NoArgReturnIntFunction(X) \
+static PyObject *PyCurses_ ## X (self, arg) \
+ PyObject * self; \
+ PyObject * arg; \
+{ \
+ PyCursesInitialised \
+ if (!PyArg_NoArgs(arg)) return NULL; \
+ return PyInt_FromLong((long) X()); }
+
+
+#define NoArgReturnStringFunction(X) \
+static PyObject *PyCurses_ ## X (self, arg) \
+ PyObject * self; \
+ PyObject * arg; \
+{ \
+ PyCursesInitialised \
+ if (!PyArg_NoArgs(arg)) return NULL; \
+ return PyString_FromString(X()); }
+
+#define NoArgTrueFalseFunction(X) \
+static PyObject * PyCurses_ ## X (self,arg) \
+ PyObject * self; \
+ PyObject * arg; \
+{ \
+ PyCursesInitialised \
+ if (!PyArg_NoArgs(arg)) return NULL; \
+ if (X () == FALSE) { \
+ Py_INCREF(Py_False); \
+ return Py_False; \
+ } \
+ Py_INCREF(Py_True); \
+ return Py_True; }
+
+#define NoArgNoReturnVoidFunction(X) \
+static PyObject * PyCurses_ ## X (self,arg) \
+ PyObject * self; \
+ PyObject * arg; \
+{ \
+ PyCursesInitialised \
+ if (!PyArg_NoArgs(arg)) return NULL; \
+ X(); \
+ Py_INCREF(Py_None); \
+ return Py_None; }
+
+NoArgNoReturnFunction(beep)
+NoArgNoReturnFunction(def_prog_mode)
+NoArgNoReturnFunction(def_shell_mode)
+NoArgNoReturnFunction(doupdate)
+NoArgNoReturnFunction(endwin)
+NoArgNoReturnFunction(flash)
+NoArgNoReturnFunction(nocbreak)
+NoArgNoReturnFunction(noecho)
+NoArgNoReturnFunction(nonl)
+NoArgNoReturnFunction(noraw)
+NoArgNoReturnFunction(reset_prog_mode)
+NoArgNoReturnFunction(reset_shell_mode)
+NoArgNoReturnFunction(resetty)
+NoArgNoReturnFunction(savetty)
+
+NoArgOrFlagNoReturnFunction(cbreak)
+NoArgOrFlagNoReturnFunction(echo)
+NoArgOrFlagNoReturnFunction(nl)
+NoArgOrFlagNoReturnFunction(raw)
+
+NoArgReturnIntFunction(baudrate)
+NoArgReturnIntFunction(termattrs)
+
+NoArgReturnStringFunction(termname)
+NoArgReturnStringFunction(longname)
+
+NoArgTrueFalseFunction(can_change_color)
+NoArgTrueFalseFunction(has_colors)
+NoArgTrueFalseFunction(has_ic)
+NoArgTrueFalseFunction(has_il)
+NoArgTrueFalseFunction(isendwin)
+
+NoArgNoReturnVoidFunction(filter)
+NoArgNoReturnVoidFunction(flushinp)
+NoArgNoReturnVoidFunction(noqiflush)
+
+static PyObject *
+PyCurses_Color_Content(self, arg)
PyObject * self;
- PyObject * args;
+ PyObject * arg;
{
- WINDOW *win;
- if (!PyArg_NoArgs(args))
+ short color,r,g,b;
+
+ PyCursesInitialised
+ PyCursesInitialisedColor
+
+ if (ARG_COUNT(arg) != 1) {
+ PyErr_SetString(PyExc_TypeError,
+ "color_content requires 1 argument");
return NULL;
- if (initialised == TRUE) {
- wrefresh(stdscr);
- return (PyObject *)PyCursesWindow_New(stdscr);
}
- win = initscr();
- if (win == NULL) {
- PyErr_SetString(PyCursesError, catchall_NULL);
+ if (!PyArg_Parse(arg, "h;color", &color)) return NULL;
+
+ if (color_content(color, &r, &g, &b) != ERR)
+ return Py_BuildValue("(iii)", r, g, b);
+ else {
+ PyErr_SetString(PyCursesError,
+ "Argument 1 was out of range. Check value of COLORS.");
return NULL;
}
+}
- initialised = TRUE;
+static PyObject *
+PyCurses_COLOR_PAIR(self, arg)
+ PyObject * self;
+ PyObject * arg;
+{
+ int n;
-/* This was moved from initcurses() because core dumped on SGI */
-/* Also, they are probably not defined until you've called initscr() */
-#define SetDictInt(string,ch) \
- PyDict_SetItemString(ModDict,string,PyInt_FromLong((long) (ch)));
-
- /* Here are some graphic symbols you can use */
- SetDictInt("ACS_ULCORNER",(ACS_ULCORNER));
- SetDictInt("ACS_ULCORNER",(ACS_ULCORNER));
- SetDictInt("ACS_LLCORNER",(ACS_LLCORNER));
- SetDictInt("ACS_URCORNER",(ACS_URCORNER));
- SetDictInt("ACS_LRCORNER",(ACS_LRCORNER));
- SetDictInt("ACS_RTEE", (ACS_RTEE));
- SetDictInt("ACS_LTEE", (ACS_LTEE));
- SetDictInt("ACS_BTEE", (ACS_BTEE));
- SetDictInt("ACS_TTEE", (ACS_TTEE));
- SetDictInt("ACS_HLINE", (ACS_HLINE));
- SetDictInt("ACS_VLINE", (ACS_VLINE));
- SetDictInt("ACS_PLUS", (ACS_PLUS));
- SetDictInt("ACS_S1", (ACS_S1));
- SetDictInt("ACS_S9", (ACS_S9));
- SetDictInt("ACS_DIAMOND", (ACS_DIAMOND));
- SetDictInt("ACS_CKBOARD", (ACS_CKBOARD));
- SetDictInt("ACS_DEGREE", (ACS_DEGREE));
- SetDictInt("ACS_PLMINUS", (ACS_PLMINUS));
- SetDictInt("ACS_BULLET", (ACS_BULLET));
- SetDictInt("ACS_LARROW", (ACS_LARROW));
- SetDictInt("ACS_RARROW", (ACS_RARROW));
- SetDictInt("ACS_DARROW", (ACS_DARROW));
- SetDictInt("ACS_UARROW", (ACS_UARROW));
- SetDictInt("ACS_BOARD", (ACS_BOARD));
- SetDictInt("ACS_LANTERN", (ACS_LANTERN));
- SetDictInt("ACS_BLOCK", (ACS_BLOCK));
+ PyCursesInitialised
+ PyCursesInitialisedColor
- return (PyObject *)PyCursesWindow_New(win);
+ if (ARG_COUNT(arg)!=1) {
+ PyErr_SetString(PyExc_TypeError, "COLOR_PAIR requires 1 argument");
+ return NULL;
+ }
+ if (!PyArg_Parse(arg, "i;number", &n)) return NULL;
+ return PyInt_FromLong((long) (n << 8));
}
-static PyObject *
-PyCurses_EndWin(self, args)
+static PyObject *
+PyCurses_Curs_Set(self, arg)
PyObject * self;
- PyObject * args;
+ PyObject * arg;
{
- if (!PyArg_NoArgs(args) || !PyCursesInitialised())
+ int vis,erg;
+
+ PyCursesInitialised
+
+ if (ARG_COUNT(arg)==1) {
+ PyErr_SetString(PyExc_TypeError, "curs_set requires 1 argument");
return NULL;
- return PyCursesCheckERR(endwin(), "endwin");
+ }
+
+ if (!PyArg_Parse(arg, "i;int", &vis)) return NULL;
+
+ erg = curs_set(vis);
+ if (erg == ERR) return PyCursesCheckERR(erg, "curs_set");
+
+ return PyInt_FromLong((long) erg);
}
-static PyObject *
-PyCurses_IsEndWin(self, args)
+static PyObject *
+PyCurses_Delay_Output(self,arg)
PyObject * self;
- PyObject * args;
+ PyObject * arg;
{
- if (!PyArg_NoArgs(args))
+ int ms;
+
+ PyCursesInitialised
+
+ if (ARG_COUNT(arg)==1) {
+ PyErr_SetString(PyExc_TypeError, "delay_output requires 1 argument");
return NULL;
- if (isendwin() == FALSE) {
- Py_INCREF(Py_False);
- return Py_False;
}
- Py_INCREF(Py_True);
- return Py_True;
+ if (!PyArg_Parse(arg, "i;ms", &ms)) return NULL;
+
+ return PyCursesCheckERR(delay_output(ms), "delay_output");
}
static PyObject *
-PyCurses_DoUpdate(self,arg)
+PyCurses_EraseChar(self,arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
- return NULL;
- return PyCursesCheckERR(doupdate(), "doupdate");
+ char ch;
+
+ PyCursesInitialised
+
+ if (!PyArg_NoArgs(arg)) return NULL;
+
+ ch = erasechar();
+
+ return PyString_FromString(&ch);
}
static PyObject *
-PyCurses_NewWindow(self,arg)
+PyCurses_getsyx(self, arg)
PyObject * self;
PyObject * arg;
{
+ int x,y;
+
+ PyCursesInitialised
+
+ if (!PyArg_NoArgs(arg)) return NULL;
+
+ getsyx(y, x);
+
+ return Py_BuildValue("(ii)", y, x);
+}
+
+static PyObject *
+PyCurses_GetWin(self,arg)
+ PyCursesWindowObject *self;
+ PyObject * arg;
+{
WINDOW *win;
- int nlines, ncols, begin_y, begin_x;
+ PyObject *temp;
- if (!PyCursesInitialised())
- return NULL;
- nlines = ncols = 0;
- switch (ARG_COUNT(arg)) {
- case 2:
- if (!PyArg_Parse(arg,"(ii);begin)_y,begin_x",&begin_y,&begin_x))
- return NULL;
- break;
- case 4:
- if (!PyArg_Parse(arg, "(iiii);nlines,ncols,begin_y,begin_x",
- &nlines,&ncols,&begin_y,&begin_x))
- return NULL;
- break;
- default:
- PyErr_SetString(PyExc_TypeError, "newwin requires 2 or 4 arguments");
+ PyCursesInitialised
+
+ if (!PyArg_Parse(arg, "O;fileobj", &temp)) return NULL;
+
+ if (!PyFile_Check(temp)) {
+ PyErr_SetString(PyExc_TypeError, "argument must be a file object");
return NULL;
}
- win = newwin(nlines,ncols,begin_y,begin_x);
+ win = getwin(PyFile_AsFile(temp));
+
if (win == NULL) {
PyErr_SetString(PyCursesError, catchall_NULL);
return NULL;
}
- return (PyObject *)PyCursesWindow_New(win);
+ return PyCursesWindow_New(win);
}
static PyObject *
-PyCurses_Beep(self,arg)
+PyCurses_HalfDelay(self,arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ unsigned char tenths;
+
+ PyCursesInitialised
+
+ switch(ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg, "b;tenths", &tenths)) return NULL;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "halfdelay requires 1 argument");
return NULL;
- beep();
- Py_INCREF(Py_None);
- return Py_None;
+ }
+
+ return PyCursesCheckERR(halfdelay(tenths), "halfdelay");
}
-static PyObject *
-PyCurses_Flash(self,arg)
+#ifndef __sgi__
+ /* No has_key! */
+static PyObject * PyCurses_has_key(self,arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
- return NULL;
- flash();
- Py_INCREF(Py_None);
- return Py_None;
+ int ch;
+
+ PyCursesInitialised
+
+ if (!PyArg_Parse(arg,"i",&ch)) return NULL;
+
+ if (has_key(ch) == FALSE) {
+ Py_INCREF(Py_False);
+ return Py_False;
+ }
+ Py_INCREF(Py_True);
+ return Py_True;
}
+#endif
static PyObject *
-PyCurses_UngetCh(self,arg)
+PyCurses_Init_Color(self, arg)
PyObject * self;
PyObject * arg;
{
- int ch;
- if (!PyArg_Parse(arg,"i;integer",&ch) || !PyCursesInitialised())
+ short color, r, g, b;
+
+ PyCursesInitialised
+ PyCursesInitialisedColor
+
+ switch(ARG_COUNT(arg)) {
+ case 4:
+ if (!PyArg_Parse(arg, "(hhhh);color,r,g,b", &color, &r, &g, &b)) return NULL;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "init_color requires 4 arguments");
return NULL;
- return PyCursesCheckERR(ungetch(ch), "ungetch");
+ }
+
+ return PyCursesCheckERR(init_color(color, r, g, b), "init_color");
}
static PyObject *
-PyCurses_FlushInp(self,arg)
+PyCurses_Init_Pair(self, arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ short pair, f, b;
+
+ PyCursesInitialised
+ PyCursesInitialisedColor
+
+ if (ARG_COUNT(arg) == 3) {
+ PyErr_SetString(PyExc_TypeError, "init_pair requires 3 arguments");
return NULL;
- flushinp();
- Py_INCREF(Py_None);
- return Py_None;
+ }
+
+ if (!PyArg_Parse(arg, "(hhh);pair, f, b", &pair, &f, &b)) return NULL;
+
+ return PyCursesCheckERR(init_pair(pair, f, b), "init_pair");
}
+static PyObject *
+PyCurses_InitScr(self, args)
+ PyObject * self;
+ PyObject * args;
+{
+ WINDOW *win;
+ PyObject *lines, *cols;
+
+ if (!PyArg_NoArgs(args)) return NULL;
+
+ if (initialised == TRUE) {
+ wrefresh(stdscr);
+ return (PyObject *)PyCursesWindow_New(stdscr);
+ }
+
+ win = initscr();
+
+ if (win == NULL) {
+ PyErr_SetString(PyCursesError, catchall_NULL);
+ return NULL;
+ }
+
+ initialised = TRUE;
+
+ lines = PyInt_FromLong((long) LINES);
+ PyDict_SetItemString(ModDict, "LINES", lines);
+ Py_DECREF(lines);
+ cols = PyInt_FromLong((long) COLS);
+ PyDict_SetItemString(ModDict, "COLS", cols);
+ Py_DECREF(cols);
+
+ return (PyObject *)PyCursesWindow_New(win);
+}
+
+
static PyObject *
-PyCurses_CBreak(self,arg)
+PyCurses_IntrFlush(self,arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ int ch;
+
+ PyCursesInitialised
+
+ switch(ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg,"i;True(1), False(0)",&ch)) return NULL;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "intrflush requires 1 argument");
return NULL;
- return PyCursesCheckERR(cbreak(), "cbreak");
+ }
+
+ return PyCursesCheckERR(intrflush(NULL,ch), "intrflush");
}
static PyObject *
-PyCurses_NoCBreak(self,arg)
+PyCurses_KeyName(self,arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
- return NULL;
- return PyCursesCheckERR(nocbreak(), "nocbreak");
+ const char *knp;
+ int ch;
+
+ PyCursesInitialised
+
+ if (!PyArg_Parse(arg,"i",&ch)) return NULL;
+
+ knp = keyname(ch);
+
+ return PyString_FromString((knp == NULL) ? "" : (char *)knp);
}
+static PyObject *
+PyCurses_KillChar(self,arg)
+PyObject * self;
+PyObject * arg;
+{
+ char ch;
+
+ if (!PyArg_NoArgs(arg)) return NULL;
+
+ ch = killchar();
+
+ return PyString_FromString(&ch);
+}
+
static PyObject *
-PyCurses_Echo(self,arg)
+PyCurses_Meta(self,arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ int ch;
+
+ PyCursesInitialised
+
+ switch(ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg,"i;True(1), False(0)",&ch)) return NULL;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "meta requires 1 argument");
return NULL;
- return PyCursesCheckERR(echo(), "echo");
+ }
+
+ return PyCursesCheckERR(meta(stdscr, ch), "meta");
}
static PyObject *
-PyCurses_NoEcho(self,arg)
+PyCurses_NewPad(self,arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ WINDOW *win;
+ int nlines, ncols;
+
+ PyCursesInitialised
+
+ if (!PyArg_Parse(arg,"(ii);nlines,ncols",&nlines,&ncols)) return NULL;
+
+ win = newpad(nlines, ncols);
+
+ if (win == NULL) {
+ PyErr_SetString(PyCursesError, catchall_NULL);
return NULL;
- return PyCursesCheckERR(noecho(), "noecho");
+ }
+
+ return (PyObject *)PyCursesWindow_New(win);
}
static PyObject *
-PyCurses_Nl(self,arg)
+PyCurses_NewWindow(self,arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ WINDOW *win;
+ int nlines, ncols, begin_y, begin_x;
+
+ PyCursesInitialised
+
+ switch (ARG_COUNT(arg)) {
+ case 2:
+ if (!PyArg_Parse(arg,"(ii);nlines,ncols",&nlines,&ncols))
+ return NULL;
+ win = newpad(nlines, ncols);
+ break;
+ case 4:
+ if (!PyArg_Parse(arg, "(iiii);nlines,ncols,begin_y,begin_x",
+ &nlines,&ncols,&begin_y,&begin_x))
+ return NULL;
+ win = newwin(nlines,ncols,begin_y,begin_x);
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "newwin requires 2 or 4 arguments");
+ return NULL;
+ }
+
+ if (win == NULL) {
+ PyErr_SetString(PyCursesError, catchall_NULL);
return NULL;
- return PyCursesCheckERR(nl(), "nl");
+ }
+
+ return (PyObject *)PyCursesWindow_New(win);
}
static PyObject *
-PyCurses_NoNl(self,arg)
+PyCurses_Pair_Content(self, arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ short pair,f,b;
+
+ PyCursesInitialised
+ PyCursesInitialisedColor
+
+ switch(ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg, "h;pair", &pair)) return NULL;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "pair_content requires 1 argument");
return NULL;
- return PyCursesCheckERR(nonl(), "nonl");
+ }
+
+ if (!pair_content(pair, &f, &b)) {
+ PyErr_SetString(PyCursesError,
+ "Argument 1 was out of range. (1..COLOR_PAIRS-1)");
+ return NULL;
+ }
+
+ return Py_BuildValue("(ii)", f, b);
}
static PyObject *
-PyCurses_Raw(self,arg)
+PyCurses_PAIR_NUMBER(self, arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ int n;
+
+ PyCursesInitialised
+ PyCursesInitialisedColor
+
+ switch(ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg, "i;pairvalue", &n)) return NULL;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError,
+ "PAIR_NUMBER requires 1 argument");
return NULL;
- return PyCursesCheckERR(raw(), "raw");
+ }
+
+ return PyInt_FromLong((long) ((n & A_COLOR) >> 8));
}
static PyObject *
-PyCurses_NoRaw(self,arg)
+PyCurses_Putp(self,arg)
+ PyObject *self;
+ PyObject *arg;
+{
+ char *str;
+
+ if (!PyArg_Parse(arg,"s;str", &str)) return NULL;
+ return PyCursesCheckERR(putp(str), "putp");
+}
+
+static PyObject *
+PyCurses_QiFlush(self, arg)
PyObject * self;
PyObject * arg;
{
- if (!PyArg_NoArgs(arg) || !PyCursesInitialised())
+ int flag = 0;
+
+ PyCursesInitialised
+
+ switch(ARG_COUNT(arg)) {
+ case 0:
+ qiflush();
+ Py_INCREF(Py_None);
+ return Py_None;
+ case 1:
+ if (!PyArg_Parse(arg, "i;True(1) or False(0)", &flag)) return NULL;
+ if (flag) qiflush();
+ else noqiflush();
+ Py_INCREF(Py_None);
+ return Py_None;
+ default:
+ PyErr_SetString(PyExc_TypeError, "nl requires 0 or 1 argument");
return NULL;
- return PyCursesCheckERR(noraw(), "noraw");
+ }
}
static PyObject *
-PyCurses_IntrFlush(self,arg)
+PyCurses_setsyx(self, arg)
PyObject * self;
PyObject * arg;
{
- int ch;
- if (!PyArg_Parse(arg,"i;True(1), False(0)",&ch))
+ int y,x;
+
+ PyCursesInitialised
+
+ if (ARG_COUNT(arg)!=3) {
+ PyErr_SetString(PyExc_TypeError, "curs_set requires 3 argument");
return NULL;
- return PyCursesCheckERR(intrflush(NULL,ch), "intrflush");
+ }
+
+ if (!PyArg_Parse(arg, "(ii);y, x", &y, &x)) return NULL;
+
+ setsyx(y,x);
+
+ Py_INCREF(Py_None);
+ return Py_None;
}
static PyObject *
-PyCurses_Meta(self,arg)
+PyCurses_Start_Color(self,arg)
PyObject * self;
PyObject * arg;
{
- int ch;
- if (!PyArg_Parse(arg,"i;True(1), False(0)",&ch) || !PyCursesInitialised())
+ int code;
+ PyObject *c, *cp;
+
+ PyCursesInitialised
+
+ if (!PyArg_NoArgs(arg)) return NULL;
+
+ code = start_color();
+ if (code != ERR) {
+ initialisedcolors = TRUE;
+ c = PyInt_FromLong((long) COLORS);
+ PyDict_SetItemString(ModDict, "COLORS", c);
+ Py_DECREF(c);
+ cp = PyInt_FromLong((long) COLOR_PAIRS);
+ PyDict_SetItemString(ModDict, "COLOR_PAIRS", cp);
+ Py_DECREF(cp);
+ Py_INCREF(Py_None);
+ return Py_None;
+ } else {
+ PyErr_SetString(PyCursesError, "start_color() returned ERR");
return NULL;
- return PyCursesCheckERR(meta(stdscr, ch), "meta");
+ }
}
static PyObject *
-PyCurses_KeyName(self,arg)
+PyCurses_UnCtrl(self,arg)
PyObject * self;
PyObject * arg;
{
- const char *knp;
- int ch;
- if (!PyArg_Parse(arg,"i",&ch))
+ PyObject *temp;
+ chtype ch;
+
+ PyCursesInitialised
+
+ if (!PyArg_Parse(arg,"O;ch or int",&temp)) return NULL;
+
+ if (PyInt_Check(temp))
+ ch = (chtype) PyInt_AsLong(temp);
+ else if (PyString_Check(temp))
+ ch = (chtype) *PyString_AsString(temp);
+ else {
+ PyErr_SetString(PyExc_TypeError, "argument must be a ch or an int");
return NULL;
- knp = keyname(ch);
- return PyString_FromString((knp == NULL) ? "" : knp);
+ }
+
+ return PyString_FromString(unctrl(ch));
}
-#ifdef NOT_YET
-static PyObject *
-PyCurses_NewTerm(self, args)
+static PyObject *
+PyCurses_UngetCh(self,arg)
PyObject * self;
- PyObject * args;
+ PyObject * arg;
{
+ PyObject *temp;
+ chtype ch;
+
+ PyCursesInitialised
+
+ if (!PyArg_Parse(arg,"O;ch or int",&temp)) return NULL;
+
+ if (PyInt_Check(temp))
+ ch = (chtype) PyInt_AsLong(temp);
+ else if (PyString_Check(temp))
+ ch = (chtype) *PyString_AsString(temp);
+ else {
+ PyErr_SetString(PyExc_TypeError, "argument must be a ch or an int");
+ return NULL;
+ }
+
+ return PyCursesCheckERR(ungetch(ch), "ungetch");
}
-static PyObject *
-PyCurses_SetTerm(self, args)
+static PyObject *
+PyCurses_Use_Env(self,arg)
PyObject * self;
- PyObject * args;
+ PyObject * arg;
{
+ int flag;
+
+ PyCursesInitialised
+
+ switch(ARG_COUNT(arg)) {
+ case 1:
+ if (!PyArg_Parse(arg,"i;True(1), False(0)",&flag))
+ return NULL;
+ break;
+ default:
+ PyErr_SetString(PyExc_TypeError, "use_env requires 1 argument");
+ return NULL;
+ }
+ use_env(flag);
+ Py_INCREF(Py_None);
+ return Py_None;
}
-#endif
/* List of functions defined in the module */
static PyMethodDef PyCurses_methods[] = {
- {"initscr", (PyCFunction)PyCurses_InitScr},
- {"endwin", (PyCFunction)PyCurses_EndWin},
- {"isendwin", (PyCFunction)PyCurses_IsEndWin},
- {"doupdate", (PyCFunction)PyCurses_DoUpdate},
- {"newwin", (PyCFunction)PyCurses_NewWindow},
- {"beep", (PyCFunction)PyCurses_Beep},
- {"flash", (PyCFunction)PyCurses_Flash},
- {"ungetch", (PyCFunction)PyCurses_UngetCh},
- {"flushinp", (PyCFunction)PyCurses_FlushInp},
- {"cbreak", (PyCFunction)PyCurses_CBreak},
- {"nocbreak", (PyCFunction)PyCurses_NoCBreak},
- {"echo", (PyCFunction)PyCurses_Echo},
- {"noecho", (PyCFunction)PyCurses_NoEcho},
- {"nl", (PyCFunction)PyCurses_Nl},
- {"nonl", (PyCFunction)PyCurses_NoNl},
- {"raw", (PyCFunction)PyCurses_Raw},
- {"noraw", (PyCFunction)PyCurses_NoRaw},
- {"intrflush", (PyCFunction)PyCurses_IntrFlush},
- {"meta", (PyCFunction)PyCurses_Meta},
- {"keyname", (PyCFunction)PyCurses_KeyName},
-#ifdef NOT_YET
- {"newterm", (PyCFunction)PyCurses_NewTerm},
- {"set_term", (PyCFunction)PyCurses_SetTerm},
+ {"baudrate", (PyCFunction)PyCurses_baudrate},
+ {"beep", (PyCFunction)PyCurses_beep},
+ {"can_change_color", (PyCFunction)PyCurses_can_change_color},
+ {"cbreak", (PyCFunction)PyCurses_cbreak},
+ {"color_content", (PyCFunction)PyCurses_Color_Content},
+ {"COLOR_PAIR", (PyCFunction)PyCurses_COLOR_PAIR},
+ {"curs_set", (PyCFunction)PyCurses_Curs_Set},
+ {"def_prog_mode", (PyCFunction)PyCurses_def_prog_mode},
+ {"def_shell_mode", (PyCFunction)PyCurses_def_shell_mode},
+ {"delay_output", (PyCFunction)PyCurses_Delay_Output},
+ {"doupdate", (PyCFunction)PyCurses_doupdate},
+ {"echo", (PyCFunction)PyCurses_echo},
+ {"endwin", (PyCFunction)PyCurses_endwin},
+ {"erasechar", (PyCFunction)PyCurses_EraseChar},
+ {"filter", (PyCFunction)PyCurses_filter},
+ {"flash", (PyCFunction)PyCurses_flash},
+ {"flushinp", (PyCFunction)PyCurses_flushinp},
+ {"getsyx", (PyCFunction)PyCurses_getsyx},
+ {"getwin", (PyCFunction)PyCurses_GetWin},
+ {"has_colors", (PyCFunction)PyCurses_has_colors},
+ {"has_ic", (PyCFunction)PyCurses_has_ic},
+ {"has_il", (PyCFunction)PyCurses_has_il},
+#ifndef __sgi__
+ {"has_key", (PyCFunction)PyCurses_has_key},
#endif
- {NULL, NULL} /* sentinel */
+ {"halfdelay", (PyCFunction)PyCurses_HalfDelay},
+ {"init_color", (PyCFunction)PyCurses_Init_Color},
+ {"init_pair", (PyCFunction)PyCurses_Init_Pair},
+ {"initscr", (PyCFunction)PyCurses_InitScr},
+ {"intrflush", (PyCFunction)PyCurses_IntrFlush},
+ {"isendwin", (PyCFunction)PyCurses_isendwin},
+ {"keyname", (PyCFunction)PyCurses_KeyName},
+ {"killchar", (PyCFunction)PyCurses_KillChar},
+ {"longname", (PyCFunction)PyCurses_longname},
+ {"meta", (PyCFunction)PyCurses_Meta},
+ {"newpad", (PyCFunction)PyCurses_NewPad},
+ {"newwin", (PyCFunction)PyCurses_NewWindow},
+ {"nl", (PyCFunction)PyCurses_nl},
+ {"nocbreak", (PyCFunction)PyCurses_nocbreak},
+ {"noecho", (PyCFunction)PyCurses_noecho},
+ {"nonl", (PyCFunction)PyCurses_nonl},
+ {"noqiflush", (PyCFunction)PyCurses_noqiflush},
+ {"noraw", (PyCFunction)PyCurses_noraw},
+ {"pair_content", (PyCFunction)PyCurses_Pair_Content},
+ {"PAIR_NUMBER", (PyCFunction)PyCurses_PAIR_NUMBER},
+ {"putp", (PyCFunction)PyCurses_Putp},
+ {"qiflush", (PyCFunction)PyCurses_QiFlush},
+ {"raw", (PyCFunction)PyCurses_raw},
+ {"reset_prog_mode", (PyCFunction)PyCurses_reset_prog_mode},
+ {"reset_shell_mode", (PyCFunction)PyCurses_reset_shell_mode},
+ {"setsyx", (PyCFunction)PyCurses_setsyx},
+ {"start_color", (PyCFunction)PyCurses_Start_Color},
+ {"termattrs", (PyCFunction)PyCurses_termattrs},
+ {"termname", (PyCFunction)PyCurses_termname},
+ {"unctrl", (PyCFunction)PyCurses_UnCtrl},
+ {"ungetch", (PyCFunction)PyCurses_UngetCh},
+ {"use_env", (PyCFunction)PyCurses_Use_Env},
+ {NULL, NULL} /* sentinel */
};
/* Initialization function for the module */
-DL_EXPORT(void)
+void
initcurses()
{
PyObject *m, *d, *v;
@@ -1552,7 +2112,7 @@ initcurses()
ModDict = d; /* For PyCurses_InitScr */
/* For exception curses.error */
- PyCursesError = PyErr_NewException("curses.error", NULL, NULL);
+ PyCursesError = PyString_FromString("curses.error");
PyDict_SetItemString(d, "error", PyCursesError);
/* Make the version available */
@@ -1562,14 +2122,107 @@ initcurses()
Py_DECREF(v);
/* Here are some attributes you can add to chars to print */
- SetDictInt("A_NORMAL", A_NORMAL);
- SetDictInt("A_STANDOUT", A_STANDOUT);
- SetDictInt("A_UNDERLINE", A_UNDERLINE);
- SetDictInt("A_REVERSE", A_REVERSE);
- SetDictInt("A_BLINK", A_BLINK);
- SetDictInt("A_DIM", A_DIM);
- SetDictInt("A_BOLD", A_BOLD);
- SetDictInt("A_ALTCHARSET", A_ALTCHARSET);
+
+#define SetDictInt(string,ch) \
+ PyDict_SetItemString(ModDict,string,PyInt_FromLong((long) (ch)));
+
+#ifndef __sgi__
+ /* On IRIX 5.3, the ACS characters aren't available until initscr() has been called. */
+ SetDictInt("ACS_ULCORNER", (ACS_ULCORNER));
+ SetDictInt("ACS_LLCORNER", (ACS_LLCORNER));
+ SetDictInt("ACS_URCORNER", (ACS_URCORNER));
+ SetDictInt("ACS_LRCORNER", (ACS_LRCORNER));
+ SetDictInt("ACS_LTEE", (ACS_LTEE));
+ SetDictInt("ACS_RTEE", (ACS_RTEE));
+ SetDictInt("ACS_BTEE", (ACS_BTEE));
+ SetDictInt("ACS_TTEE", (ACS_TTEE));
+ SetDictInt("ACS_HLINE", (ACS_HLINE));
+ SetDictInt("ACS_VLINE", (ACS_VLINE));
+ SetDictInt("ACS_PLUS", (ACS_PLUS));
+ SetDictInt("ACS_S1", (ACS_S1));
+ SetDictInt("ACS_S9", (ACS_S9));
+ SetDictInt("ACS_DIAMOND", (ACS_DIAMOND));
+ SetDictInt("ACS_CKBOARD", (ACS_CKBOARD));
+ SetDictInt("ACS_DEGREE", (ACS_DEGREE));
+ SetDictInt("ACS_PLMINUS", (ACS_PLMINUS));
+ SetDictInt("ACS_BULLET", (ACS_BULLET));
+ SetDictInt("ACS_LARROW", (ACS_LARROW));
+ SetDictInt("ACS_RARROW", (ACS_RARROW));
+ SetDictInt("ACS_DARROW", (ACS_DARROW));
+ SetDictInt("ACS_UARROW", (ACS_UARROW));
+ SetDictInt("ACS_BOARD", (ACS_BOARD));
+ SetDictInt("ACS_LANTERN", (ACS_LANTERN));
+ SetDictInt("ACS_BLOCK", (ACS_BLOCK));
+#ifndef __sgi__
+ /* The following are never available on IRIX 5.3 */
+ SetDictInt("ACS_S3", (ACS_S3));
+ SetDictInt("ACS_LEQUAL", (ACS_LEQUAL));
+ SetDictInt("ACS_GEQUAL", (ACS_GEQUAL));
+ SetDictInt("ACS_PI", (ACS_PI));
+ SetDictInt("ACS_NEQUAL", (ACS_NEQUAL));
+ SetDictInt("ACS_STERLING", (ACS_STERLING));
+#endif
+ SetDictInt("ACS_BSSB", (ACS_ULCORNER));
+ SetDictInt("ACS_SSBB", (ACS_LLCORNER));
+ SetDictInt("ACS_BBSS", (ACS_URCORNER));
+ SetDictInt("ACS_SBBS", (ACS_LRCORNER));
+ SetDictInt("ACS_SBSS", (ACS_RTEE));
+ SetDictInt("ACS_SSSB", (ACS_LTEE));
+ SetDictInt("ACS_SSBS", (ACS_BTEE));
+ SetDictInt("ACS_BSSS", (ACS_TTEE));
+ SetDictInt("ACS_BSBS", (ACS_HLINE));
+ SetDictInt("ACS_SBSB", (ACS_VLINE));
+ SetDictInt("ACS_SSSS", (ACS_PLUS));
+#endif
+
+ SetDictInt("A_ATTRIBUTES", A_ATTRIBUTES);
+ SetDictInt("A_NORMAL", A_NORMAL);
+ SetDictInt("A_STANDOUT", A_STANDOUT);
+ SetDictInt("A_UNDERLINE", A_UNDERLINE);
+ SetDictInt("A_REVERSE", A_REVERSE);
+ SetDictInt("A_BLINK", A_BLINK);
+ SetDictInt("A_DIM", A_DIM);
+ SetDictInt("A_BOLD", A_BOLD);
+ SetDictInt("A_ALTCHARSET", A_ALTCHARSET);
+ SetDictInt("A_INVIS", A_INVIS);
+ SetDictInt("A_PROTECT", A_PROTECT);
+#ifndef __sgi__
+ SetDictInt("A_HORIZONTAL", A_HORIZONTAL);
+ SetDictInt("A_LEFT", A_LEFT);
+ SetDictInt("A_LOW", A_LOW);
+ SetDictInt("A_RIGHT", A_RIGHT);
+ SetDictInt("A_TOP", A_TOP);
+ SetDictInt("A_VERTICAL", A_VERTICAL);
+#endif
+ SetDictInt("A_CHARTEXT", A_CHARTEXT);
+ SetDictInt("A_COLOR", A_COLOR);
+#ifndef __sgi__
+ SetDictInt("WA_ATTRIBUTES", WA_ATTRIBUTES);
+ SetDictInt("WA_NORMAL", WA_NORMAL);
+ SetDictInt("WA_STANDOUT", WA_STANDOUT);
+ SetDictInt("WA_UNDERLINE", WA_UNDERLINE);
+ SetDictInt("WA_REVERSE", WA_REVERSE);
+ SetDictInt("WA_BLINK", WA_BLINK);
+ SetDictInt("WA_DIM", WA_DIM);
+ SetDictInt("WA_BOLD", WA_BOLD);
+ SetDictInt("WA_ALTCHARSET", WA_ALTCHARSET);
+ SetDictInt("WA_INVIS", WA_INVIS);
+ SetDictInt("WA_PROTECT", WA_PROTECT);
+ SetDictInt("WA_HORIZONTAL", WA_HORIZONTAL);
+ SetDictInt("WA_LEFT", WA_LEFT);
+ SetDictInt("WA_LOW", WA_LOW);
+ SetDictInt("WA_RIGHT", WA_RIGHT);
+ SetDictInt("WA_TOP", WA_TOP);
+ SetDictInt("WA_VERTICAL", WA_VERTICAL);
+#endif
+ SetDictInt("COLOR_BLACK", COLOR_BLACK);
+ SetDictInt("COLOR_RED", COLOR_RED);
+ SetDictInt("COLOR_GREEN", COLOR_GREEN);
+ SetDictInt("COLOR_YELLOW", COLOR_YELLOW);
+ SetDictInt("COLOR_BLUE", COLOR_BLUE);
+ SetDictInt("COLOR_MAGENTA", COLOR_MAGENTA);
+ SetDictInt("COLOR_CYAN", COLOR_CYAN);
+ SetDictInt("COLOR_WHITE", COLOR_WHITE);
/* Now set everything up for KEY_ variables */
{
@@ -1602,4 +2255,10 @@ initcurses()
SetDictInt("KEY_MIN", KEY_MIN);
SetDictInt("KEY_MAX", KEY_MAX);
}
+
+ /* Check for errors */
+ if (PyErr_Occurred())
+ Py_FatalError("can't initialize module curses");
}
+
+