aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.python/tui-window-disabled.py
diff options
context:
space:
mode:
Diffstat (limited to 'gdb/testsuite/gdb.python/tui-window-disabled.py')
-rw-r--r--gdb/testsuite/gdb.python/tui-window-disabled.py89
1 files changed, 89 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.python/tui-window-disabled.py b/gdb/testsuite/gdb.python/tui-window-disabled.py
new file mode 100644
index 0000000..0b3c076
--- /dev/null
+++ b/gdb/testsuite/gdb.python/tui-window-disabled.py
@@ -0,0 +1,89 @@
+# Copyright (C) 2021 Free Software Foundation, Inc.
+#
+# 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/>.
+
+# A TUI window implemented in Python that responds to, and displays,
+# stop and exit events.
+
+import gdb
+
+# When an event arrives we ask the window to redraw itself. We should
+# only do this if the window is valid. When this flag is true we
+# perform the is_valid check. When this flag is false
+perform_valid_check = True
+update_title = False
+cleanup_properly = False
+
+# A global place into which we can write the window title.
+titles_at_the_close = {}
+
+class EventWindow:
+ def __init__ (self, win):
+ self._win = win
+ self._count = 0
+ win.title = "This Is The Event Window"
+ self._stop_listener = lambda e : self._event ('stop', e)
+ gdb.events.stop.connect (self._stop_listener)
+ self._exit_listener = lambda e : self._event ('exit', e)
+ gdb.events.exited.connect (self._exit_listener)
+ self._events = []
+
+ # Ensure we can erase and write to the window from the
+ # constructor, the window should be valid by this point.
+ self._win.erase ()
+ self._win.write ("Hello world...")
+
+ def close (self):
+ global cleanup_properly
+ global titles_at_the_close
+
+ # Ensure that window properties can be read within the close method.
+ titles_at_the_close[self._win.title] = dict (width=self._win.width,
+ height=self._win.height)
+
+ # The following calls are pretty pointless, but this ensures
+ # that we can erase and write to a window from the close
+ # method, the last moment a window should be valid.
+ self._win.erase ()
+ self._win.write ("Goodbye cruel world...")
+
+ if cleanup_properly:
+ # Disconnect the listeners and delete the lambda functions.
+ # This removes cyclic references to SELF, and so alows SELF to
+ # be deleted.
+ gdb.events.stop.disconnect (self._stop_listener)
+ gdb.events.exited.disconnect (self._exit_listener)
+ self._stop_listener = None
+ self._exit_listener = None
+
+ def _event (self, type, event):
+ global perform_valid_check
+ global update_title
+
+ self._count += 1
+ self._events.insert (0, type)
+ if not perform_valid_check or self._win.is_valid ():
+ if update_title:
+ self._win.title = "This Is The Event Window (" + str (self._count) + ")"
+ else:
+ self.render ()
+
+ def render (self):
+ self._win.erase ()
+ w = self._win.width
+ h = self._win.height
+ for i in range (min (h, len (self._events))):
+ self._win.write (self._events[i] + "\n")
+
+gdb.register_window_type("events", EventWindow)