re PR fortran/79447 ([F08] gfortran rejects valid & accepts invalid internal subprogram in a submodule)
2017-02-19 Paul Thomas <pault@gcc.gnu.org> PR fortran/79447 * decl.c (gfc_set_constant_character_len): Whitespace. (gfc_match_end): Catch case where a procedure is contained in a module procedure and ensure that 'end procedure' is the correct termination. 2017-02-19 Paul Thomas <pault@gcc.gnu.org> PR fortran/79447 * gfortran.dg/submodule_24.f08 : New test. From-SVN: r245582
This commit is contained in:
parent
4ca4d1e95e
commit
63af1586ca
|
@ -1,4 +1,12 @@
|
|||
017-02-19 Paul Thomas <pault@gcc.gnu.org>
|
||||
2017-02-19 Paul Thomas <pault@gcc.gnu.org>
|
||||
|
||||
PR fortran/79447
|
||||
* decl.c (gfc_set_constant_character_len): Whitespace.
|
||||
(gfc_match_end): Catch case where a procedure is contained in
|
||||
a module procedure and ensure that 'end procedure' is the
|
||||
correct termination.
|
||||
|
||||
2017-02-19 Paul Thomas <pault@gcc.gnu.org>
|
||||
|
||||
PR fortran/79402
|
||||
* resolve.c (fixup_unique_dummy): New function.
|
||||
|
|
|
@ -1499,7 +1499,7 @@ gfc_set_constant_character_len (int len, gfc_expr *expr, int check_len)
|
|||
|
||||
if (expr->ts.type != BT_CHARACTER)
|
||||
return;
|
||||
|
||||
|
||||
if (expr->expr_type != EXPR_CONSTANT)
|
||||
{
|
||||
gfc_error_now ("CHARACTER length must be a constant at %L", &expr->where);
|
||||
|
@ -6756,7 +6756,7 @@ gfc_match_end (gfc_statement *st)
|
|||
match m;
|
||||
gfc_namespace *parent_ns, *ns, *prev_ns;
|
||||
gfc_namespace **nsp;
|
||||
bool abreviated_modproc_decl;
|
||||
bool abreviated_modproc_decl = false;
|
||||
bool got_matching_end = false;
|
||||
|
||||
old_loc = gfc_current_locus;
|
||||
|
@ -6780,15 +6780,17 @@ gfc_match_end (gfc_statement *st)
|
|||
state = gfc_state_stack->previous->state;
|
||||
block_name = gfc_state_stack->previous->sym == NULL
|
||||
? NULL : gfc_state_stack->previous->sym->name;
|
||||
abreviated_modproc_decl = gfc_state_stack->previous->sym
|
||||
&& gfc_state_stack->previous->sym->abr_modproc_decl;
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
abreviated_modproc_decl
|
||||
= gfc_current_block ()
|
||||
&& gfc_current_block ()->abr_modproc_decl;
|
||||
if (!abreviated_modproc_decl)
|
||||
abreviated_modproc_decl = gfc_current_block ()
|
||||
&& gfc_current_block ()->abr_modproc_decl;
|
||||
|
||||
switch (state)
|
||||
{
|
||||
|
|
|
@ -1,3 +1,8 @@
|
|||
2017-02-19 Paul Thomas <pault@gcc.gnu.org>
|
||||
|
||||
PR fortran/79447
|
||||
* gfortran.dg/submodule_24.f08 : New test.
|
||||
|
||||
2017-02-19 Andre Vehreschild <vehre@gcc.gnu.org>
|
||||
|
||||
PR fortran/79229
|
||||
|
|
|
@ -0,0 +1,23 @@
|
|||
! { dg-do compile }
|
||||
! Test the fix for PR79447, in which the END PROCEDURE statement
|
||||
! for MODULE PROCEDURE foo was not accepted.
|
||||
!
|
||||
! Contributed by Damian Rouson <damian@sourceryinstitute.org>
|
||||
!
|
||||
module foo_interface
|
||||
implicit none
|
||||
interface
|
||||
module subroutine foo()
|
||||
end subroutine
|
||||
end interface
|
||||
end module foo_interface
|
||||
|
||||
submodule(foo_interface) foo_implementation
|
||||
contains
|
||||
module procedure foo
|
||||
contains
|
||||
module subroutine bar()
|
||||
end subroutine
|
||||
end procedure
|
||||
!end subroutine ! gfortran accepted this invalid workaround
|
||||
end submodule
|
Loading…
Reference in New Issue