From: Pedro Alves <pedro@codesourcery.com>
To: gdb-patches@sourceware.org
Subject: Don't allow switching on the TUI in some cases
Date: Tue, 30 Mar 2010 22:23:00 -0000 [thread overview]
Message-ID: <201003302323.40127.pedro@codesourcery.com> (raw)
A slightly updated patch originally posted at:
<http://sourceware.org/ml/gdb-patches/2010-03/msg01085.html>
Tested on x86_64-linux and checked in.
--
Pedro Alves
2010-03-30 Pedro Alves <pedro@codesourcery.com>
* tui/tui-interp.c (tui_is_toplevel): New.
(tui_init): Set it.
(tui_allowed_p): New.
* tui/tui.c (tui_enable): Check if the TUI is allowed before
enabling it.
* tui/tui.h (tui_allowed_p): Declare.
---
gdb/tui/tui-interp.c | 17 +++++++++++++++++
gdb/tui/tui.c | 3 +++
gdb/tui/tui.h | 4 ++++
3 files changed, 24 insertions(+)
Index: src/gdb/tui/tui-interp.c
===================================================================
--- src.orig/gdb/tui/tui-interp.c 2010-03-30 21:40:50.000000000 +0100
+++ src/gdb/tui/tui-interp.c 2010-03-30 22:44:05.000000000 +0100
@@ -45,11 +45,16 @@ tui_exit (void)
tui_disable ();
}
+/* True if TUI is the top-level interpreter. */
+static int tui_is_toplevel = 0;
+
/* These implement the TUI interpreter. */
static void *
tui_init (int top_level)
{
+ tui_is_toplevel = top_level;
+
/* Install exit handler to leave the screen in a good shape. */
atexit (tui_exit);
@@ -63,6 +68,18 @@ tui_init (int top_level)
return NULL;
}
+/* True if enabling the TUI is allowed. Example, if the top level
+ interpreter is MI, enabling curses will certainly lose. */
+
+int
+tui_allowed_p (void)
+{
+ /* Only if TUI is the top level interpreter. Also don't try to
+ setup curses (and print funny control characters) if we're not
+ outputting to a terminal. */
+ return tui_is_toplevel && ui_file_isatty (gdb_stdout);
+}
+
static int
tui_resume (void *data)
{
Index: src/gdb/tui/tui.c
===================================================================
--- src.orig/gdb/tui/tui.c 2010-03-30 21:40:50.000000000 +0100
+++ src/gdb/tui/tui.c 2010-03-30 22:39:28.000000000 +0100
@@ -364,6 +364,9 @@ tui_initialize_readline (void)
void
tui_enable (void)
{
+ if (!tui_allowed_p ())
+ error (_("TUI mode not allowed"));
+
if (tui_active)
return;
Index: src/gdb/tui/tui.h
===================================================================
--- src.orig/gdb/tui/tui.h 2010-03-30 21:40:50.000000000 +0100
+++ src/gdb/tui/tui.h 2010-03-30 22:39:28.000000000 +0100
@@ -65,6 +65,10 @@ extern int tui_get_command_dimension (un
key shortcut. */
extern void tui_initialize_readline (void);
+/* True if enabling the TUI is allowed. Example, if the top level
+ interpreter is MI, enabling curses will certainly lose. */
+extern int tui_allowed_p (void);
+
/* Enter in the tui mode (curses). */
extern void tui_enable (void);
next reply other threads:[~2010-03-30 22:23 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-03-30 22:23 Pedro Alves [this message]
2010-03-31 7:30 ` Eli Zaretskii
2010-03-31 11:47 ` Pedro Alves
2010-03-31 12:09 ` Eli Zaretskii
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=201003302323.40127.pedro@codesourcery.com \
--to=pedro@codesourcery.com \
--cc=gdb-patches@sourceware.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox