aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/array.cc
diff options
context:
space:
mode:
authorHarald Anlauf <anlauf@gmx.de>2022-12-17 22:04:32 +0100
committerHarald Anlauf <anlauf@gmx.de>2022-12-23 22:23:10 +0100
commit6a95f0e0a06d78d94138d4c3dd64d41591197281 (patch)
tree223e54217b2a9224018047fada3b7b188382ace2 /gcc/fortran/array.cc
parentcf59c8983ef6590f0d69014f8dc8778b5b7691c6 (diff)
downloadgcc-6a95f0e0a06d78d94138d4c3dd64d41591197281.zip
gcc-6a95f0e0a06d78d94138d4c3dd64d41591197281.tar.gz
gcc-6a95f0e0a06d78d94138d4c3dd64d41591197281.tar.bz2
Fortran: incorrect array bounds when bound intrinsic used in decl [PR108131]
gcc/fortran/ChangeLog: PR fortran/108131 * array.cc (match_array_element_spec): Avoid too early simplification of matched array element specs that can lead to a misinterpretation when used as array bounds in array declarations. gcc/testsuite/ChangeLog: PR fortran/108131 * gfortran.dg/pr103505.f90: Adjust expected patterns. * gfortran.dg/pr108131.f90: New test.
Diffstat (limited to 'gcc/fortran/array.cc')
-rw-r--r--gcc/fortran/array.cc4
1 files changed, 0 insertions, 4 deletions
diff --git a/gcc/fortran/array.cc b/gcc/fortran/array.cc
index 10d9e0c..7457c03 100644
--- a/gcc/fortran/array.cc
+++ b/gcc/fortran/array.cc
@@ -512,8 +512,6 @@ match_array_element_spec (gfc_array_spec *as)
if (!gfc_expr_check_typed (*upper, gfc_current_ns, false))
return AS_UNKNOWN;
- gfc_try_simplify_expr (*upper, 0);
-
if (((*upper)->expr_type == EXPR_CONSTANT
&& (*upper)->ts.type != BT_INTEGER) ||
((*upper)->expr_type == EXPR_FUNCTION
@@ -546,8 +544,6 @@ match_array_element_spec (gfc_array_spec *as)
if (!gfc_expr_check_typed (*upper, gfc_current_ns, false))
return AS_UNKNOWN;
- gfc_try_simplify_expr (*upper, 0);
-
if (((*upper)->expr_type == EXPR_CONSTANT
&& (*upper)->ts.type != BT_INTEGER) ||
((*upper)->expr_type == EXPR_FUNCTION