aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/dependency.c8
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/char_length_18.f909
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