Separate out locator window
[deliverable/binutils-gdb.git] / gdb / tui / tui-data.h
CommitLineData
f377b406 1/* TUI data manipulation routines.
55fb0713 2
42a4f53d 3 Copyright (C) 1998-2019 Free Software Foundation, Inc.
55fb0713 4
f377b406
SC
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
a9762ec7 11 the Free Software Foundation; either version 3 of the License, or
f377b406
SC
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
a9762ec7 20 along with this program. If not, see <http://www.gnu.org/licenses/>. */
f377b406 21
1a5c2598
TT
22#ifndef TUI_TUI_DATA_H
23#define TUI_TUI_DATA_H
c906108c 24
6a83354a
AC
25#include "tui/tui.h" /* For enum tui_win_type. */
26#include "gdb_curses.h" /* For WINDOW. */
27
28/* This is a point definition. */
29struct tui_point
30{
31 int x, y;
32};
2a5127c4 33
63ed8182
PP
34struct tui_win_element;
35
36/* This describes the content of the window. */
37typedef struct tui_win_element **tui_win_content;
38
1cc6d956 39/* Generic window information. */
2a8854a7
AC
40struct tui_gen_win_info
41{
ab313b35
TT
42 explicit tui_gen_win_info (enum tui_win_type t)
43 : type (t)
44 {
45 }
46
f936bca2 47 virtual ~tui_gen_win_info ();
ab313b35 48
5b81daba
TT
49 /* Call to refresh this window. */
50 virtual void refresh_window ();
51
48a3bd16
TT
52 /* Make this window visible or invisible. */
53 virtual void make_visible (bool visible);
54
152f3f4b
TT
55 /* Return the name of this type of window. */
56 virtual const char *name () const
57 {
58 return "";
59 }
60
d6ba6a11
TT
61 /* Reset this window. WIN_TYPE must match the existing type of this
62 window (it is only passed for self-test purposes). The other
63 parameters are used to set the window's size and position. */
64 void reset (enum tui_win_type win_type,
65 int height, int width,
66 int origin_x, int origin_y);
67
ab313b35
TT
68 /* Window handle. */
69 WINDOW *handle = nullptr;
70 /* Type of window. */
71 enum tui_win_type type;
72 /* Window width. */
73 int width = 0;
74 /* Window height. */
75 int height = 0;
76 /* Origin of window. */
77 struct tui_point origin = {0, 0};
78 /* Content of window. */
79 tui_win_content content = nullptr;
80 /* Size of content (# of elements). */
81 int content_size = 0;
82 /* Can it be used, or is it already used? */
83 int content_in_use = FALSE;
84 /* Viewport height. */
85 int viewport_height = 0;
86 /* Index of last visible line. */
87 int last_visible_line = 0;
88 /* Whether the window is visible or not. */
89 bool is_visible = false;
90 /* Window title to display. */
91 char *title = nullptr;
2a8854a7 92};
2a5127c4 93
17374de4
TT
94/* Whether or not a window should be drawn with a box. */
95enum tui_box
96{
97 DONT_BOX_WINDOW = 0,
98 BOX_WINDOW
99};
100
1cc6d956 101/* Constant definitions. */
08ef48c5
MS
102#define DEFAULT_TAB_LEN 8
103#define NO_SRC_STRING "[ No Source Available ]"
104#define NO_DISASSEM_STRING "[ No Assembly Available ]"
105#define NO_REGS_STRING "[ Register Values Unavailable ]"
106#define NO_DATA_STRING "[ No Data Values Displayed ]"
107#define MAX_CONTENT_COUNT 100
6dce28e4
AB
108#define SRC_NAME "src"
109#define CMD_NAME "cmd"
110#define DATA_NAME "regs"
111#define DISASSEM_NAME "asm"
08ef48c5
MS
112#define TUI_NULL_STR ""
113#define DEFAULT_HISTORY_COUNT 25
08ef48c5
MS
114#define HILITE TRUE
115#define NO_HILITE FALSE
116#define WITH_LOCATOR TRUE
117#define NO_LOCATOR FALSE
118#define EMPTY_SOURCE_PROMPT TRUE
119#define NO_EMPTY_SOURCE_PROMPT FALSE
120#define UNDEFINED_ITEM -1
121#define MIN_WIN_HEIGHT 3
122#define MIN_CMD_WIN_HEIGHT 3
c906108c 123
50265402 124/* Strings to display in the TUI status line. */
08ef48c5 125#define PROC_PREFIX "In: "
9f2850ba 126#define LINE_PREFIX "L"
08ef48c5
MS
127#define PC_PREFIX "PC: "
128#define SINGLE_KEY "(SingleKey)"
50265402 129
1cc6d956
MS
130/* Minimum/Maximum length of some fields displayed in the TUI status
131 line. */
132#define MIN_LINE_WIDTH 4 /* Use at least 4 digits for line
133 numbers. */
50265402
SC
134#define MIN_PROC_WIDTH 12
135#define MAX_TARGET_WIDTH 10
9f2850ba 136#define MAX_PID_WIDTH 19
c906108c 137
1cc6d956 138/* The kinds of layouts available. */
2a8854a7
AC
139enum tui_layout_type
140{
141 SRC_COMMAND,
142 DISASSEM_COMMAND,
143 SRC_DISASSEM_COMMAND,
144 SRC_DATA_COMMAND,
145 DISASSEM_DATA_COMMAND,
146 UNDEFINED_LAYOUT
147};
c906108c 148
1cc6d956 149/* Basic data types that can be displayed in the data window. */
2a8854a7
AC
150enum tui_data_type
151{
152 TUI_REGISTER,
153 TUI_SCALAR,
154 TUI_COMPLEX,
155 TUI_STRUCT
156};
c906108c 157
52059ffd
TT
158enum tui_line_or_address_kind
159{
160 LOA_LINE,
161 LOA_ADDRESS
162};
163
1cc6d956 164/* Structure describing source line or line address. */
362c05fe 165struct tui_line_or_address
2a8854a7 166{
52059ffd 167 enum tui_line_or_address_kind loa;
362c05fe
AS
168 union
169 {
170 int line_no;
171 CORE_ADDR addr;
172 } u;
2a8854a7 173};
c906108c 174
1cc6d956 175/* Current Layout definition. */
2a8854a7
AC
176struct tui_layout_def
177{
6d012f14 178 enum tui_win_type display_mode;
2a8854a7 179 int split;
2a8854a7 180};
c906108c 181
1cc6d956 182/* Elements in the Source/Disassembly Window. */
2a8854a7
AC
183struct tui_source_element
184{
185 char *line;
362c05fe 186 struct tui_line_or_address line_or_addr;
6d012f14
AC
187 int is_exec_point;
188 int has_break;
2a8854a7 189};
c906108c
SS
190
191
1cc6d956 192/* Elements in the data display window content. */
2a8854a7
AC
193struct tui_data_element
194{
195 const char *name;
08ef48c5
MS
196 int item_no; /* The register number, or data display
197 number. */
2a8854a7 198 enum tui_data_type type;
22940a24 199 void *value;
2a8854a7 200 int highlight;
10f59415 201 char *content;
2a8854a7 202};
c906108c
SS
203
204
1cc6d956 205/* Elements in the command window content. */
2a8854a7
AC
206struct tui_command_element
207{
208 char *line;
209};
c906108c 210
2d42f9a8
JB
211#ifdef PATH_MAX
212# define MAX_LOCATOR_ELEMENT_LEN PATH_MAX
213#else
214# define MAX_LOCATOR_ELEMENT_LEN 1024
215#endif
c906108c 216
00b2bad4
SC
217/* Flags to tell what kind of breakpoint is at current line. */
218#define TUI_BP_ENABLED 0x01
219#define TUI_BP_DISABLED 0x02
220#define TUI_BP_HIT 0x04
221#define TUI_BP_CONDITIONAL 0x08
222#define TUI_BP_HARDWARE 0x10
223
224/* Position of breakpoint markers in the exec info string. */
225#define TUI_BP_HIT_POS 0
226#define TUI_BP_BREAK_POS 1
227#define TUI_EXEC_POS 2
228#define TUI_EXECINFO_SIZE 4
229
2a8854a7 230typedef char tui_exec_info_content[TUI_EXECINFO_SIZE];
c906108c 231
1cc6d956 232/* An content element in a window. */
2a8854a7
AC
233union tui_which_element
234{
1cc6d956 235 struct tui_source_element source; /* The source elements. */
dc2c33e4 236 struct tui_gen_win_info *data_window; /* Data display elements. */
1cc6d956
MS
237 struct tui_data_element data; /* Elements of data_window. */
238 struct tui_command_element command; /* Command elements. */
2a8854a7
AC
239};
240
241struct tui_win_element
242{
6d012f14 243 union tui_which_element which_element;
2a8854a7 244};
c906108c 245
489e9d8b
TT
246/* Execution info window class. */
247
248struct tui_exec_info_window : public tui_gen_win_info
249{
250 tui_exec_info_window ()
251 : tui_gen_win_info (EXEC_INFO_WIN)
252 {
253 }
254
255 ~tui_exec_info_window () override
256 {
257 xfree (m_content);
258 }
259
260 /* Get or allocate contents. */
261 tui_exec_info_content *maybe_allocate_content (int n_elements);
262
263 /* Return the contents. */
264 const tui_exec_info_content *get_content () const
265 {
266 return m_content;
267 }
268
269private:
270
271 tui_exec_info_content *m_content = nullptr;
272};
273
3add462f
TT
274/* Locator window class. */
275
276struct tui_locator_window : public tui_gen_win_info
277{
278 tui_locator_window ()
279 : tui_gen_win_info (LOCATOR_WIN)
280 {
281 full_name[0] = 0;
282 proc_name[0] = 0;
283 }
284
285 char full_name[MAX_LOCATOR_ELEMENT_LEN];
286 char proc_name[MAX_LOCATOR_ELEMENT_LEN];
287 int line_no = 0;
288 CORE_ADDR addr = 0;
289 /* Architecture associated with code at this location. */
290 struct gdbarch *gdbarch = nullptr;
291};
292
1cc6d956 293/* This defines information about each logical window. */
cb2ce893 294struct tui_win_info : public tui_gen_win_info
2a8854a7 295{
33b906ab 296protected:
e7e11af4 297
33b906ab 298 explicit tui_win_info (enum tui_win_type type);
6792b55e
TT
299 DISABLE_COPY_AND_ASSIGN (tui_win_info);
300
13446e05
TT
301 /* Scroll the contents vertically. This is only called via
302 forward_scroll and backward_scroll. */
c3bd716f 303 virtual void do_scroll_vertical (int num_to_scroll) = 0;
13446e05
TT
304
305 /* Scroll the contents horizontally. This is only called via
306 left_scroll and right_scroll. */
c3bd716f 307 virtual void do_scroll_horizontal (int num_to_scroll) = 0;
13446e05 308
5fcee43a
TT
309 /* Called after make_visible_with_new_height sets the new height.
310 Should update the window. */
311 virtual void do_make_visible_with_new_height () = 0;
312
33b906ab
TT
313public:
314
f936bca2
TT
315 ~tui_win_info () override
316 {
317 }
33b906ab 318
8761a91b
TT
319 /* Clear the pertinent detail in the window. */
320 virtual void clear_detail () = 0;
321
44f0e208
TT
322 /* Return true if this window has the locator. */
323 virtual bool has_locator () const
324 {
325 return false;
326 }
327
2042b506
TT
328 /* Refresh this window and any associated windows. */
329 virtual void refresh ();
330
1825f487
TT
331 /* Called after all the TUI windows are refreshed, to let this
332 window have a chance to update itself further. */
333 virtual void refresh_all ()
334 {
335 }
336
3f02ce1e
TT
337 /* Called after a TUI window is given a new height; this updates any
338 related auxiliary windows. */
339 virtual void set_new_height (int height)
340 {
341 }
342
8903bd8a
TT
343 /* Compute the maximum height of this window. */
344 virtual int max_height () const;
345
d83f1fe6
TT
346 /* Called after the tab width has been changed. */
347 virtual void update_tab_width ()
348 {
349 }
350
5fcee43a
TT
351 /* Make the window visible after the height has been changed. */
352 void make_visible_with_new_height ();
353
214a5cbe
TT
354 /* Set whether this window is highglighted. */
355 void set_highlight (bool highlight)
356 {
357 is_highlighted = highlight;
358 }
359
13446e05
TT
360 /* Methods to scroll the contents of this window. Note that they
361 are named with "_scroll" coming at the end because the more
362 obvious "scroll_forward" is defined as a macro in term.h. */
363 void forward_scroll (int num_to_scroll);
364 void backward_scroll (int num_to_scroll);
365 void left_scroll (int num_to_scroll);
366 void right_scroll (int num_to_scroll);
367
33b906ab 368 /* Can this window ever be highlighted? */
d6ba6a11 369 bool can_highlight = true;
33b906ab
TT
370
371 /* Is this window highlighted? */
214a5cbe 372 bool is_highlighted = false;
33b906ab
TT
373};
374
5cf82909
TT
375/* The base class for all source-like windows, namely the source and
376 disassembly windows. */
377
378struct tui_source_window_base : public tui_win_info
33b906ab 379{
5cf82909
TT
380protected:
381 explicit tui_source_window_base (enum tui_win_type type);
382 ~tui_source_window_base () override;
383 DISABLE_COPY_AND_ASSIGN (tui_source_window_base);
384
c3bd716f 385 void do_scroll_horizontal (int num_to_scroll) override;
5fcee43a 386 void do_make_visible_with_new_height () override;
13446e05 387
5cf82909 388public:
8761a91b
TT
389
390 void clear_detail () override;
44f0e208
TT
391
392 /* Return true if this window has the locator. */
e6e41501
TT
393 bool has_locator () const override
394 {
395 return m_has_locator;
396 }
397
56122977 398 void make_visible (bool visible) override;
2042b506 399 void refresh () override;
1825f487 400 void refresh_all () override;
cda37efb 401
ad54d15b
TT
402 /* Refill the source window's source cache and update it. If this
403 is a disassembly window, then just update it. */
404 void refill ();
405
406 /* Set the location of the execution point. */
407 void set_is_exec_point_at (struct tui_line_or_address l);
408
3f02ce1e
TT
409 void set_new_height (int height) override;
410
d83f1fe6
TT
411 void update_tab_width () override;
412
e6e41501
TT
413 /* Does the locator belong to this window? */
414 bool m_has_locator = false;
415 /* Execution information window. */
489e9d8b 416 struct tui_exec_info_window *execution_info = nullptr;
e6e41501
TT
417 /* Used for horizontal scroll. */
418 int horizontal_offset = 0;
419 struct tui_line_or_address start_line_or_addr;
420
421 /* It is the resolved form as returned by symtab_to_fullname. */
422 char *fullname = nullptr;
423
424 /* Architecture associated with code at this location. */
425 struct gdbarch *gdbarch = nullptr;
33b906ab
TT
426};
427
5cf82909
TT
428/* A TUI source window. */
429
430struct tui_source_window : public tui_source_window_base
431{
432 tui_source_window ()
433 : tui_source_window_base (SRC_WIN)
434 {
435 }
436
437 DISABLE_COPY_AND_ASSIGN (tui_source_window);
13446e05 438
152f3f4b
TT
439 const char *name () const override
440 {
441 return SRC_NAME;
442 }
443
13446e05
TT
444protected:
445
c3bd716f 446 void do_scroll_vertical (int num_to_scroll) override;
5cf82909
TT
447};
448
449/* A TUI disassembly window. */
450
451struct tui_disasm_window : public tui_source_window_base
452{
453 tui_disasm_window ()
454 : tui_source_window_base (DISASSEM_WIN)
455 {
456 }
457
458 DISABLE_COPY_AND_ASSIGN (tui_disasm_window);
13446e05 459
152f3f4b
TT
460 const char *name () const override
461 {
462 return DISASSEM_NAME;
463 }
464
13446e05
TT
465protected:
466
c3bd716f 467 void do_scroll_vertical (int num_to_scroll) override;
5cf82909
TT
468};
469
33b906ab
TT
470struct tui_data_window : public tui_win_info
471{
63901aec
TT
472 tui_data_window ()
473 : tui_win_info (DATA_WIN)
474 {
475 }
476
ee1d42d6 477 ~tui_data_window () override;
33b906ab 478 DISABLE_COPY_AND_ASSIGN (tui_data_window);
8761a91b
TT
479
480 void clear_detail () override;
1825f487 481 void refresh_all () override;
13446e05 482
3f02ce1e
TT
483 void set_new_height (int height) override;
484
5b81daba
TT
485 void refresh_window () override;
486
152f3f4b
TT
487 const char *name () const override
488 {
489 return DATA_NAME;
490 }
491
63901aec
TT
492 /* Start of data display content. */
493 tui_win_content data_content = NULL;
494 int data_content_count = 0;
495 /* Start of regs display content. */
496 tui_win_content regs_content = NULL;
497 int regs_content_count = 0;
498 int regs_column_count = 0;
499 /* Should regs be displayed at all? */
500 bool display_regs = false;
501 struct reggroup *current_group = nullptr;
238eb706 502
13446e05
TT
503protected:
504
c3bd716f
TT
505 void do_scroll_vertical (int num_to_scroll) override;
506 void do_scroll_horizontal (int num_to_scroll) override
13446e05
TT
507 {
508 }
5fcee43a 509 void do_make_visible_with_new_height () override;
33b906ab
TT
510};
511
512struct tui_cmd_window : public tui_win_info
513{
63901aec
TT
514 tui_cmd_window ()
515 : tui_win_info (CMD_WIN)
516 {
d6ba6a11 517 can_highlight = false;
63901aec
TT
518 }
519
33b906ab 520 DISABLE_COPY_AND_ASSIGN (tui_cmd_window);
8761a91b
TT
521
522 void clear_detail () override;
13446e05 523
56122977 524 void make_visible (bool visible) override
cda37efb
TT
525 {
526 }
527
8903bd8a
TT
528 int max_height () const override;
529
5b81daba
TT
530 void refresh_window () override
531 {
532 }
533
152f3f4b
TT
534 const char *name () const override
535 {
536 return CMD_NAME;
537 }
538
63901aec 539 int start_line = 0;
81491aa0 540
13446e05
TT
541protected:
542
c3bd716f 543 void do_scroll_vertical (int num_to_scroll) override
13446e05
TT
544 {
545 }
546
c3bd716f 547 void do_scroll_horizontal (int num_to_scroll) override
13446e05
TT
548 {
549 }
5fcee43a
TT
550
551 void do_make_visible_with_new_height () override;
2a8854a7 552};
c906108c 553
6d012f14 554extern int tui_win_is_auxillary (enum tui_win_type win_type);
c906108c
SS
555
556
1cc6d956 557/* Global Data. */
7fa29be9 558extern struct tui_win_info *tui_win_list[MAX_MAJOR_WINDOWS];
c906108c 559
e6e41501
TT
560#define TUI_SRC_WIN ((tui_source_window_base *) tui_win_list[SRC_WIN])
561#define TUI_DISASM_WIN ((tui_source_window_base *) tui_win_list[DISASSEM_WIN])
238eb706 562#define TUI_DATA_WIN ((tui_data_window *) tui_win_list[DATA_WIN])
81491aa0 563#define TUI_CMD_WIN ((tui_cmd_window *) tui_win_list[CMD_WIN])
c906108c 564
1cc6d956 565/* Data Manipulation Functions. */
dd1abb8c 566extern void tui_initialize_static_data (void);
dd1abb8c 567extern void tui_init_generic_part (struct tui_gen_win_info *);
2a8854a7 568extern tui_win_content tui_alloc_content (int, enum tui_win_type);
08ef48c5
MS
569extern int tui_add_content_elements (struct tui_gen_win_info *,
570 int);
dd1abb8c 571extern void tui_free_win_content (struct tui_gen_win_info *);
2a8854a7 572extern void tui_free_data_content (tui_win_content, int);
dd1abb8c 573extern void tui_free_all_source_wins_content (void);
a121b7c1 574extern struct tui_win_info *tui_partial_win_by_name (const char *);
2a8854a7
AC
575extern enum tui_layout_type tui_current_layout (void);
576extern void tui_set_current_layout_to (enum tui_layout_type);
dd1abb8c
AC
577extern int tui_term_height (void);
578extern void tui_set_term_height_to (int);
579extern int tui_term_width (void);
580extern void tui_set_term_width_to (int);
3add462f 581extern struct tui_locator_window *tui_locator_win_info_ptr (void);
ad54d15b 582extern std::vector<tui_source_window_base *> &tui_source_windows ();
dd1abb8c
AC
583extern void tui_clear_source_windows (void);
584extern void tui_clear_source_windows_detail (void);
ad54d15b 585extern void tui_add_to_source_windows (struct tui_source_window_base *);
dd1abb8c
AC
586extern struct tui_win_info *tui_win_with_focus (void);
587extern void tui_set_win_with_focus (struct tui_win_info *);
5b6fe301 588extern struct tui_layout_def *tui_layout_def (void);
dd1abb8c
AC
589extern int tui_win_resized (void);
590extern void tui_set_win_resized_to (int);
591
592extern struct tui_win_info *tui_next_win (struct tui_win_info *);
593extern struct tui_win_info *tui_prev_win (struct tui_win_info *);
594
7806cea7
TT
595extern unsigned int tui_tab_width;
596
1a5c2598 597#endif /* TUI_TUI_DATA_H */
This page took 1.948628 seconds and 4 git commands to generate.