* ada-lang.c (ada_evaluate_subexp) [BINOP_ADD, BINOP_SUB]:
Add special handling for pointer types.
This commit is contained in:
parent
b861ac8114
commit
2ac8a782d9
2 changed files with 13 additions and 0 deletions
|
@ -8497,6 +8497,10 @@ ada_evaluate_subexp (struct type *expect_type, struct expression *exp,
|
|||
arg2 = evaluate_subexp_with_coercion (exp, pos, noside);
|
||||
if (noside == EVAL_SKIP)
|
||||
goto nosideret;
|
||||
if (TYPE_CODE (value_type (arg1)) == TYPE_CODE_PTR)
|
||||
return (value_from_longest
|
||||
(value_type (arg1),
|
||||
value_as_long (arg1) + value_as_long (arg2)));
|
||||
if ((ada_is_fixed_point_type (value_type (arg1))
|
||||
|| ada_is_fixed_point_type (value_type (arg2)))
|
||||
&& value_type (arg1) != value_type (arg2))
|
||||
|
@ -8514,6 +8518,10 @@ ada_evaluate_subexp (struct type *expect_type, struct expression *exp,
|
|||
arg2 = evaluate_subexp_with_coercion (exp, pos, noside);
|
||||
if (noside == EVAL_SKIP)
|
||||
goto nosideret;
|
||||
if (TYPE_CODE (value_type (arg1)) == TYPE_CODE_PTR)
|
||||
return (value_from_longest
|
||||
(value_type (arg1),
|
||||
value_as_long (arg1) - value_as_long (arg2)));
|
||||
if ((ada_is_fixed_point_type (value_type (arg1))
|
||||
|| ada_is_fixed_point_type (value_type (arg2)))
|
||||
&& value_type (arg1) != value_type (arg2))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue