diff options
author | Joel Brobecker <brobecker@adacore.com> | 2014-10-09 12:37:17 -0400 |
---|---|---|
committer | Joel Brobecker <brobecker@adacore.com> | 2014-10-14 14:05:11 -0700 |
commit | c40cc657bcc930b83ec42e071fe419073bd199f5 (patch) | |
tree | 5bbf82ebaeae8c4787a1ffa35b2011cacaa07dd2 /binutils | |
parent | 2abf49e11e603ecc002fa27704a978733c601386 (diff) | |
download | gdb-c40cc657bcc930b83ec42e071fe419073bd199f5.zip gdb-c40cc657bcc930b83ec42e071fe419073bd199f5.tar.gz gdb-c40cc657bcc930b83ec42e071fe419073bd199f5.tar.bz2 |
[Ada] Error adding/subtracting pointer value to/from integral.
When trying to evaluate an expression which adds a pointer and
an integral, the evaluation succeeds if the pointer is on
the left handside of the operator, but not when it is on the right
handside:
(gdb) p something'address + 0
$1 = (system.address) 0x613418 <pck.something>
(gdb) p 0 + something'address
Argument to arithmetic operation not a number or boolean.
Same issue when doing subtractions:
(gdb) p something'address - 0
$2 = (system.address) 0x613418 <pck.something>
(gdb) p 0 - something'address
Argument to arithmetic operation not a number or boolean.
This patch enhances the Ada expression evaluator to handle
these two situations.
gdb/ChangeLog:
* ada-lang.c (ada_evaluate_subexp) <BINOP_ADD>: Add handling
of the case where the second operand is a pointer.
<BINOP_SUB>: Likewise.
gdb/testsuite/ChangeLog:
* gdb.ada/addr_arith: New testcase.
Tested on x86_64-linux.
Diffstat (limited to 'binutils')
0 files changed, 0 insertions, 0 deletions