mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-05-31 01:45:52 +08:00
Use previous count when 'x' command is repeated
About the 'x' command, the manual says: If you use <RET> to repeat the 'x' command, the repeat count N is used again; the other arguments default as for successive uses of 'x'. However, PR gdb/22619 points out that this does not work. This patch fixes the problem. ChangeLog 2018-05-04 Tom Tromey <tom@tromey.com> PR gdb/22619: * printcmd.c (last_count): New global. (x_command): Use saved count when repeating. testsuite/ChangeLog 2018-05-04 Tom Tromey <tom@tromey.com> PR gdb/22619: * gdb.base/long_long.exp (gdb_test_long_long): Add test for repeat behavior.
This commit is contained in:
@ -62,6 +62,10 @@ static char last_format = 0;
|
||||
|
||||
static char last_size = 'w';
|
||||
|
||||
/* Last specified count for the 'x' command. */
|
||||
|
||||
static int last_count;
|
||||
|
||||
/* Default address to examine next, and associated architecture. */
|
||||
|
||||
static struct gdbarch *next_gdbarch;
|
||||
@ -1616,6 +1620,11 @@ x_command (const char *exp, int from_tty)
|
||||
fmt.count = 1;
|
||||
fmt.raw = 0;
|
||||
|
||||
/* If there is no expression and no format, use the most recent
|
||||
count. */
|
||||
if (exp == nullptr && last_count > 0)
|
||||
fmt.count = last_count;
|
||||
|
||||
if (exp && *exp == '/')
|
||||
{
|
||||
const char *tmp = exp + 1;
|
||||
@ -1624,6 +1633,8 @@ x_command (const char *exp, int from_tty)
|
||||
exp = (char *) tmp;
|
||||
}
|
||||
|
||||
last_count = fmt.count;
|
||||
|
||||
/* If we have an expression, evaluate it and use it as the address. */
|
||||
|
||||
if (exp != 0 && *exp != 0)
|
||||
|
Reference in New Issue
Block a user