aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorTobias Schlüter <tobias.schlueter@physik.uni-muenchen.de>2004-06-14 20:50:44 +0200
committerTobias Schlüter <tobi@gcc.gnu.org>2004-06-14 20:50:44 +0200
commit7031baf4de70d1f280df2c3837861ca042ae79b8 (patch)
tree27a33ac55c433ba5387fb8cf06aaf3598f5881a7 /gcc
parentf1c3e0a60cd1fd42147cb79c8ee19d6a0f224303 (diff)
downloadgcc-7031baf4de70d1f280df2c3837861ca042ae79b8.zip
gcc-7031baf4de70d1f280df2c3837861ca042ae79b8.tar.gz
gcc-7031baf4de70d1f280df2c3837861ca042ae79b8.tar.bz2
re PR fortran/15211 (ICE with LEN intrinsic)
fortran/ PR fortran/15211 * trans-intrinsic.c (gfc_conv_intrinsic_len): Deal with arrays of strings. testsuite/ PR fortran/15211 * gfortran.fortran-torture/execute/intrinsic_len.f90: Also test LEN of a character array. From-SVN: r83126
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/trans-intrinsic.c6
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/gfortran.fortran-torture/execute/intrinsic_len.f909
4 files changed, 26 insertions, 1 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 47b7e24..04e5290 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,9 @@
+2004-05-31 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
+
+ PR fortran/15211
+ * trans-intrinsic.c (gfc_conv_intrinsic_len): Deal with arrays
+ of strings.
+
2004-06-14 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
PR fortran/15510
diff --git a/gcc/fortran/trans-intrinsic.c b/gcc/fortran/trans-intrinsic.c
index e2c1b7e..67b6cc4 100644
--- a/gcc/fortran/trans-intrinsic.c
+++ b/gcc/fortran/trans-intrinsic.c
@@ -1874,8 +1874,12 @@ gfc_conv_intrinsic_len (gfc_se * se, gfc_expr * expr)
break;
default:
- if (arg->expr_type == EXPR_VARIABLE && arg->ref == NULL)
+ if (arg->expr_type == EXPR_VARIABLE && arg->ref == NULL
+ || (arg->ref->next == NULL && arg->ref->type == REF_ARRAY))
{
+ /* This doesn't catch all cases.
+ See http://gcc.gnu.org/ml/fortran/2004-06/msg00165.html
+ and the surrounding thread. */
sym = arg->symtree->n.sym;
decl = gfc_get_symbol_decl (sym);
if (decl == current_function_decl && sym->attr.function
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 0bff3ab..36cb478 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2004-06-14 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
+
+ PR fortran/15211
+ * gfortran.fortran-torture/execute/intrinsic_len.f90: Also test
+ LEN of a character array.
+
2004-06-14 Mark Mitchell <mark@codesourcery.com>
PR c++/15096
diff --git a/gcc/testsuite/gfortran.fortran-torture/execute/intrinsic_len.f90 b/gcc/testsuite/gfortran.fortran-torture/execute/intrinsic_len.f90
index 6721738..9db8d40 100644
--- a/gcc/testsuite/gfortran.fortran-torture/execute/intrinsic_len.f90
+++ b/gcc/testsuite/gfortran.fortran-torture/execute/intrinsic_len.f90
@@ -12,6 +12,7 @@ program test
if ((a .ne. "01234567") .or. (n .ne. 8)) call abort
if (len(Tom%name) .ne. 10) call abort
+ call array_test()
end
function w(i)
@@ -20,3 +21,11 @@ function w(i)
w = "01234567"
i = len(w)
end
+
+! This is the testcase from PR 15211 converted to a subroutine
+subroutine array_test
+ implicit none
+ character(len=10) a(4)
+ if (len(a) .NE. 10) call abort()
+end subroutine array_test
+