diff options
author | Thomas Koenig <tkoenig@gcc.gnu.org> | 2010-09-07 22:50:54 +0000 |
---|---|---|
committer | Thomas Koenig <tkoenig@gcc.gnu.org> | 2010-09-07 22:50:54 +0000 |
commit | c56c085331e710253ae53abd17fa152248a17e08 (patch) | |
tree | 37f836ea67602ac1a676daee90cd7f0f46e46547 /gcc | |
parent | ccef29e83119a42c412fbc9608a1f11ee165db5f (diff) | |
download | gcc-c56c085331e710253ae53abd17fa152248a17e08.zip gcc-c56c085331e710253ae53abd17fa152248a17e08.tar.gz gcc-c56c085331e710253ae53abd17fa152248a17e08.tar.bz2 |
re PR fortran/45576 (ICE on character stuff)
2010-09-07 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/45576
* dependency.c (gfc_deb_compare_expr): Take missing optional
arguments into account.
2010-09-07 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/45576
* gfortran.dg/char_length_18.f90: New test.
From-SVN: r163978
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/fortran/dependency.c | 8 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/char_length_18.f90 | 9 |
4 files changed, 27 insertions, 1 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 7a9f678..2215eb8 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2010-09-07 Thomas Koenig <tkoenig@gcc.gnu.org> + + PR fortran/45576 + * dependency.c (gfc_deb_compare_expr): Take missing optional + arguments into account. + 2010-09-08 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> * trans.h (gfor_fndecl_clz128, gfor_fndecl_ctz128): Remove. diff --git a/gcc/fortran/dependency.c b/gcc/fortran/dependency.c index 960155e..ab14e33 100644 --- a/gcc/fortran/dependency.c +++ b/gcc/fortran/dependency.c @@ -368,8 +368,14 @@ gfc_dep_compare_expr (gfc_expr *e1, gfc_expr *e2) /* Compare the argument lists for equality. */ while (args1 && args2) { - if (gfc_dep_compare_expr (args1->expr, args2->expr) != 0) + /* Bitwise xor, since C has no non-bitwise xor operator. */ + if ((args1->expr == NULL) ^ (args2->expr == NULL)) return -2; + + if (args1->expr != NULL && args2->expr != NULL + && gfc_dep_compare_expr (args1->expr, args2->expr) != 0) + return -2; + args1 = args1->next; args2 = args2->next; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 0c29f20..b628e22 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-09-07 Thomas Koenig <tkoenig@gcc.gnu.org> + + PR fortran/45576 + * gfortran.dg/char_length_18.f90: New test. + 2010-09-07 Jack Howarth <howarth@bromo.med.uc.edu> PR target/36502 diff --git a/gcc/testsuite/gfortran.dg/char_length_18.f90 b/gcc/testsuite/gfortran.dg/char_length_18.f90 new file mode 100644 index 0000000..9fd31c8 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/char_length_18.f90 @@ -0,0 +1,9 @@ +! { dg-do compile } +! PR 45576 - no ICE for missing optional argument +! Test case supplied by Joost VandeVondele +SUBROUTINE get_r_val() + INTEGER, PARAMETER :: default_string_length=128 + CHARACTER(len=default_string_length) :: c_val + LOGICAL :: check + check = c_val(LEN_TRIM(c_val):LEN_TRIM(c_val))=="]" +END SUBROUTINE get_r_val |