PR gdb/20604 - fix "quit" when an invalid expression is used
authorTom Tromey <tom@tromey.com>
Wed, 14 Sep 2016 17:48:31 +0000 (11:48 -0600)
committerTom Tromey <tom@tromey.com>
Wed, 21 Sep 2016 17:39:37 +0000 (11:39 -0600)
commit36cf1806a87fdd208c704d0768af232ce35aae9f
tree58fa483828e183ae1effb31bf393e57d34d52ee1
parent74172ecf37e5877085c5d01f335db94e8091ba97
PR gdb/20604 - fix "quit" when an invalid expression is used

This fixes PR gdb/20604.  The bug here is that passing an invalid
expression to "quit" -- e.g., "quit()" -- causes gdb to enter a
non-functioning state.

The immediate problem is that quit_force resets the terminal before
evaluating the expression.  However, it seemed to me that it doesn't
really make sense to pass the quit_force argument to kill_or_detach
(which passes it to to_detach), first because conflating the exit
status for "quit" and the signal to pass when detaching doesn't make
sense, and second because to_detach implementations generally only
accept a constant here, while "quit" accepts an expression.  So, I
removed that.

As an aside, I think the "detach SIGNO" functionality is not
documented.

Built and regtested on x86-64 Fedora 24.

2016-09-21  Tom Tromey  <tom@tromey.com>

PR gdb/20604:
* top.h (quit_force): Update.
* top.c (quit_force): Changed type of first argument.  Don't
evaluate expression.  Pass NULL to kill_or_detach.
* cli/cli-cmds.c (quit_command): Evaluate "args".

2016-09-21  Tom Tromey  <tom@tromey.com>

PR gdb/20604:
* gdb.base/quit.exp: New file.
gdb/ChangeLog
gdb/cli/cli-cmds.c
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.base/quit.exp [new file with mode: 0644]
gdb/top.c
gdb/top.h