homepage

This issue tracker has been migrated to GitHub , and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: Export more libreadline API functions
Type: enhancement Stage: test needed
Components: Extension Modules Versions: Python 3.2
process
Status: open Resolution:
Dependencies: 23067 Superseder:
Assigned To: Nosy List: bruce_edge, loewis, martin.panter, mwh, ned.deily, sa, strank
Priority: normal Keywords: patch

Created on 2005年04月01日 19:30 by bruce_edge, last changed 2022年04月11日 14:56 by admin.

Files
File name Uploaded Description Edit
export_more_libreadline_api.patch bruce_edge, 2005年04月04日 15:25 API expansion patch, with docs this time
Messages (10)
msg48122 - (view) Author: Bruce Edge (bruce_edge) Date: 2005年04月01日 19:30
The python readline.c is missing several of the API
funcs provided by libreadline. This patch adds the
missing ones that I needed.
Add support for libreadline callbacks to python functions.
eg:
readline.set_py_callback_hook( my_func )
Also, export rl_delete_text, rl_message,
rl_on_new_line, rl_forced_update_display,
rl_position_cursor
-Bruce
msg48123 - (view) Author: Martin v. Löwis (loewis) * (Python committer) Date: 2005年04月01日 20:57
Logged In: YES 
user_id=21627
Have these function always been available in readline (i.e.
all readline versions)? If not, please provide configure.in
changes.
Also, please provide Doc/lib/libreadline.tex changes.
If you cannot provide these things, please indicate so.
msg48124 - (view) Author: Bruce Edge (bruce_edge) Date: 2005年04月01日 21:16
Logged In: YES 
user_id=1251183
AFAIK, yes, they have always been available, at least in
Linux. I've been carrying this patch around since python 2.1.
I have not looked into this on other platforms.
I can't commit to providing doc changes. With my schedule,
it was all I could do to package it up and send it in. 
I'm sorry, I know this is incomplete work, but I figure
someone may be able to use it.
-Bruce
msg48125 - (view) Author: Martin v. Löwis (loewis) * (Python committer) Date: 2005年04月01日 21:31
Logged In: YES 
user_id=21627
As incomplete work, we might have to reject it, unless
somebody volunteers to complete it. Let's give it one month
from now.
msg48126 - (view) Author: Bruce Edge (bruce_edge) Date: 2005年04月04日 15:25
Logged In: YES 
user_id=1251183
I got the OK to work on the docs. Here's the patch
resubmitted with the libreadline.tex changes.
-Bruce
msg48127 - (view) Author: Michael Hudson (mwh) (Python committer) Date: 2005年04月11日 00:00
Logged In: YES 
user_id=6656
I've just broken this patch by changing the signature of the set_hook/
on_hook functions.
There seem to be some whitespace oddities (e.g. right at the start of the 
patch).
The docstrings should use the PyDoc_STRVAR macros.
I'm not sure about some of the details of the py_callback stuff (although 
the functionality seems desirable):
1) the name -- I think I'd find python_command more transparent
2) it would be nice to pass the count and key arguments to the Python 
callable
3) the comments around it's implementation don't make much sense to 
me.
4) the example in the docs -- which is what finally clued me in to what the 
function did :) -- isn't self-contained.
None of this should be very hard to deal with, but I don't know when/if I'd 
get round to it myself.
msg93159 - (view) Author: Simon Arlott (sa) Date: 2009年09月26日 11:48
Access to rl_reset_line_state (and possibly others in the Redisplay
section) are also required, otherwise it's not possible to recover from
KeyboardInterrupt during raw_input() if readline isn't in the expected
editing mode.
Example:
 1. call raw_input() and use ctrl-R (reverse-i-search)
 2. catch a KeyboardInterrupt
 3. call raw_input() again
The input editing is still in reverse-i-search mode.
This makes it impractical to use raw_input() again after
KeyboardInterrupt because the input buffer may be in an unknown state.
If the history is modified then the search will break and character
input will appear to be ignored.
Note: It may be desirable to stay in this mode and call raw_input()
again, ignoring KeyboardInterrupt entirely (although the prompt is
redisplayed when exiting search mode so that doesn't currently work
cleanly), so it can't just auto-reset on KeyboardInterrupt.
The documentation should explain how to resume after KeyboardInterrupt
safely.
msg116708 - (view) Author: Ned Deily (ned.deily) * (Python committer) Date: 2010年09月17日 18:48
Issue1744456 contains a different patch to implement readline callbacks. Suggest that anyone moving forward with this review both patches.
msg247841 - (view) Author: Martin Panter (martin.panter) * (Python committer) Date: 2015年08月02日 00:41
Simon: See Issue 24266 about recovering after interrupting the search mode.
Also, I think Issue 1744456 wraps a different part of the Readline API (rl_callback_ for non-blocking interface) to the patch here (rl_add_defun for adding a custom "key binding" or something). So the two patches could be considered independently.
msg247848 - (view) Author: Martin Panter (martin.panter) * (Python committer) Date: 2015年08月02日 01:26
rl_forced_update_display() wrappers already proposed in Issue 23067 
History
Date User Action Args
2022年04月11日 14:56:10adminsetgithub: 41788
2015年08月02日 01:26:19martin.pantersetdependencies: + Export readline forced_update_display
messages: + msg247848
2015年08月02日 00:41:55martin.pantersetnosy: + martin.panter
messages: + msg247841
2010年09月23日 10:20:33stranksetnosy: + strank
2010年09月17日 18:48:02ned.deilysetnosy: + ned.deily
messages: + msg116708
2010年09月17日 18:46:29ned.deilylinkissue1744456 superseder
2010年08月21日 12:49:34BreamoreBoysetversions: + Python 3.2, - Python 2.7
2009年09月26日 11:48:34sasetnosy: + sa
messages: + msg93159
2009年02月15日 22:15:38ajaksu2setstage: test needed
type: enhancement
versions: + Python 2.7, - Python 2.4
2005年04月01日 19:30:23bruce_edgecreate

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