1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300
|
/* TUI data manipulation routines.
Copyright (C) 1998-2024 Free Software Foundation, Inc.
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 3 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, see <http://www.gnu.org/licenses/>. */
#ifndef GDB_TUI_TUI_DATA_H
#define GDB_TUI_TUI_DATA_H
#include "tui/tui.h"
#include "gdb_curses.h"
/* A deleter that calls delwin. */
struct curses_deleter
{
void operator() (WINDOW *win) const
{
delwin (win);
}
};
#define MIN_WIN_HEIGHT 3
/* Generic window information. */
struct tui_win_info
{
protected:
tui_win_info () = default;
DISABLE_COPY_AND_ASSIGN (tui_win_info);
/* This is called after the window is resized, and should update the
window's contents. */
virtual void rerender ();
/* Create the curses window. */
void make_window ();
public:
tui_win_info (tui_win_info &&) = default;
virtual ~tui_win_info () = default;
/* Call to refresh this window. */
virtual void refresh_window ();
/* Make this window visible or invisible. */
virtual void make_visible (bool visible);
/* Return the name of this type of window. */
virtual const char *name () const = 0;
/* Compute the maximum height of this window. */
virtual int max_height () const;
/* Compute the minimum height of this window. */
virtual int min_height () const
{
return MIN_WIN_HEIGHT;
}
/* Compute the maximum width of this window. */
int max_width () const;
/* Compute the minimum width of this window. */
int min_width () const
{
return 3;
}
/* Return true if this window can be boxed. */
virtual bool can_box () const
{
return true;
}
/* Return the width of the box. */
int box_width () const
{
return can_box () ? 1 : 0;
}
/* Return the size of the box. */
int box_size () const
{
return 2 * box_width ();
}
/* Resize this window. The parameters are used to set the window's
size and position. */
virtual void resize (int height, int width,
int origin_x, int origin_y);
/* Return true if this window is visible. */
bool is_visible () const
{
return handle != nullptr && tui_active;
}
/* Return true if this window can accept the focus. */
virtual bool can_focus () const
{
return true;
}
/* Called after the tab width has been changed. */
virtual void update_tab_width ()
{
}
/* Set whether this window is highlighted. */
void set_highlight (bool highlight)
{
is_highlighted = highlight;
}
/* Methods to scroll the contents of this window. Note that they
are named with "_scroll" coming at the end because the more
obvious "scroll_forward" is defined as a macro in term.h. */
void forward_scroll (int num_to_scroll);
void backward_scroll (int num_to_scroll);
void left_scroll (int num_to_scroll);
void right_scroll (int num_to_scroll);
/* Return true if this window can be scrolled, false otherwise. */
virtual bool can_scroll () const
{
return true;
}
/* Called for each mouse click inside this window. Coordinates MOUSE_X
and MOUSE_Y are 0-based relative to the window, and MOUSE_BUTTON can
be 1 (left), 2 (middle), or 3 (right). */
virtual void click (int mouse_x, int mouse_y, int mouse_button)
{
}
void check_and_display_highlight_if_needed ();
/* A helper function to change the title and then redraw the
surrounding box, if needed. */
void set_title (std::string &&new_title);
/* Return a reference to the current window title. */
const std::string &title () const
{ return m_title; }
/* Clear the window, maybe draw the border, and then display string
STR centered in the window, abbreviated if necessary. */
void center_string (const char *str);
/* Display string STR in the window at the current cursor position,
abbreviated if necessary. */
void display_string (const char *str) const;
/* Window handle. */
std::unique_ptr<WINDOW, curses_deleter> handle;
/* Window width. */
int width = 0;
/* Window height. */
int height = 0;
/* Origin of window. */
int x = 0;
int y = 0;
/* Is this window highlighted? */
bool is_highlighted = false;
protected:
/* Scroll the contents vertically. This is only called via
forward_scroll and backward_scroll. */
virtual void do_scroll_vertical (int num_to_scroll) = 0;
/* Scroll the contents horizontally. This is only called via
left_scroll and right_scroll. */
virtual void do_scroll_horizontal (int num_to_scroll) = 0;
private:
/* Window title to display. */
std::string m_title;
};
/* A TUI window that doesn't scroll. */
struct tui_noscroll_window : public virtual tui_win_info
{
public:
virtual bool can_scroll () const final override
{
return false;
}
protected:
virtual void do_scroll_vertical (int num_to_scroll) final override
{
}
/* Scroll the contents horizontally. This is only called via
left_scroll and right_scroll. */
virtual void do_scroll_horizontal (int num_to_scroll) final override
{
}
};
/* A TUI window that cannot have focus. */
struct tui_nofocus_window : public virtual tui_win_info
{
public:
virtual bool can_focus () const final override
{
return false;
}
};
/* A TUI window that occupies a single line. */
struct tui_oneline_window : public virtual tui_win_info
{
int max_height () const final override
{
return 1;
}
int min_height () const final override
{
return 1;
}
};
/* A TUI window that has no border. */
struct tui_nobox_window : public virtual tui_win_info
{
bool can_box () const final override
{
return false;
}
};
/* A TUI window that is always visible. */
struct tui_always_visible_window : public virtual tui_win_info
{
virtual void make_visible (bool visible) final override
{
}
};
/* Constant definitions. */
#define SRC_NAME "src"
#define CMD_NAME "cmd"
#define DATA_NAME "regs"
#define DISASSEM_NAME "asm"
#define STATUS_NAME "status"
/* Global Data. */
extern struct tui_win_info *tui_win_list[MAX_MAJOR_WINDOWS];
/* All the windows that are currently instantiated, in layout
order. */
extern std::vector<tui_win_info *> tui_windows;
/* Return a range adapter for iterating over TUI windows. */
static inline std::vector<tui_win_info *> &
all_tui_windows ()
{
return tui_windows;
}
/* Data Manipulation Functions. */
extern int tui_term_height (void);
extern void tui_set_term_height_to (int);
extern int tui_term_width (void);
extern void tui_set_term_width_to (int);
extern struct tui_win_info *tui_win_with_focus (void);
extern bool tui_win_resized ();
extern void tui_set_win_resized_to (bool);
extern struct tui_win_info *tui_next_win (struct tui_win_info *);
extern struct tui_win_info *tui_prev_win (struct tui_win_info *);
extern unsigned int tui_tab_width;
#endif /* GDB_TUI_TUI_DATA_H */
|