* tuiWin.c, tuiWin.h, tui.c, tui.h, tuiCommand.c: Add FSF copyright.
tuiCommand.h, tuiIO.c, tuiIO.h, tuiData.h, tuiData.c: Likewise.
tuiDataWin.c, tuiDataWin.h, tuiDisassem.c, tuiDisassem.h: Likewise.
tuiGeneralWin.c, tuiGeneralWin.h, tuiLayout.c, tuiLayout.h: Likewise.
tuiRegs.c, tuiRegs.h, tuiSource.c, tuiSource.h: Likewise.
tuiSouceWin.c, tuiSourceWin.h, tuiStack.c, tuiStack.h: Likewise.
2001-07-14 19:01:25 +00:00
|
|
|
/* General functions for the WDB TUI.
|
2002-03-01 06:19:28 +00:00
|
|
|
|
2003-06-22 15:21:39 +00:00
|
|
|
Copyright 1998, 1999, 2000, 2001, 2002, 2003 Free Software Foundation,
|
2002-03-01 06:19:28 +00:00
|
|
|
Inc.
|
|
|
|
|
* tuiWin.c, tuiWin.h, tui.c, tui.h, tuiCommand.c: Add FSF copyright.
tuiCommand.h, tuiIO.c, tuiIO.h, tuiData.h, tuiData.c: Likewise.
tuiDataWin.c, tuiDataWin.h, tuiDisassem.c, tuiDisassem.h: Likewise.
tuiGeneralWin.c, tuiGeneralWin.h, tuiLayout.c, tuiLayout.h: Likewise.
tuiRegs.c, tuiRegs.h, tuiSource.c, tuiSource.h: Likewise.
tuiSouceWin.c, tuiSourceWin.h, tuiStack.c, tuiStack.h: Likewise.
2001-07-14 19:01:25 +00:00
|
|
|
Contributed by Hewlett-Packard Company.
|
|
|
|
|
|
|
|
This file is part of GDB.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
Boston, MA 02111-1307, USA. */
|
1999-04-16 01:35:26 +00:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <ctype.h>
|
|
|
|
#include <malloc.h>
|
|
|
|
#ifdef HAVE_TERM_H
|
|
|
|
#include <term.h>
|
|
|
|
#endif
|
|
|
|
#include <signal.h>
|
|
|
|
#include <fcntl.h>
|
2002-08-18 23:20:47 +00:00
|
|
|
#if 0
|
1999-04-16 01:35:26 +00:00
|
|
|
#include <termio.h>
|
2002-08-18 23:20:47 +00:00
|
|
|
#endif
|
1999-04-16 01:35:26 +00:00
|
|
|
#include <setjmp.h>
|
|
|
|
#include "defs.h"
|
|
|
|
#include "gdbcmd.h"
|
|
|
|
#include "tui.h"
|
|
|
|
#include "tuiData.h"
|
|
|
|
#include "tuiLayout.h"
|
|
|
|
#include "tuiIO.h"
|
|
|
|
#include "tuiRegs.h"
|
2001-07-21 20:49:56 +00:00
|
|
|
#include "tuiStack.h"
|
1999-04-16 01:35:26 +00:00
|
|
|
#include "tuiWin.h"
|
2001-07-23 21:13:57 +00:00
|
|
|
#include "tuiSourceWin.h"
|
2003-07-24 20:23:17 +00:00
|
|
|
#include "tuiDataWin.h"
|
2001-07-21 19:59:14 +00:00
|
|
|
#include "readline/readline.h"
|
|
|
|
#include "target.h"
|
|
|
|
#include "frame.h"
|
|
|
|
#include "breakpoint.h"
|
2001-07-23 21:13:57 +00:00
|
|
|
#include "inferior.h"
|
2002-09-30 00:52:27 +00:00
|
|
|
#include "symtab.h"
|
|
|
|
#include "source.h"
|
2001-07-21 19:59:14 +00:00
|
|
|
|
2003-06-22 15:21:39 +00:00
|
|
|
#ifdef HAVE_NCURSES_H
|
|
|
|
#include <ncurses.h>
|
|
|
|
#else
|
|
|
|
#ifdef HAVE_CURSES_H
|
|
|
|
#include <curses.h>
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* Tells whether the TUI is active or not. */
|
|
|
|
int tui_active = 0;
|
|
|
|
static int tui_finish_init = 1;
|
|
|
|
|
2002-08-31 12:02:14 +00:00
|
|
|
enum tui_key_mode tui_current_key_mode = tui_command_mode;
|
|
|
|
|
|
|
|
struct tui_char_command
|
|
|
|
{
|
|
|
|
unsigned char key;
|
|
|
|
const char* cmd;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Key mapping to gdb commands when the TUI is using the single key mode. */
|
|
|
|
static const struct tui_char_command tui_commands[] = {
|
|
|
|
{ 'c', "continue" },
|
|
|
|
{ 'd', "down" },
|
|
|
|
{ 'f', "finish" },
|
|
|
|
{ 'n', "next" },
|
|
|
|
{ 'r', "run" },
|
|
|
|
{ 's', "step" },
|
|
|
|
{ 'u', "up" },
|
|
|
|
{ 'v', "info locals" },
|
|
|
|
{ 'w', "where" },
|
|
|
|
{ 0, 0 },
|
|
|
|
};
|
|
|
|
|
|
|
|
static Keymap tui_keymap;
|
|
|
|
static Keymap tui_readline_standard_keymap;
|
|
|
|
|
|
|
|
/* TUI readline command.
|
|
|
|
Switch the output mode between TUI/standard gdb. */
|
2001-07-21 19:59:14 +00:00
|
|
|
static int
|
2003-02-12 15:14:36 +00:00
|
|
|
tui_rl_switch_mode (int notused1, int notused2)
|
1999-04-16 01:35:26 +00:00
|
|
|
{
|
2001-07-21 19:59:14 +00:00
|
|
|
if (tui_active)
|
1999-04-16 01:35:26 +00:00
|
|
|
{
|
2001-07-21 19:59:14 +00:00
|
|
|
tui_disable ();
|
2001-07-23 21:13:57 +00:00
|
|
|
rl_prep_terminal (0);
|
2001-07-21 19:59:14 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2001-07-23 21:13:57 +00:00
|
|
|
rl_deprep_terminal ();
|
2001-07-21 19:59:14 +00:00
|
|
|
tui_enable ();
|
1999-04-16 01:35:26 +00:00
|
|
|
}
|
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* Clear the readline in case switching occurred in middle of something. */
|
|
|
|
if (rl_end)
|
|
|
|
rl_kill_text (0, rl_end);
|
|
|
|
|
|
|
|
/* Since we left the curses mode, the terminal mode is restored to
|
|
|
|
some previous state. That state may not be suitable for readline
|
|
|
|
to work correctly (it may be restored in line mode). We force an
|
|
|
|
exit of the current readline so that readline is re-entered and it
|
|
|
|
will be able to setup the terminal for its needs. By re-entering
|
|
|
|
in readline, we also redisplay its prompt in the non-curses mode. */
|
|
|
|
rl_newline (1, '\n');
|
2001-07-23 21:13:57 +00:00
|
|
|
|
|
|
|
/* Make sure the \n we are returning does not repeat the last command. */
|
|
|
|
dont_repeat ();
|
2001-07-21 19:59:14 +00:00
|
|
|
return 0;
|
|
|
|
}
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2002-08-25 21:44:41 +00:00
|
|
|
/* TUI readline command.
|
|
|
|
Change the TUI layout to show a next layout.
|
2001-07-21 20:49:56 +00:00
|
|
|
This function is bound to CTRL-X 2. It is intended to provide
|
|
|
|
a functionality close to the Emacs split-window command. We always
|
|
|
|
show two windows (src+asm), (src+regs) or (asm+regs). */
|
|
|
|
static int
|
2003-02-12 15:14:36 +00:00
|
|
|
tui_rl_change_windows (int notused1, int notused2)
|
2001-07-21 20:49:56 +00:00
|
|
|
{
|
|
|
|
if (!tui_active)
|
2003-02-12 15:14:36 +00:00
|
|
|
tui_rl_switch_mode (0/*notused*/, 0/*notused*/);
|
2001-07-21 20:49:56 +00:00
|
|
|
|
|
|
|
if (tui_active)
|
|
|
|
{
|
|
|
|
TuiLayoutType new_layout;
|
|
|
|
TuiRegisterDisplayType regs_type = TUI_UNDEFINED_REGS;
|
|
|
|
|
|
|
|
new_layout = currentLayout ();
|
|
|
|
|
|
|
|
/* Select a new layout to have a rolling layout behavior
|
|
|
|
with always two windows (except when undefined). */
|
|
|
|
switch (new_layout)
|
|
|
|
{
|
|
|
|
case SRC_COMMAND:
|
|
|
|
new_layout = SRC_DISASSEM_COMMAND;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case DISASSEM_COMMAND:
|
|
|
|
new_layout = SRC_DISASSEM_COMMAND;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SRC_DATA_COMMAND:
|
|
|
|
new_layout = SRC_DISASSEM_COMMAND;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SRC_DISASSEM_COMMAND:
|
|
|
|
new_layout = DISASSEM_DATA_COMMAND;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case DISASSEM_DATA_COMMAND:
|
|
|
|
new_layout = SRC_DATA_COMMAND;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
new_layout = SRC_COMMAND;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
tuiSetLayout (new_layout, regs_type);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2002-08-25 21:44:41 +00:00
|
|
|
/* TUI readline command.
|
|
|
|
Delete the second TUI window to only show one. */
|
2001-07-21 20:49:56 +00:00
|
|
|
static int
|
2003-02-12 15:14:36 +00:00
|
|
|
tui_rl_delete_other_windows (int notused1, int notused2)
|
2001-07-21 20:49:56 +00:00
|
|
|
{
|
|
|
|
if (!tui_active)
|
2003-02-12 15:14:36 +00:00
|
|
|
tui_rl_switch_mode (0/*notused*/, 0/*notused*/);
|
2001-07-21 20:49:56 +00:00
|
|
|
|
|
|
|
if (tui_active)
|
|
|
|
{
|
|
|
|
TuiLayoutType new_layout;
|
|
|
|
TuiRegisterDisplayType regs_type = TUI_UNDEFINED_REGS;
|
|
|
|
|
|
|
|
new_layout = currentLayout ();
|
|
|
|
|
|
|
|
/* Kill one window. */
|
|
|
|
switch (new_layout)
|
|
|
|
{
|
|
|
|
case SRC_COMMAND:
|
|
|
|
case SRC_DATA_COMMAND:
|
|
|
|
case SRC_DISASSEM_COMMAND:
|
|
|
|
default:
|
|
|
|
new_layout = SRC_COMMAND;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case DISASSEM_COMMAND:
|
|
|
|
case DISASSEM_DATA_COMMAND:
|
|
|
|
new_layout = DISASSEM_COMMAND;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
tuiSetLayout (new_layout, regs_type);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2003-07-24 20:23:17 +00:00
|
|
|
/* TUI readline command.
|
|
|
|
Switch the active window to give the focus to a next window. */
|
|
|
|
static int
|
|
|
|
tui_rl_other_window (int count, int key)
|
|
|
|
{
|
|
|
|
TuiWinInfoPtr winInfo;
|
|
|
|
|
|
|
|
if (!tui_active)
|
|
|
|
tui_rl_switch_mode (0/*notused*/, 0/*notused*/);
|
|
|
|
|
|
|
|
winInfo = tuiNextWin (tuiWinWithFocus ());
|
|
|
|
if (winInfo)
|
|
|
|
{
|
|
|
|
tuiSetWinFocusTo (winInfo);
|
|
|
|
if (dataWin && dataWin->generic.isVisible)
|
|
|
|
tuiRefreshDataWin ();
|
|
|
|
keypad (cmdWin->generic.handle, (winInfo != cmdWin));
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2002-08-31 12:02:14 +00:00
|
|
|
/* TUI readline command.
|
|
|
|
Execute the gdb command bound to the specified key. */
|
|
|
|
static int
|
|
|
|
tui_rl_command_key (int count, int key)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
reinitialize_more_filter ();
|
|
|
|
for (i = 0; tui_commands[i].cmd; i++)
|
|
|
|
{
|
|
|
|
if (tui_commands[i].key == key)
|
|
|
|
{
|
|
|
|
/* Must save the command because it can be modified
|
|
|
|
by execute_command. */
|
|
|
|
char* cmd = alloca (strlen (tui_commands[i].cmd) + 1);
|
|
|
|
strcpy (cmd, tui_commands[i].cmd);
|
|
|
|
execute_command (cmd, TRUE);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* TUI readline command.
|
|
|
|
Temporarily leave the TUI SingleKey mode to allow editing
|
|
|
|
a gdb command with the normal readline. Once the command
|
|
|
|
is executed, the TUI SingleKey mode is installed back. */
|
|
|
|
static int
|
|
|
|
tui_rl_command_mode (int count, int key)
|
|
|
|
{
|
|
|
|
tui_set_key_mode (tui_one_command_mode);
|
|
|
|
return rl_insert (count, key);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* TUI readline command.
|
|
|
|
Switch between TUI SingleKey mode and gdb readline editing. */
|
|
|
|
static int
|
2003-02-12 15:14:36 +00:00
|
|
|
tui_rl_next_keymap (int notused1, int notused2)
|
2002-08-31 12:02:14 +00:00
|
|
|
{
|
2003-07-24 20:23:17 +00:00
|
|
|
if (!tui_active)
|
|
|
|
tui_rl_switch_mode (0/*notused*/, 0/*notused*/);
|
|
|
|
|
2002-08-31 12:02:14 +00:00
|
|
|
tui_set_key_mode (tui_current_key_mode == tui_command_mode
|
|
|
|
? tui_single_key_mode : tui_command_mode);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Readline hook to redisplay ourself the gdb prompt.
|
|
|
|
In the SingleKey mode, the prompt is not printed so that
|
|
|
|
the command window is cleaner. It will be displayed if
|
|
|
|
we temporarily leave the SingleKey mode. */
|
|
|
|
static int
|
|
|
|
tui_rl_startup_hook ()
|
|
|
|
{
|
2002-09-03 20:47:48 +00:00
|
|
|
rl_already_prompted = 1;
|
|
|
|
if (tui_current_key_mode != tui_command_mode)
|
|
|
|
tui_set_key_mode (tui_single_key_mode);
|
|
|
|
tui_redisplay_readline ();
|
2002-08-31 12:02:14 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Change the TUI key mode by installing the appropriate readline keymap. */
|
|
|
|
void
|
|
|
|
tui_set_key_mode (enum tui_key_mode mode)
|
|
|
|
{
|
|
|
|
tui_current_key_mode = mode;
|
|
|
|
rl_set_keymap (mode == tui_single_key_mode
|
|
|
|
? tui_keymap : tui_readline_standard_keymap);
|
|
|
|
tuiShowLocatorContent ();
|
|
|
|
}
|
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* Initialize readline and configure the keymap for the switching
|
|
|
|
key shortcut. */
|
1999-04-16 01:35:26 +00:00
|
|
|
void
|
2001-07-21 19:59:14 +00:00
|
|
|
tui_initialize_readline ()
|
1999-04-16 01:35:26 +00:00
|
|
|
{
|
2002-08-31 12:02:14 +00:00
|
|
|
int i;
|
|
|
|
Keymap tui_ctlx_keymap;
|
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
rl_initialize ();
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2002-08-25 21:44:41 +00:00
|
|
|
rl_add_defun ("tui-switch-mode", tui_rl_switch_mode, -1);
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_add_defun ("gdb-command", tui_rl_command_key, -1);
|
|
|
|
rl_add_defun ("next-keymap", tui_rl_next_keymap, -1);
|
|
|
|
|
|
|
|
tui_keymap = rl_make_bare_keymap ();
|
|
|
|
tui_ctlx_keymap = rl_make_bare_keymap ();
|
|
|
|
tui_readline_standard_keymap = rl_get_keymap ();
|
|
|
|
|
|
|
|
for (i = 0; tui_commands[i].cmd; i++)
|
|
|
|
rl_bind_key_in_map (tui_commands[i].key, tui_rl_command_key, tui_keymap);
|
|
|
|
|
|
|
|
rl_generic_bind (ISKMAP, "\\C-x", (char*) tui_ctlx_keymap, tui_keymap);
|
|
|
|
|
|
|
|
/* Bind all other keys to tui_rl_command_mode so that we switch
|
|
|
|
temporarily from SingleKey mode and can enter a gdb command. */
|
2002-09-13 20:06:56 +00:00
|
|
|
for (i = ' '; i < 0x7f; i++)
|
2002-08-31 12:02:14 +00:00
|
|
|
{
|
|
|
|
int j;
|
|
|
|
|
|
|
|
for (j = 0; tui_commands[j].cmd; j++)
|
|
|
|
if (tui_commands[j].key == i)
|
|
|
|
break;
|
|
|
|
|
|
|
|
if (tui_commands[j].cmd)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
rl_bind_key_in_map (i, tui_rl_command_mode, tui_keymap);
|
|
|
|
}
|
|
|
|
|
2002-08-25 21:44:41 +00:00
|
|
|
rl_bind_key_in_map ('a', tui_rl_switch_mode, emacs_ctlx_keymap);
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_bind_key_in_map ('a', tui_rl_switch_mode, tui_ctlx_keymap);
|
2002-08-25 21:44:41 +00:00
|
|
|
rl_bind_key_in_map ('A', tui_rl_switch_mode, emacs_ctlx_keymap);
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_bind_key_in_map ('A', tui_rl_switch_mode, tui_ctlx_keymap);
|
2002-08-25 21:44:41 +00:00
|
|
|
rl_bind_key_in_map (CTRL ('A'), tui_rl_switch_mode, emacs_ctlx_keymap);
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_bind_key_in_map (CTRL ('A'), tui_rl_switch_mode, tui_ctlx_keymap);
|
2002-08-25 21:44:41 +00:00
|
|
|
rl_bind_key_in_map ('1', tui_rl_delete_other_windows, emacs_ctlx_keymap);
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_bind_key_in_map ('1', tui_rl_delete_other_windows, tui_ctlx_keymap);
|
2002-08-25 21:44:41 +00:00
|
|
|
rl_bind_key_in_map ('2', tui_rl_change_windows, emacs_ctlx_keymap);
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_bind_key_in_map ('2', tui_rl_change_windows, tui_ctlx_keymap);
|
2003-07-24 20:23:17 +00:00
|
|
|
rl_bind_key_in_map ('o', tui_rl_other_window, emacs_ctlx_keymap);
|
|
|
|
rl_bind_key_in_map ('o', tui_rl_other_window, tui_ctlx_keymap);
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_bind_key_in_map ('q', tui_rl_next_keymap, tui_keymap);
|
|
|
|
rl_bind_key_in_map ('s', tui_rl_next_keymap, emacs_ctlx_keymap);
|
|
|
|
rl_bind_key_in_map ('s', tui_rl_next_keymap, tui_ctlx_keymap);
|
2001-07-21 19:59:14 +00:00
|
|
|
}
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* Enter in the tui mode (curses).
|
|
|
|
When in normal mode, it installs the tui hooks in gdb, redirects
|
|
|
|
the gdb output, configures the readline to work in tui mode.
|
|
|
|
When in curses mode, it does nothing. */
|
1999-04-16 01:35:26 +00:00
|
|
|
void
|
2001-07-21 19:59:14 +00:00
|
|
|
tui_enable (void)
|
1999-04-16 01:35:26 +00:00
|
|
|
{
|
2001-07-21 19:59:14 +00:00
|
|
|
if (tui_active)
|
|
|
|
return;
|
|
|
|
|
|
|
|
/* To avoid to initialize curses when gdb starts, there is a defered
|
|
|
|
curses initialization. This initialization is made only once
|
|
|
|
and the first time the curses mode is entered. */
|
|
|
|
if (tui_finish_init)
|
1999-04-16 01:35:26 +00:00
|
|
|
{
|
2001-07-21 19:59:14 +00:00
|
|
|
WINDOW *w;
|
|
|
|
|
|
|
|
w = initscr ();
|
|
|
|
|
2001-07-21 20:49:56 +00:00
|
|
|
cbreak ();
|
|
|
|
noecho ();
|
2001-07-21 19:59:14 +00:00
|
|
|
/*timeout (1);*/
|
|
|
|
nodelay(w, FALSE);
|
|
|
|
nl();
|
|
|
|
keypad (w, TRUE);
|
|
|
|
rl_initialize ();
|
|
|
|
setTermHeightTo (LINES);
|
|
|
|
setTermWidthTo (COLS);
|
|
|
|
def_prog_mode ();
|
|
|
|
|
2002-08-24 15:25:25 +00:00
|
|
|
tuiShowFrameInfo (0);
|
|
|
|
tuiSetLayout (SRC_COMMAND, TUI_UNDEFINED_REGS);
|
2001-07-21 19:59:14 +00:00
|
|
|
tuiSetWinFocusTo (srcWin);
|
2001-07-21 20:49:56 +00:00
|
|
|
keypad (cmdWin->generic.handle, TRUE);
|
2001-07-21 19:59:14 +00:00
|
|
|
wrefresh (cmdWin->generic.handle);
|
|
|
|
tui_finish_init = 0;
|
1999-04-16 01:35:26 +00:00
|
|
|
}
|
2001-07-21 19:59:14 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Save the current gdb setting of the terminal.
|
|
|
|
Curses will restore this state when endwin() is called. */
|
|
|
|
def_shell_mode ();
|
|
|
|
clearok (stdscr, TRUE);
|
|
|
|
}
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* Install the TUI specific hooks. */
|
|
|
|
tui_install_hooks ();
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_startup_hook = tui_rl_startup_hook;
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2001-07-21 20:49:56 +00:00
|
|
|
tui_update_variables ();
|
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
tui_setup_io (1);
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
tui_active = 1;
|
2002-11-29 Andrew Cagney <ac131313@redhat.com>
* stack.c (selected_frame, select_frame): Move from here ...
* frame.c (selected_frame, select_frame): ... to here. Include
"language.h".
* Makefile.in (frame.o): Update dependencies.
* frame.c (get_selected_frame): New function.
* frame.h (get_selected_frame): Declare.
(deprecated_selected_frame): Rename selected_frame.
* ada-lang.c, ada-tasks.c, breakpoint.c, corelow.c: Update.
* eval.c, f-valprint.c, findvar.c, frame.c, frame.h: Update.
* h8300-tdep.c, h8500-tdep.c, hppa-tdep.c, infcmd.c: Update.
* inflow.c, infrun.c, macroscope.c, mips-tdep.c: Update.
* mn10300-tdep.c, ocd.c, regcache.h, remote-e7000.c: Update.
* remote-mips.c, remote-rdp.c, sh-tdep.c, sparc-tdep.c: Update.
* stack.c, thread.c, tracepoint.c, valops.c, varobj.c: Update.
* z8k-tdep.c, cli/cli-cmds.c: Update.
Index: mi/ChangeLog
2002-11-29 Andrew Cagney <ac131313@redhat.com>
* mi/mi-cmd-stack.c, mi/mi-main.c: Update to use
deprecated_selected_frame.
Index: tui/ChangeLog
2002-11-29 Andrew Cagney <ac131313@redhat.com>
* tui/tui-hooks.c: Update to use deprecated_selected_frame.
* tui/tui.c, tui/tuiDisassem.c, tui/tuiRegs.c: Ditto.
* tui/tuiSource.c, tui/tuiSourceWin.c, tui/tuiWin.c: Ditto.
2002-11-29 19:15:16 +00:00
|
|
|
if (deprecated_selected_frame)
|
|
|
|
tuiShowFrameInfo (deprecated_selected_frame);
|
2002-08-24 17:04:33 +00:00
|
|
|
|
2002-09-13 20:06:56 +00:00
|
|
|
/* Restore TUI keymap. */
|
|
|
|
tui_set_key_mode (tui_current_key_mode);
|
2003-07-23 21:40:59 +00:00
|
|
|
tuiRefreshAll ();
|
2002-08-26 19:35:37 +00:00
|
|
|
|
|
|
|
/* Update gdb's knowledge of its terminal. */
|
|
|
|
target_terminal_save_ours ();
|
2002-08-24 16:43:08 +00:00
|
|
|
tui_update_gdb_sizes ();
|
2001-07-21 19:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Leave the tui mode.
|
|
|
|
Remove the tui hooks and configure the gdb output and readline
|
|
|
|
back to their original state. The curses mode is left so that
|
|
|
|
the terminal setting is restored to the point when we entered. */
|
1999-04-16 01:35:26 +00:00
|
|
|
void
|
2001-07-21 19:59:14 +00:00
|
|
|
tui_disable (void)
|
1999-04-16 01:35:26 +00:00
|
|
|
{
|
2001-07-21 19:59:14 +00:00
|
|
|
if (!tui_active)
|
|
|
|
return;
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2002-09-13 20:06:56 +00:00
|
|
|
/* Restore initial readline keymap. */
|
|
|
|
rl_set_keymap (tui_readline_standard_keymap);
|
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* Remove TUI hooks. */
|
|
|
|
tui_remove_hooks ();
|
2002-08-31 12:02:14 +00:00
|
|
|
rl_startup_hook = 0;
|
|
|
|
rl_already_prompted = 0;
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* Leave curses and restore previous gdb terminal setting. */
|
|
|
|
endwin ();
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* gdb terminal has changed, update gdb internal copy of it
|
|
|
|
so that terminal management with the inferior works. */
|
|
|
|
tui_setup_io (0);
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2002-08-26 19:35:37 +00:00
|
|
|
/* Update gdb's knowledge of its terminal. */
|
|
|
|
target_terminal_save_ours ();
|
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
tui_active = 0;
|
2002-08-24 16:43:08 +00:00
|
|
|
tui_update_gdb_sizes ();
|
2001-07-21 19:59:14 +00:00
|
|
|
}
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
/* Wrapper on top of free() to ensure that input address
|
|
|
|
is greater than 0x0. */
|
1999-04-16 01:35:26 +00:00
|
|
|
void
|
2001-07-14 19:31:09 +00:00
|
|
|
tuiFree (char *ptr)
|
1999-04-16 01:35:26 +00:00
|
|
|
{
|
|
|
|
if (ptr != (char *) NULL)
|
|
|
|
{
|
2000-12-15 01:01:51 +00:00
|
|
|
xfree (ptr);
|
1999-04-16 01:35:26 +00:00
|
|
|
}
|
2001-07-21 19:59:14 +00:00
|
|
|
}
|
1999-04-16 01:35:26 +00:00
|
|
|
|
|
|
|
void
|
2002-08-24 17:04:33 +00:00
|
|
|
strcat_to_buf (char *buf, int buflen, const char *itemToAdd)
|
1999-04-16 01:35:26 +00:00
|
|
|
{
|
|
|
|
if (itemToAdd != (char *) NULL && buf != (char *) NULL)
|
|
|
|
{
|
|
|
|
if ((strlen (buf) + strlen (itemToAdd)) <= buflen)
|
|
|
|
strcat (buf, itemToAdd);
|
|
|
|
else
|
|
|
|
strncat (buf, itemToAdd, (buflen - strlen (buf)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
#if 0
|
|
|
|
/* Solaris <sys/termios.h> defines CTRL. */
|
|
|
|
#ifndef CTRL
|
|
|
|
#define CTRL(x) (x & ~0140)
|
|
|
|
#endif
|
1999-04-16 01:35:26 +00:00
|
|
|
|
2001-07-21 19:59:14 +00:00
|
|
|
#define FILEDES 2
|
|
|
|
#define CHK(val, dft) (val<=0 ? dft : val)
|
1999-04-16 01:35:26 +00:00
|
|
|
|
|
|
|
static void
|
|
|
|
_tuiReset (void)
|
|
|
|
{
|
|
|
|
struct termio mode;
|
|
|
|
|
|
|
|
/*
|
1999-07-07 20:19:36 +00:00
|
|
|
** reset the teletype mode bits to a sensible state.
|
|
|
|
** Copied tset.c
|
|
|
|
*/
|
1999-04-16 01:35:26 +00:00
|
|
|
#if ! defined (USG) && defined (TIOCGETC)
|
|
|
|
struct tchars tbuf;
|
|
|
|
#endif /* !USG && TIOCGETC */
|
|
|
|
#ifdef UCB_NTTY
|
|
|
|
struct ltchars ltc;
|
|
|
|
|
|
|
|
if (ldisc == NTTYDISC)
|
|
|
|
{
|
|
|
|
ioctl (FILEDES, TIOCGLTC, <c);
|
|
|
|
ltc.t_suspc = CHK (ltc.t_suspc, CTRL ('Z'));
|
|
|
|
ltc.t_dsuspc = CHK (ltc.t_dsuspc, CTRL ('Y'));
|
|
|
|
ltc.t_rprntc = CHK (ltc.t_rprntc, CTRL ('R'));
|
|
|
|
ltc.t_flushc = CHK (ltc.t_flushc, CTRL ('O'));
|
|
|
|
ltc.t_werasc = CHK (ltc.t_werasc, CTRL ('W'));
|
|
|
|
ltc.t_lnextc = CHK (ltc.t_lnextc, CTRL ('V'));
|
|
|
|
ioctl (FILEDES, TIOCSLTC, <c);
|
|
|
|
}
|
|
|
|
#endif /* UCB_NTTY */
|
|
|
|
#ifndef USG
|
|
|
|
#ifdef TIOCGETC
|
|
|
|
ioctl (FILEDES, TIOCGETC, &tbuf);
|
|
|
|
tbuf.t_intrc = CHK (tbuf.t_intrc, CTRL ('?'));
|
|
|
|
tbuf.t_quitc = CHK (tbuf.t_quitc, CTRL ('\\'));
|
|
|
|
tbuf.t_startc = CHK (tbuf.t_startc, CTRL ('Q'));
|
|
|
|
tbuf.t_stopc = CHK (tbuf.t_stopc, CTRL ('S'));
|
|
|
|
tbuf.t_eofc = CHK (tbuf.t_eofc, CTRL ('D'));
|
|
|
|
/* brkc is left alone */
|
|
|
|
ioctl (FILEDES, TIOCSETC, &tbuf);
|
|
|
|
#endif /* TIOCGETC */
|
|
|
|
mode.sg_flags &= ~(RAW
|
|
|
|
#ifdef CBREAK
|
|
|
|
| CBREAK
|
|
|
|
#endif /* CBREAK */
|
|
|
|
| VTDELAY | ALLDELAY);
|
|
|
|
mode.sg_flags |= XTABS | ECHO | CRMOD | ANYP;
|
1999-07-07 20:19:36 +00:00
|
|
|
#else /*USG */
|
1999-04-16 01:35:26 +00:00
|
|
|
ioctl (FILEDES, TCGETA, &mode);
|
|
|
|
mode.c_cc[VINTR] = CHK (mode.c_cc[VINTR], CTRL ('?'));
|
|
|
|
mode.c_cc[VQUIT] = CHK (mode.c_cc[VQUIT], CTRL ('\\'));
|
|
|
|
mode.c_cc[VEOF] = CHK (mode.c_cc[VEOF], CTRL ('D'));
|
|
|
|
|
|
|
|
mode.c_iflag &= ~(IGNBRK | PARMRK | INPCK | INLCR | IGNCR | IUCLC | IXOFF);
|
|
|
|
mode.c_iflag |= (BRKINT | ISTRIP | ICRNL | IXON);
|
|
|
|
mode.c_oflag &= ~(OLCUC | OCRNL | ONOCR | ONLRET | OFILL | OFDEL |
|
|
|
|
NLDLY | CRDLY | TABDLY | BSDLY | VTDLY | FFDLY);
|
|
|
|
mode.c_oflag |= (OPOST | ONLCR);
|
|
|
|
mode.c_cflag &= ~(CSIZE | PARODD | CLOCAL);
|
|
|
|
#ifndef hp9000s800
|
|
|
|
mode.c_cflag |= (CS8 | CREAD);
|
1999-07-07 20:19:36 +00:00
|
|
|
#else /*hp9000s800 */
|
1999-04-16 01:35:26 +00:00
|
|
|
mode.c_cflag |= (CS8 | CSTOPB | CREAD);
|
|
|
|
#endif /* hp9000s800 */
|
|
|
|
mode.c_lflag &= ~(XCASE | ECHONL | NOFLSH);
|
|
|
|
mode.c_lflag |= (ISIG | ICANON | ECHO | ECHOK);
|
|
|
|
ioctl (FILEDES, TCSETAW, &mode);
|
|
|
|
#endif /* USG */
|
|
|
|
|
|
|
|
return;
|
|
|
|
} /* _tuiReset */
|
2001-07-21 19:59:14 +00:00
|
|
|
#endif
|
|
|
|
|
2001-07-23 21:13:57 +00:00
|
|
|
void
|
|
|
|
tui_show_source (const char *file, int line)
|
|
|
|
{
|
2002-09-30 00:52:27 +00:00
|
|
|
struct symtab_and_line cursal = get_current_source_symtab_and_line ();
|
2001-07-23 21:13:57 +00:00
|
|
|
/* make sure that the source window is displayed */
|
|
|
|
tuiAddWinToLayout (SRC_WIN);
|
|
|
|
|
2002-09-30 00:52:27 +00:00
|
|
|
tuiUpdateSourceWindowsWithLine (cursal.symtab, line);
|
2001-07-23 21:13:57 +00:00
|
|
|
tuiUpdateLocatorFilename (file);
|
|
|
|
}
|
2001-07-21 22:24:44 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
tui_show_assembly (CORE_ADDR addr)
|
|
|
|
{
|
|
|
|
tuiAddWinToLayout (DISASSEM_WIN);
|
|
|
|
tuiUpdateSourceWindowsWithAddr (addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
tui_is_window_visible (TuiWinType type)
|
|
|
|
{
|
2003-02-14 13:58:06 +00:00
|
|
|
if (tui_active == 0)
|
2001-07-21 22:24:44 +00:00
|
|
|
return 0;
|
|
|
|
|
|
|
|
if (winList[type] == 0)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
return winList[type]->generic.isVisible;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
tui_get_command_dimension (int *width, int *height)
|
|
|
|
{
|
2003-02-14 13:58:06 +00:00
|
|
|
if (!tui_active || !m_winPtrNotNull (cmdWin))
|
2001-07-21 22:24:44 +00:00
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
*width = cmdWin->generic.width;
|
|
|
|
*height = cmdWin->generic.height;
|
|
|
|
return 1;
|
|
|
|
}
|