aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2005-07-08 12:06:57 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2005-07-08 12:06:57 +0200
commit0921bc44f78c9c3326d608039d099ea672541e39 (patch)
treeaf8d6fe8b5761d621a6b65c255725b238dfaa92c /gcc
parent29f9d52d10a453b3f2c2b6057827ae18b8ae0e0f (diff)
downloadgcc-0921bc44f78c9c3326d608039d099ea672541e39.zip
gcc-0921bc44f78c9c3326d608039d099ea672541e39.tar.gz
gcc-0921bc44f78c9c3326d608039d099ea672541e39.tar.bz2
primary.c (gfc_match_rvalue): Handle ENTRY the same way as FUNCTION.
* primary.c (gfc_match_rvalue): Handle ENTRY the same way as FUNCTION. * gfortran.fortran-torture/execute/entry_10.f90: New test. From-SVN: r101758
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog5
-rw-r--r--gcc/fortran/primary.c21
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gfortran.fortran-torture/execute/entry_10.f9013
4 files changed, 39 insertions, 4 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 5de8b3c..b09cb7e 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,8 @@
+2005-07-08 Jakub Jelinek <jakub@redhat.com>
+
+ * primary.c (gfc_match_rvalue): Handle ENTRY the same way
+ as FUNCTION.
+
2005-07-07 Jakub Jelinek <jakub@redhat.com>
* scanner.c (load_line): Add pbuflen argument, don't make
diff --git a/gcc/fortran/primary.c b/gcc/fortran/primary.c
index f6807d5..36e5eb9 100644
--- a/gcc/fortran/primary.c
+++ b/gcc/fortran/primary.c
@@ -1846,11 +1846,24 @@ gfc_match_rvalue (gfc_expr ** result)
gfc_set_sym_referenced (sym);
- if (sym->attr.function && sym->result == sym
- && (gfc_current_ns->proc_name == sym
+ if (sym->attr.function && sym->result == sym)
+ {
+ if (gfc_current_ns->proc_name == sym
|| (gfc_current_ns->parent != NULL
- && gfc_current_ns->parent->proc_name == sym)))
- goto variable;
+ && gfc_current_ns->parent->proc_name == sym))
+ goto variable;
+
+ if (sym->attr.entry
+ && (sym->ns == gfc_current_ns
+ || sym->ns == gfc_current_ns->parent))
+ {
+ gfc_entry_list *el = NULL;
+
+ for (el = sym->ns->entries; el; el = el->next)
+ if (sym == el->sym)
+ goto variable;
+ }
+ }
if (sym->attr.function || sym->attr.external || sym->attr.intrinsic)
goto function0;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 67c70d4..2a068542 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2005-07-08 Jakub Jelinek <jakub@redhat.com>
+
+ * gfortran.fortran-torture/execute/entry_10.f90: New test.
+
2005-07-07 Geoffrey Keating <geoffk@apple.com>
* gcc.dg/darwin-version-1.c: New.
diff --git a/gcc/testsuite/gfortran.fortran-torture/execute/entry_10.f90 b/gcc/testsuite/gfortran.fortran-torture/execute/entry_10.f90
new file mode 100644
index 0000000..0c21d76
--- /dev/null
+++ b/gcc/testsuite/gfortran.fortran-torture/execute/entry_10.f90
@@ -0,0 +1,13 @@
+ function foo ()
+ foo = 4
+ foo = foo / 2
+ return
+ entry bar ()
+ bar = 9
+ bar = bar / 3
+ end
+
+ program entrytest
+ if (foo () .ne. 2) call abort ()
+ if (bar () .ne. 3) call abort ()
+ end