From 2be7c5d9c9efdeda3f49999d50342f625edf9d53 Mon Sep 17 00:00:00 2001 From: tobi Date: Wed, 23 Feb 2005 20:56:58 +0000 Subject: [PATCH] fortran/ * gfortran.h (symbol_attribute): New 'untyped' field, fix comment formatting. * symbol.c (gfc_set_default_type): Issue error only once, by setting and checking 'untyped' attribute. testsuite/ * gfortran.dg/deftype_1.f90: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@95469 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/fortran/ChangeLog | 5 +++++ gcc/fortran/gfortran.h | 3 ++- gcc/fortran/symbol.c | 9 ++++++--- gcc/testsuite/ChangeLog | 2 ++ gcc/testsuite/gfortran.dg/deftype_1.f90 | 6 ++++++ 5 files changed, 21 insertions(+), 4 deletions(-) create mode 100644 gcc/testsuite/gfortran.dg/deftype_1.f90 diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index d099843cd12..b28e7070f63 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -11,6 +11,11 @@ (gfc_symbol_init_2): Pass second argument to gfc_get_namespace. * trans-common.c (build_common_decl): Likewise. + * gfortran.h (symbol_attribute): New 'untyped' field, fix comment + formatting. + * symbol.c (gfc_set_default_type): Issue error only once, by setting + and checking 'untyped' attribute. + 2005-02-23 Kazu Hirata * intrinsic.h, st.c: Update copyright. diff --git a/gcc/fortran/gfortran.h b/gcc/fortran/gfortran.h index 0778d65c705..f96cff10dde 100644 --- a/gcc/fortran/gfortran.h +++ b/gcc/fortran/gfortran.h @@ -408,7 +408,8 @@ typedef struct unsigned in_namelist:1, in_common:1; unsigned function:1, subroutine:1, generic:1; - unsigned implicit_type:1; /* Type defined via implicit rules */ + unsigned implicit_type:1; /* Type defined via implicit rules. */ + unsigned untyped:1; /* No implicit type could be found. */ /* Function/subroutine attributes */ unsigned sequence:1, elemental:1, pure:1, recursive:1; diff --git a/gcc/fortran/symbol.c b/gcc/fortran/symbol.c index efe121111e0..77d3f1a3a2d 100644 --- a/gcc/fortran/symbol.c +++ b/gcc/fortran/symbol.c @@ -213,9 +213,12 @@ gfc_set_default_type (gfc_symbol * sym, int error_flag, gfc_namespace * ns) if (ts->type == BT_UNKNOWN) { - if (error_flag) - gfc_error ("Symbol '%s' at %L has no IMPLICIT type", sym->name, - &sym->declared_at); + if (error_flag && !sym->attr.untyped) + { + gfc_error ("Symbol '%s' at %L has no IMPLICIT type", + sym->name, &sym->declared_at); + sym->attr.untyped = 1; /* Ensure we only give an error once. */ + } return FAILURE; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index e06a9790093..199acc114b7 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -2,6 +2,8 @@ * gfortran.dg/implicit_3.f90: New test. + * gfortran.dg/deftype_1.f90: New test. + 2005-02-23 Alexandre Oliva * g++.dg/lookup/anon2.C: Don't let access checks make it look like diff --git a/gcc/testsuite/gfortran.dg/deftype_1.f90 b/gcc/testsuite/gfortran.dg/deftype_1.f90 new file mode 100644 index 00000000000..e0476d02e58 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/deftype_1.f90 @@ -0,0 +1,6 @@ +! { dg-do compile } +! Checks for excess errors. +implicit none +dimension i(10) ! { dg-error "has no IMPLICIT type" } +i = 2 +end -- 2.11.0