diff options
author | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2002-03-24 01:09:04 (GMT) |
---|---|---|
committer | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2002-03-24 01:09:04 (GMT) |
commit | 0f75e0dcad9b193fc11855b5c59d4c9bd42e533f (patch) | |
tree | 412f09e46de859163fee0f77561fd46f9ed9c5c9 /Modules/readline.c | |
parent | e085017ab7121b27be315d36ef0c25ed51484023 (diff) | |
download | cpython-0f75e0dcad9b193fc11855b5c59d4c9bd42e533f.zip cpython-0f75e0dcad9b193fc11855b5c59d4c9bd42e533f.tar.gz cpython-0f75e0dcad9b193fc11855b5c59d4c9bd42e533f.tar.bz2 |
Add get_history_item, get_current_history_length, and redisplay functions.
Clarify the docstring for get_history_length. Closes SF patch 494066.
Diffstat (limited to 'Modules/readline.c')
-rw-r--r-- | Modules/readline.c | 63 |
1 files changed, 61 insertions, 2 deletions
diff --git a/Modules/readline.c b/Modules/readline.c index 94aa1db..e573773 100644 --- a/Modules/readline.c +++ b/Modules/readline.c @@ -143,7 +143,8 @@ set_history_length(PyObject *self, PyObject *args) static char get_history_length_doc[] = "\ get_history_length() -> int\n\ -return the current history length value.\n\ +return the maximum number of items that will be written to\n\ +the history file.\n\ "; static PyObject* @@ -332,6 +333,47 @@ for state in 0, 1, 2, ..., until it returns a non-string.\n\ It should return the next possible completion starting with 'text'.\ "; +/* Exported function to get any element of history */ + +static PyObject * +get_history_item(PyObject *self, PyObject *args) +{ + int idx = 0; + HIST_ENTRY *hist_ent; + + if (!PyArg_ParseTuple(args, "i:index", &idx)) + return NULL; + if ((hist_ent = history_get(idx))) + return PyString_FromString(hist_ent->line); + else { + Py_INCREF(Py_None); + return Py_None; + } +} + +static char doc_get_history_item[] = "\ +get_history_item() -> string\n\ +return the current contents of history item at index.\ +"; + +/* Exported function to get current length of history */ + +static PyObject * +get_current_history_length(PyObject *self, PyObject *args) +{ + HISTORY_STATE *hist_st; + + if (!PyArg_NoArgs(args)) + return NULL; + hist_st = history_get_history_state(); + return PyInt_FromLong(hist_st ? (long) hist_st->length : (long) 0); +} + +static char doc_get_current_history_length[] = "\ +get_current_history_length() -> integer\n\ +return the current (not the maximum) length of history.\ +"; + /* Exported function to read the current line buffer */ static PyObject * @@ -360,12 +402,24 @@ insert_text(PyObject *self, PyObject *args) return Py_None; } - static char doc_insert_text[] = "\ insert_text(string) -> None\n\ Insert text into the command line.\ "; +static PyObject * +redisplay(PyObject *self) +{ + rl_redisplay(); + Py_INCREF(Py_None); + return Py_None; +} + +static char doc_redisplay[] = "\ +redisplay() -> None\n\ +Change what's displayed on the screen to reflect the current\n\ +contents of the line buffer.\ +"; /* Table of functions exported by the module */ @@ -375,11 +429,16 @@ static struct PyMethodDef readline_methods[] = {"get_line_buffer", get_line_buffer, METH_OLDARGS, doc_get_line_buffer}, {"insert_text", insert_text, METH_VARARGS, doc_insert_text}, + {"redisplay", (PyCFunction)redisplay, METH_NOARGS, doc_redisplay}, {"read_init_file", read_init_file, METH_VARARGS, doc_read_init_file}, {"read_history_file", read_history_file, METH_VARARGS, doc_read_history_file}, {"write_history_file", write_history_file, METH_VARARGS, doc_write_history_file}, + {"get_history_item", get_history_item, + METH_VARARGS, doc_get_history_item}, + {"get_current_history_length", get_current_history_length, + METH_OLDARGS, doc_get_current_history_length}, {"set_history_length", set_history_length, METH_VARARGS, set_history_length_doc}, {"get_history_length", get_history_length, |