tui.h revision 1.9
1/* External/Public TUI Header File.
2
3   Copyright (C) 1998-2020 Free Software Foundation, Inc.
4
5   Contributed by Hewlett-Packard Company.
6
7   This file is part of GDB.
8
9   This program is free software; you can redistribute it and/or modify
10   it under the terms of the GNU General Public License as published by
11   the Free Software Foundation; either version 3 of the License, or
12   (at your option) any later version.
13
14   This program is distributed in the hope that it will be useful,
15   but WITHOUT ANY WARRANTY; without even the implied warranty of
16   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17   GNU General Public License for more details.
18
19   You should have received a copy of the GNU General Public License
20   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
21
22#ifndef TUI_TUI_H
23#define TUI_TUI_H
24
25struct ui_file;
26
27/* Types of error returns.  */
28enum tui_status
29{
30  TUI_SUCCESS,
31  TUI_FAILURE
32};
33
34/* Types of windows.  */
35enum tui_win_type
36{
37  SRC_WIN = 0,
38  DISASSEM_WIN,
39  DATA_WIN,
40  CMD_WIN,
41  /* This must ALWAYS be AFTER the major windows last.  */
42  MAX_MAJOR_WINDOWS,
43};
44
45extern CORE_ADDR tui_get_low_disassembly_address (struct gdbarch *,
46						  CORE_ADDR, CORE_ADDR);
47extern void tui_show_assembly (struct gdbarch *gdbarch, CORE_ADDR addr);
48extern bool tui_is_window_visible (enum tui_win_type type);
49extern bool tui_get_command_dimension (unsigned int *width,
50				       unsigned int *height);
51
52/* Initialize readline and configure the keymap for the switching key
53   shortcut.  May be called more than once without issue.  */
54extern void tui_ensure_readline_initialized ();
55
56/* Enter in the tui mode (curses).  */
57extern void tui_enable (void);
58
59/* Leave the tui mode.  */
60extern void tui_disable (void);
61
62enum tui_key_mode
63{
64  /* Plain command mode to enter gdb commands.  */
65  TUI_COMMAND_MODE,
66
67  /* SingleKey mode with some keys bound to gdb commands.  */
68  TUI_SINGLE_KEY_MODE,
69
70  /* Read/edit one command and return to SingleKey after it's
71     processed.  */
72  TUI_ONE_COMMAND_MODE
73};
74
75extern enum tui_key_mode tui_current_key_mode;
76
77/* Change the TUI key mode by installing the appropriate readline
78   keymap.  */
79extern void tui_set_key_mode (enum tui_key_mode mode);
80
81extern bool tui_active;
82
83#endif /* TUI_TUI_H */
84