binutils-gdb/gdb/tui/tui-wingeneral.c
Tom Tromey 1ce3e8442e Introduce TUI window iterator
This introduces an iterator class and a range adapter to make it
simpler to iterate over TUI windows.

One explicit iteration remains, in tui-win.c, because that spot is
deleting windows as well.

gdb/ChangeLog
2019-07-17  Tom Tromey  <tom@tromey.com>

	* tui/tui-wingeneral.h (tui_refresh_all): Update.
	* tui/tui-wingeneral.c (make_all_visible): Use foreach.
	(tui_refresh_all): Remove "list" parameter.  Use foreach.
	* tui/tui-win.c (window_name_completer): Use foreach.
	(tui_refresh_all_win, tui_rehighlight_all, tui_all_windows_info)
	(update_tab_width): Likewise.
	* tui/tui-layout.c (show_layout): Update.
	* tui/tui-data.h (class tui_window_iterator): New.
	(struct all_tui_windows): New.
	* tui/tui-data.c (tui_partial_win_by_name): Use foreach.
2019-07-17 12:19:03 -06:00

272 lines
5.5 KiB
C

/* General window behavior.
Copyright (C) 1998-2019 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/>. */
#include "defs.h"
#include "tui/tui.h"
#include "tui/tui-data.h"
#include "tui/tui-wingeneral.h"
#include "tui/tui-win.h"
#include "gdb_curses.h"
/***********************
** PUBLIC FUNCTIONS
***********************/
/* See tui-data.h. */
void
tui_gen_win_info::refresh_window ()
{
if (handle != NULL)
wrefresh (handle);
}
/* See tui-data.h. */
void
tui_data_window::refresh_window ()
{
if (!regs_content.empty ())
{
for (auto &&win : regs_content)
{
if (win != NULL && win->handle != NULL)
wrefresh (win->handle);
}
}
else
tui_gen_win_info::refresh_window ();
}
/* Function to delete the curses window, checking for NULL. */
void
tui_delete_win (WINDOW *window)
{
if (window != NULL)
delwin (window);
}
/* Draw a border arround the window. */
static void
box_win (struct tui_gen_win_info *win_info,
int highlight_flag)
{
if (win_info && win_info->handle)
{
WINDOW *win;
int attrs;
win = win_info->handle;
if (highlight_flag == HILITE)
attrs = tui_active_border_attrs;
else
attrs = tui_border_attrs;
wattron (win, attrs);
#ifdef HAVE_WBORDER
wborder (win, tui_border_vline, tui_border_vline,
tui_border_hline, tui_border_hline,
tui_border_ulcorner, tui_border_urcorner,
tui_border_llcorner, tui_border_lrcorner);
#else
box (win, tui_border_vline, tui_border_hline);
#endif
if (win_info->title)
mvwaddstr (win, 0, 3, win_info->title);
wattroff (win, attrs);
}
}
void
tui_unhighlight_win (struct tui_win_info *win_info)
{
if (win_info != NULL
&& win_info->can_highlight
&& win_info->handle != NULL)
{
box_win (win_info, NO_HILITE);
wrefresh (win_info->handle);
win_info->set_highlight (false);
}
}
void
tui_highlight_win (struct tui_win_info *win_info)
{
if (win_info != NULL
&& win_info->can_highlight
&& win_info->handle != NULL)
{
box_win (win_info, HILITE);
wrefresh (win_info->handle);
win_info->set_highlight (true);
}
}
void
tui_check_and_display_highlight_if_needed (struct tui_win_info *win_info)
{
if (win_info != NULL && win_info->can_highlight)
{
if (win_info->is_highlighted)
tui_highlight_win (win_info);
else
tui_unhighlight_win (win_info);
}
return;
}
void
tui_make_window (struct tui_gen_win_info *win_info, enum tui_box box_it)
{
WINDOW *handle;
handle = newwin (win_info->height,
win_info->width,
win_info->origin.y,
win_info->origin.x);
win_info->handle = handle;
if (handle != NULL)
{
if (box_it == BOX_WINDOW)
box_win (win_info, NO_HILITE);
win_info->is_visible = true;
scrollok (handle, TRUE);
}
}
/* We can't really make windows visible, or invisible. So we have to
delete the entire window when making it visible, and create it
again when making it visible. */
void
tui_gen_win_info::make_visible (bool visible)
{
if (visible)
{
if (!is_visible)
{
tui_make_window (this, (tui_win_is_auxiliary (type)
? DONT_BOX_WINDOW : BOX_WINDOW));
is_visible = true;
}
}
else if (!visible
&& is_visible
&& handle != NULL)
{
is_visible = false;
tui_delete_win (handle);
handle = NULL;
}
}
void
tui_make_visible (struct tui_gen_win_info *win_info)
{
win_info->make_visible (true);
}
void
tui_make_invisible (struct tui_gen_win_info *win_info)
{
win_info->make_visible (false);
}
/* See tui-data.h. */
void
tui_source_window_base::make_visible (bool visible)
{
if (execution_info != nullptr)
execution_info->make_visible (visible);
tui_win_info::make_visible (visible);
}
/* Makes all windows invisible (except the command and locator
windows). */
static void
make_all_visible (bool visible)
{
for (tui_win_info *win_info : all_tui_windows ())
win_info->make_visible (visible);
}
void
tui_make_all_visible (void)
{
make_all_visible (true);
}
void
tui_make_all_invisible (void)
{
make_all_visible (false);
}
/* See tui-data.h. */
void
tui_win_info::refresh ()
{
touchwin (handle);
refresh_window ();
}
/* See tui-data.h. */
void
tui_source_window_base::refresh ()
{
touchwin (execution_info->handle);
execution_info->refresh_window ();
tui_win_info::refresh ();
}
/* Function to refresh all the windows currently displayed. */
void
tui_refresh_all ()
{
struct tui_locator_window *locator = tui_locator_win_info_ptr ();
for (tui_win_info *win_info : all_tui_windows ())
{
if (win_info->is_visible)
win_info->refresh ();
}
if (locator->is_visible)
{
touchwin (locator->handle);
locator->refresh_window ();
}
}
/*********************************
** Local Static Functions
*********************************/