/* TUI display source window. 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 . */ #ifndef GDB_TUI_TUI_SOURCE_H #define GDB_TUI_TUI_SOURCE_H #include "gdbsupport/gdb-checked-static-cast.h" #include "tui/tui-data.h" #include "tui-winsource.h" /* A TUI source window. */ struct tui_source_window : public tui_source_window_base { tui_source_window (); ~tui_source_window (); DISABLE_COPY_AND_ASSIGN (tui_source_window); const char *name () const override { return SRC_NAME; } /* Return true if the location LOC corresponds to the line number LINE_NO in this source window; false otherwise. */ bool location_matches_p (struct bp_location *loc, int line_no) override; bool showing_source_p (const char *filename) const; void maybe_update (const frame_info_ptr &fi, symtab_and_line sal) override; void erase_source_content () override { do_erase_source_content (_("[ No Source Available ]")); } void display_start_addr (struct gdbarch **gdbarch_p, CORE_ADDR *addr_p) override; protected: void do_scroll_vertical (int num_to_scroll) override; bool set_contents (struct gdbarch *gdbarch, const struct symtab_and_line &sal) override; int extra_margin () const override { return m_digits; } void show_line_number (int lineno) const override; private: /* Answer whether a particular line number or address is displayed in the current source window. */ bool line_is_displayed (int line) const; /* How many digits to use when formatting the line number. This includes the trailing space. */ int m_digits; /* It is the resolved form as returned by symtab_to_fullname. */ gdb::unique_xmalloc_ptr m_fullname; /* A token used to register and unregister an observer. */ gdb::observers::token m_src_observable; }; /* Return the instance of the source window. */ inline tui_source_window * tui_src_win () { return gdb::checked_static_cast (tui_win_list[SRC_WIN]); } #endif /* GDB_TUI_TUI_SOURCE_H */