aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Tromey <tom@tromey.com>2019-06-28 22:55:45 -0600
committerTom Tromey <tom@tromey.com>2019-07-17 12:19:09 -0600
commitf31ec9af48578adb0baf8db3e10da871d6ee3eca (patch)
tree2dcb164e0f0bfa99dbaff8c1ba1744e946ae7004
parentd1b6f1e5ebdd755274a77a31c4afa48969b73bee (diff)
downloadgdb-f31ec9af48578adb0baf8db3e10da871d6ee3eca.zip
gdb-f31ec9af48578adb0baf8db3e10da871d6ee3eca.tar.gz
gdb-f31ec9af48578adb0baf8db3e10da871d6ee3eca.tar.bz2
Simplify source window clearing
When a TUI source window is empty, it displays a "No Source Available" message. The function tui_set_source_content_nil also made sure to put this message into the window's "content" field. However, I believe this isn't really necessary. Instead, it's simpler to just empty the contents and let curses handle the refreshing. gdb/ChangeLog 2019-07-17 Tom Tromey <tom@tromey.com> * tui/tui-winsource.c (tui_erase_source_content): Clear the window's contents. * tui/tui-source.h (tui_set_source_content_nil): Don't declare. * tui/tui-source.c (tui_set_source_content_nil): Remove.
-rw-r--r--gdb/ChangeLog7
-rw-r--r--gdb/tui/tui-source.c63
-rw-r--r--gdb/tui/tui-source.h3
-rw-r--r--gdb/tui/tui-winsource.c8
4 files changed, 8 insertions, 73 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index ee17d50..4b5a876 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,12 @@
2019-07-17 Tom Tromey <tom@tromey.com>
+ * tui/tui-winsource.c (tui_erase_source_content): Clear the
+ window's contents.
+ * tui/tui-source.h (tui_set_source_content_nil): Don't declare.
+ * tui/tui-source.c (tui_set_source_content_nil): Remove.
+
+2019-07-17 Tom Tromey <tom@tromey.com>
+
* tui/tui-data.h (UNDEFINED_ITEM): Remove define.
(struct tui_data_item_window): Update.
diff --git a/gdb/tui/tui-source.c b/gdb/tui/tui-source.c
index 2fcb42d..d3cce1c 100644
--- a/gdb/tui/tui-source.c
+++ b/gdb/tui/tui-source.c
@@ -209,69 +209,6 @@ tui_set_source_content (tui_source_window_base *win_info,
}
-/* elz: This function sets the contents of the source window to empty
- except for a line in the middle with a warning message about the
- source not being available. This function is called by
- tui_erase_source_contents(), which in turn is invoked when the
- source files cannot be accessed. */
-
-void
-tui_set_source_content_nil (struct tui_source_window_base *win_info,
- const char *warning_string)
-{
- int line_width;
- int n_lines;
- int curr_line = 0;
-
- line_width = win_info->width - 1;
- n_lines = win_info->height - 2;
-
- /* Set to empty each line in the window, except for the one which
- contains the message. */
- while (curr_line < win_info->content.size ())
- {
- /* Set the information related to each displayed line to null:
- i.e. the line number is 0, there is no bp, it is not where
- the program is stopped. */
-
- struct tui_source_element *element = &win_info->content[curr_line];
-
- element->line_or_addr.loa = LOA_LINE;
- element->line_or_addr.u.line_no = 0;
- element->is_exec_point = false;
- element->break_mode = 0;
-
- /* Set the contents of the line to blank. */
- element->line[0] = (char) 0;
-
- /* If the current line is in the middle of the screen, then we
- want to display the 'no source available' message in it.
- Note: the 'weird' arithmetic with the line width and height
- comes from the function tui_erase_source_content(). We need
- to keep the screen and the window's actual contents in
- synch. */
-
- if (curr_line == (n_lines / 2 + 1))
- {
- int xpos;
- int warning_length = strlen (warning_string);
- char *src_line;
-
- if (warning_length >= ((line_width - 1) / 2))
- xpos = 1;
- else
- xpos = (line_width - 1) / 2 - warning_length;
-
- src_line = xstrprintf ("%s%s", n_spaces (xpos), warning_string);
- xfree (element->line);
- element->line = src_line;
- }
-
- curr_line++;
- }
-}
-
-
/* Function to display source in the source window. This function
initializes the horizontal scroll to 0. */
void
diff --git a/gdb/tui/tui-source.h b/gdb/tui/tui-source.h
index e4b2313..fc129ab 100644
--- a/gdb/tui/tui-source.h
+++ b/gdb/tui/tui-source.h
@@ -27,9 +27,6 @@
struct symtab;
struct tui_win_info;
-extern void tui_set_source_content_nil (struct tui_source_window_base *,
- const char *);
-
extern enum tui_status tui_set_source_content (tui_source_window_base *,
struct symtab *,
int, int);
diff --git a/gdb/tui/tui-winsource.c b/gdb/tui/tui-winsource.c
index 65aa516..2be2049 100644
--- a/gdb/tui/tui-winsource.c
+++ b/gdb/tui/tui-winsource.c
@@ -250,13 +250,7 @@ tui_erase_source_content (struct tui_source_window_base *win_info)
x_pos,
(char *) no_src_str);
- /* elz: Added this function call to set the real contents of
- the window to what is on the screen, so that later calls
- to refresh, do display the correct stuff, and not the old
- image. */
-
- tui_set_source_content_nil (win_info, no_src_str);
-
+ win_info->content.clear ();
win_info->refresh_window ();
}
}