diff options
| author | tobi <tobi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-06-21 17:23:52 +0000 |
|---|---|---|
| committer | tobi <tobi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-06-21 17:23:52 +0000 |
| commit | ef9d8353231f15eb5b9c7086207f32382168f355 (patch) | |
| tree | b8e9dc37ac0f6a4b0c5731888cce991d658387c9 /gcc/fortran/resolve.c | |
| parent | ac68a56d7362d45aeff09cfb6df6d81baf1ae9c5 (diff) | |
| download | ppe42-gcc-ef9d8353231f15eb5b9c7086207f32382168f355.tar.gz ppe42-gcc-ef9d8353231f15eb5b9c7086207f32382168f355.zip | |
* resolve.c (resolve_symbol): Add comment in function body.
(check_data_variable): Change type of mark to ar_type, adapt code
accordingly.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@83443 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/fortran/resolve.c')
| -rw-r--r-- | gcc/fortran/resolve.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c index b19721f1432..77ac3d4bb8d 100644 --- a/gcc/fortran/resolve.c +++ b/gcc/fortran/resolve.c @@ -3724,6 +3724,9 @@ resolve_symbol (gfc_symbol * sym) } } + /* Assumed size arrays and assumed shape arrays must be dummy + arguments. */ + if (sym->as != NULL && (sym->as->type == AS_ASSUMED_SIZE || sym->as->type == AS_ASSUMED_SHAPE) @@ -3945,7 +3948,7 @@ check_data_variable (gfc_data_variable * var, locus * where) mpz_t size; mpz_t offset; try t; - int mark = 0; + ar_type mark = AR_UNKNOWN; int i; mpz_t section_index[GFC_MAX_DIMENSIONS]; gfc_ref *ref; @@ -3982,14 +3985,14 @@ check_data_variable (gfc_data_variable * var, locus * where) switch (ref->u.ar.type) { case AR_FULL: - mark = 1; + mark = AR_FULL; break; case AR_SECTION: ar = &ref->u.ar; /* Get the start position of array section. */ gfc_get_section_index (ar, section_index, &offset); - mark = 2; + mark = AR_SECTION; break; default: @@ -4024,17 +4027,17 @@ check_data_variable (gfc_data_variable * var, locus * where) /* Assign initial value to symbol. */ gfc_assign_data_value (var->expr, values.vnode->expr, offset); - if (mark == 1) + if (mark == AR_FULL) mpz_add_ui (offset, offset, 1); /* Modify the array section indexes and recalculate the offset for next element. */ - else if (mark == 2) + else if (mark == AR_SECTION) gfc_advance_section (section_index, ar, &offset); mpz_sub_ui (size, size, 1); } - if (mark == 2) + if (mark == AR_SECTION) { for (i = 0; i < ar->dimen; i++) mpz_clear (section_index[i]); |

