mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-19 17:18:24 +08:00
* defs.h (read_command_lines, query_hook): Update prototypes.
(readline_begin_hook, readline_hook, readline_end_hook): Declare. * breakpoint.c (commands_command): Build message in temporary buffer and pass that, as well as tty control flag, to read_command_lines. * top.c (readline_begin_hook, readline_hook, readline_end_hook): Define here. (command_loop): Check for non-NULL instream before looping. (command_line_input): Use readline_hook when appropriate, to get user input from a GUI window. (read_next_line): Also build prompt if getting user input from a GUI. (recurse_read_control_structure): Fix typo in comment. (read_command_lines): Use passed in prompt and tty flag to decide how to build message. Use readline_begin_hook when appropriate, to set up a GUI interaction window. Just return head, whether NULL or not, after using readline_end_hook to complete GUI interaction. (define_command, document_command): Build message in a temporary buffer and pass it to read_command_lines, along with tty flag. * gdbtk.c (gdbtk_readline_begin, gdbtk_readline, gdbtk_readline_end): New functions. (tk_command_loop): Set instream to NULL to enable Tk user interaction. (gdbtk_init): Set readline_begin_hook, readline_hook, and readline_end_hook. * gdbtk.tcl (gdbtk_tcl_readline_begin, gdbtk_tcl_readline, gdbtk_tcl_readline_end): New functions. (tclsh): Pack scroll bar on right side of window, not left. PR 9385
This commit is contained in:
@ -265,6 +265,86 @@ proc gdbtk_tcl_breakpoint {action bpnum} {
|
||||
${action}_breakpoint $bpnum $file $line $pc
|
||||
}
|
||||
|
||||
#
|
||||
# GDB Callback:
|
||||
#
|
||||
# gdbtk_tcl_readline_begin (message) - Notify Tk to open an interaction
|
||||
# window and start gathering user input
|
||||
#
|
||||
# Description:
|
||||
#
|
||||
# GDB calls this to notify TK that it needs to open an interaction
|
||||
# window, displaying the given message, and be prepared to accept
|
||||
# calls to gdbtk_tcl_readline to gather user input.
|
||||
|
||||
proc gdbtk_tcl_readline_begin {message} {
|
||||
global readline_text
|
||||
|
||||
# If another readline window already exists, just bring it to the front.
|
||||
if {[winfo exists .rl]} {raise .rl ; return}
|
||||
|
||||
# Create top level frame with scrollbar and text widget.
|
||||
toplevel .rl
|
||||
wm title .rl "Interaction Window"
|
||||
wm iconname .rl "Input"
|
||||
message .rl.msg -text $message -aspect 7500 -justify left
|
||||
text .rl.text -width 80 -height 20 -setgrid true -cursor hand2 \
|
||||
-yscrollcommand {.rl.scroll set}
|
||||
scrollbar .rl.scroll -command {.rl.text yview}
|
||||
pack .rl.msg -side top -fill x
|
||||
pack .rl.scroll -side right -fill y
|
||||
pack .rl.text -side left -fill both -expand true
|
||||
|
||||
# When the user presses return, get the text from the command start mark to the
|
||||
# current insert point, stash it in the readline text variable, and update the
|
||||
# command start mark to the current insert point
|
||||
bind .rl.text <Return> {
|
||||
set readline_text [.rl.text get cmdstart {end - 1 char}]
|
||||
.rl.text mark set cmdstart insert
|
||||
}
|
||||
bindtags .rl.text {.rl.text Text all}
|
||||
}
|
||||
|
||||
#
|
||||
# GDB Callback:
|
||||
#
|
||||
# gdbtk_tcl_readline (prompt) - Get one user input line
|
||||
#
|
||||
# Description:
|
||||
#
|
||||
# GDB calls this to get one line of input from the user interaction
|
||||
# window, using "prompt" as the command line prompt.
|
||||
|
||||
proc gdbtk_tcl_readline {prompt} {
|
||||
global readline_text
|
||||
|
||||
.rl.text insert end $prompt
|
||||
.rl.text mark set cmdstart insert
|
||||
.rl.text mark gravity cmdstart left
|
||||
.rl.text see insert
|
||||
|
||||
# Make this window the current one for input.
|
||||
focus .rl.text
|
||||
grab .rl
|
||||
tkwait variable readline_text
|
||||
grab release .rl
|
||||
return $readline_text
|
||||
}
|
||||
|
||||
#
|
||||
# GDB Callback:
|
||||
#
|
||||
# gdbtk_tcl_readline_end - Terminate a user interaction
|
||||
#
|
||||
# Description:
|
||||
#
|
||||
# GDB calls this when it is done getting interactive user input.
|
||||
# Destroy the interaction window.
|
||||
|
||||
proc gdbtk_tcl_readline_end {} {
|
||||
if {[winfo exists .rl]} { destroy .rl }
|
||||
}
|
||||
|
||||
proc create_breakpoints_window {} {
|
||||
global bpframe_lasty
|
||||
|
||||
@ -3149,8 +3229,8 @@ proc tclsh {} {
|
||||
text .eval.text -width 80 -height 20 -setgrid true -cursor hand2 \
|
||||
-yscrollcommand {.eval.scroll set}
|
||||
scrollbar .eval.scroll -command {.eval.text yview}
|
||||
pack .eval.scroll -side left -fill y
|
||||
pack .eval.text -side right -fill both -expand true
|
||||
pack .eval.scroll -side right -fill y
|
||||
pack .eval.text -side left -fill both -expand true
|
||||
|
||||
# Insert the tcl_prompt and initialize the cmdstart mark
|
||||
.eval.text insert insert $tcl_prompt
|
||||
|
Reference in New Issue
Block a user