aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJerry DeLisle <jvdelisle@gcc.gnu.org>2007-07-03 22:14:55 +0000
committerJerry DeLisle <jvdelisle@gcc.gnu.org>2007-07-03 22:14:55 +0000
commita24668a34fb292cda15da0b709e21d17c8b40e35 (patch)
tree4352b8947dcf2586ceea4b93620531d88a0240f0 /gcc
parentf9faf95474a8a0009af1f6fd19097b1e96d8eefc (diff)
downloadgcc-a24668a34fb292cda15da0b709e21d17c8b40e35.zip
gcc-a24668a34fb292cda15da0b709e21d17c8b40e35.tar.gz
gcc-a24668a34fb292cda15da0b709e21d17c8b40e35.tar.bz2
re PR fortran/32432 (SEGV/endless loop after: "ERROR: ... already is initialized")
2007-07-03 Jerry DeLisle <jvdelisle@gcc.gnu.org> PR fortran/32432 * gfortran.h: Change type of gfc_assign_data_value from void to try. * data.c (gfc_assign_data_value): Return FAILURE if error found. * resolve.c (check_data_variable): If gfc_assign_data_value returns failure, break out of loop and return failure. From-SVN: r126282
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog8
-rw-r--r--gcc/fortran/data.c7
-rw-r--r--gcc/fortran/resolve.c4
3 files changed, 15 insertions, 4 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 51fcdf9..2fe400c 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,11 @@
+2007-07-03 Jerry DeLisle <jvdelisle@gcc.gnu.org>
+
+ PR fortran/32432
+ * gfortran.h: Change type of gfc_assign_data_value from void to try.
+ * data.c (gfc_assign_data_value): Return FAILURE if error found.
+ * resolve.c (check_data_variable): If gfc_assign_data_value returns
+ failure, break out of loop and return failure.
+
2007-07-03 Christopher D. Rickett <crickett@lanl.gov>
PR fortran/32579
diff --git a/gcc/fortran/data.c b/gcc/fortran/data.c
index 35213a8..3c86bc8 100644
--- a/gcc/fortran/data.c
+++ b/gcc/fortran/data.c
@@ -245,7 +245,7 @@ create_character_intializer (gfc_expr *init, gfc_typespec *ts,
LVALUE already has an initialization, we extend this, otherwise we
create a new one. */
-void
+try
gfc_assign_data_value (gfc_expr *lvalue, gfc_expr *rvalue, mpz_t index)
{
gfc_ref *ref;
@@ -293,8 +293,7 @@ gfc_assign_data_value (gfc_expr *lvalue, gfc_expr *rvalue, mpz_t index)
gfc_error ("'%s' at %L already is initialized at %L",
lvalue->symtree->n.sym->name, &lvalue->where,
&init->where);
- gfc_free_expr (init);
- init = NULL;
+ return FAILURE;
}
if (init == NULL)
@@ -423,6 +422,8 @@ gfc_assign_data_value (gfc_expr *lvalue, gfc_expr *rvalue, mpz_t index)
symbol->value = expr;
else
last_con->expr = expr;
+
+ return SUCCESS;
}
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
index 615d85e..158abe0 100644
--- a/gcc/fortran/resolve.c
+++ b/gcc/fortran/resolve.c
@@ -7472,7 +7472,9 @@ check_data_variable (gfc_data_variable *var, locus *where)
values.left -= 1;
mpz_sub_ui (size, size, 1);
- gfc_assign_data_value (var->expr, values.vnode->expr, offset);
+ t = gfc_assign_data_value (var->expr, values.vnode->expr, offset);
+ if (t == FAILURE)
+ break;
if (mark == AR_FULL)
mpz_add_ui (offset, offset, 1);