diff options
author | Paul Thomas <pault@gcc.gnu.org> | 2021-01-21 10:00:00 +0000 |
---|---|---|
committer | Paul Thomas <pault@gcc.gnu.org> | 2021-01-21 10:00:49 +0000 |
commit | eaf883710c0039eca5caea5115e848adb4ab67bd (patch) | |
tree | fc7baa465ca84ce19178b9c6657ed0932ea636fb /gcc/fortran/expr.c | |
parent | f46a40112caa7e039d949beda94386ff4e436a35 (diff) | |
download | gcc-eaf883710c0039eca5caea5115e848adb4ab67bd.zip gcc-eaf883710c0039eca5caea5115e848adb4ab67bd.tar.gz gcc-eaf883710c0039eca5caea5115e848adb4ab67bd.tar.bz2 |
Fortran: This patch fixes comments 23 and 24 of PR96320.
2021-01-21 Paul Thomas <pault@gcc.gnu.org>
gcc/fortran
PR fortran/96320
* decl.c (gfc_match_modproc): It is not an error to find a
module procedure declaration within a contains block.
* expr.c (gfc_check_vardef_context): Pure procedure result is
assignable. Change 'own_scope' accordingly.
* resolve.c (resolve_typebound_procedure): A procedure that
has the module procedure attribute is almost certainly a
module procedure, whatever its interface.
gcc/testsuite/
PR fortran/96320
* gfortran.dg/module_procedure_5.f90 : New test.
* gfortran.dg/module_procedure_6.f90 : New test.
Diffstat (limited to 'gcc/fortran/expr.c')
-rw-r--r-- | gcc/fortran/expr.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/gcc/fortran/expr.c b/gcc/fortran/expr.c index 188e796..4f456fc 100644 --- a/gcc/fortran/expr.c +++ b/gcc/fortran/expr.c @@ -6243,6 +6243,9 @@ gfc_check_vardef_context (gfc_expr* e, bool pointer, bool alloc_obj, /* Variable not assignable from a PURE procedure but appears in variable definition context. */ + own_scope = own_scope + || (sym->attr.result && sym->ns->proc_name + && sym == sym->ns->proc_name->result); if (!pointer && !own_scope && gfc_pure (NULL) && gfc_impure_variable (sym)) { if (context) |