diff options
author | Joel Brobecker <brobecker@adacore.com> | 2015-01-15 10:09:32 +0400 |
---|---|---|
committer | Joel Brobecker <brobecker@adacore.com> | 2015-01-15 12:53:33 +0400 |
commit | bafffb51c4da50881dc5d72ec9bf9b78377ac692 (patch) | |
tree | 0ebb3809995e2b934463341e002e7aad458d88fe /gdb/ada-lang.c | |
parent | a300380e12ca04a6cb900e9bfd26161b3fe56ed8 (diff) | |
download | gdb-bafffb51c4da50881dc5d72ec9bf9b78377ac692.zip gdb-bafffb51c4da50881dc5d72ec9bf9b78377ac692.tar.gz gdb-bafffb51c4da50881dc5d72ec9bf9b78377ac692.tar.bz2 |
[Ada] 'first/'last/'length of array whose bound is a discriminant
Consider the following code:
type Table is array (Positive range <>) of Integer;
type Object (N : Integer) is record
Data : Table (1 .. N);
end record;
My_Object : Object := (N => 3, Data => (3, 5, 8));
Trying to print the range and length of the My_Object.Data array yields:
(gdb) print my_object.data'first
$1 = 1
(gdb) print my_object.data'last
$2 = 0
(gdb) print my_object.data'length
$3 = 0
The first one is correct, and that is thanks to the fact that
the lower bound is statically known. However, for the upper
bound, and consequently the array's length, the values are incorrect.
It should be:
(gdb) print my_object.data'last
$2 = 3
(gdb) print my_object.data'length
$3 = 3
What happens here is that ada_array_bound_from_type sees that
our array has a parallel "___XA" type, and therefore tries to
use it. In particular, it described our array's index type as:
[...]___XDLU_1__n, which means lower bound = 1, and upper bound
is value of "n". Unfortunately, ada_array_bound_from_type does
not have access to the discriminant, and is therefore unable to
compute the bound correctly.
Fortunately, at this stage, the bound has already been computed
a while ago, and therefore doesn't need to be re-computed here.
This patch fixes the issue by ignoring that ___XA type if the array
is marked as already fixed.
This also fixes the same issue with packed arrays.
gdb/ChangeLog:
* ada-lang.c (ada_array_bound_from_type): Ignore array's parallel
___XA type if the array has already been fixed.
gdb/testsuite/ChangeLog:
* gdb.ada/var_arr_attrs: New testcase.
Diffstat (limited to 'gdb/ada-lang.c')
-rw-r--r-- | gdb/ada-lang.c | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/gdb/ada-lang.c b/gdb/ada-lang.c index ec06693..f5753f1 100644 --- a/gdb/ada-lang.c +++ b/gdb/ada-lang.c @@ -2928,8 +2928,19 @@ ada_array_bound_from_type (struct type *arr_type, int n, int which) else type = arr_type; - index_type_desc = ada_find_parallel_type (type, "___XA"); - ada_fixup_array_indexes_type (index_type_desc); + if (TYPE_FIXED_INSTANCE (type)) + { + /* The array has already been fixed, so we do not need to + check the parallel ___XA type again. That encoding has + already been applied, so ignore it now. */ + index_type_desc = NULL; + } + else + { + index_type_desc = ada_find_parallel_type (type, "___XA"); + ada_fixup_array_indexes_type (index_type_desc); + } + if (index_type_desc != NULL) index_type = to_fixed_range_type (TYPE_FIELD_TYPE (index_type_desc, n - 1), NULL); |