aboutsummaryrefslogtreecommitdiff
path: root/gcc/ada/gcc-interface/utils.c
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@adacore.com>2011-09-25 20:40:10 +0000
committerEric Botcazou <ebotcazou@gcc.gnu.org>2011-09-25 20:40:10 +0000
commitad1d36bafd1f18e33bd03169af788c6467f09c4d (patch)
tree9f6bbde3c9bf15f76ca025d853cd82821eb0fffd /gcc/ada/gcc-interface/utils.c
parent6162cec0d9ca47c71ab3b0effe544d53ce27e3c8 (diff)
downloadgcc-ad1d36bafd1f18e33bd03169af788c6467f09c4d.zip
gcc-ad1d36bafd1f18e33bd03169af788c6467f09c4d.tar.gz
gcc-ad1d36bafd1f18e33bd03169af788c6467f09c4d.tar.bz2
ada-tree.h (TREE_THIS_NOTRAP): Redefine.
* gcc-interface/ada-tree.h (TREE_THIS_NOTRAP): Redefine. * gcc-interface/trans.c (Identifier_to_gnu): Factor out common code in the by-ref case. Do not set TREE_READONLY on a renamed object. Set TREE_THIS_NOTRAP on UNCONSTRAINED_ARRAY_REF nodes. (Attribute_to_gnu) <Attr_Length>: Expand the use of the parameter cache to the indirect case. * gcc-interface/utils.c (convert) <UNCONSTRAINED_ARRAY_REF>: Preserve the TREE_THIS_NOTRAP flag. From-SVN: r179171
Diffstat (limited to 'gcc/ada/gcc-interface/utils.c')
-rw-r--r--gcc/ada/gcc-interface/utils.c29
1 files changed, 17 insertions, 12 deletions
diff --git a/gcc/ada/gcc-interface/utils.c b/gcc/ada/gcc-interface/utils.c
index 0176c3e..de9256a 100644
--- a/gcc/ada/gcc-interface/utils.c
+++ b/gcc/ada/gcc-interface/utils.c
@@ -3947,17 +3947,21 @@ convert (tree type, tree expr)
break;
case UNCONSTRAINED_ARRAY_REF:
- /* Convert this to the type of the inner array by getting the address of
- the array from the template. */
- expr = TREE_OPERAND (expr, 0);
- expr = build_unary_op (INDIRECT_REF, NULL_TREE,
- build_component_ref (expr, NULL_TREE,
- TYPE_FIELDS
- (TREE_TYPE (expr)),
- false));
- etype = TREE_TYPE (expr);
- ecode = TREE_CODE (etype);
- break;
+ {
+ /* Convert this to the type of the inner array by getting the address
+ of the array from the template. */
+ const bool no_trap = TREE_THIS_NOTRAP (expr);
+ expr = TREE_OPERAND (expr, 0);
+ expr = build_unary_op (INDIRECT_REF, NULL_TREE,
+ build_component_ref (expr, NULL_TREE,
+ TYPE_FIELDS
+ (TREE_TYPE (expr)),
+ false));
+ TREE_THIS_NOTRAP (expr) = no_trap;
+ etype = TREE_TYPE (expr);
+ ecode = TREE_CODE (etype);
+ break;
+ }
case VIEW_CONVERT_EXPR:
{
@@ -3992,8 +3996,9 @@ convert (tree type, tree expr)
&& !TYPE_IS_FAT_POINTER_P (etype))
return convert (type, op0);
}
+
+ break;
}
- break;
default:
break;