PR fortran/38672
* trans-types.c (gfc_get_derived_type): Check for the
presence of derived->ns->proc_name before
accessing derived->ns->proc_name->attr.flavor .
* resolve.c (resolve_symbol): Likewise.
2009-01-05 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/38672
* gfortran.dg/host_assoc_blockdata_1.f90: New test.
* gfortran.dg/host_assoc_blockdata_2.f90: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@143074
138bc75d-0d04-0410-961f-
82ee72b054a4
+2009-01-05 Thomas Koenig <tkoenig@gcc.gnu.org>
+
+ PR fortran/38672
+ * trans-types.c (gfc_get_derived_type): Check for the
+ presence of derived->ns->proc_name before
+ accessing derived->ns->proc_name->attr.flavor .
+ * resolve.c (resolve_symbol): Likewise.
+
2009-01-05 Paul Thomas <pault@gcc.gnu.org>
PR fortran/38665
module function and is not PRIVATE. */
if (sym->ts.type == BT_DERIVED
&& sym->ts.derived->attr.use_assoc
+ && sym->ns->proc_name
&& sym->ns->proc_name->attr.flavor == FL_MODULE)
{
gfc_symbol *ds;
gfc_finish_type (typenode);
gfc_set_decl_location (TYPE_STUB_DECL (typenode), &derived->declared_at);
- if (derived->module && derived->ns->proc_name->attr.flavor == FL_MODULE)
+ if (derived->module && derived->ns->proc_name
+ && derived->ns->proc_name->attr.flavor == FL_MODULE)
{
if (derived->ns->proc_name->backend_decl
&& TREE_CODE (derived->ns->proc_name->backend_decl)
+2009-01-05 Thomas Koenig <tkoenig@gcc.gnu.org>
+
+ PR fortran/38672
+ * gfortran.dg/host_assoc_blockdata_1.f90: New test.
+ * gfortran.dg/host_assoc_blockdata_2.f90: New test.
+
2009-01-05 Uros Bizjak <ubizjak@gmail.com>
* gcc.dg/compat/struct-layout-1_generate.c (dg-options): Add -mieee
--- /dev/null
+! { dg-do compile }
+! PR 38672 - this used to ICE.
+MODULE globals
+ TYPE :: type1
+ integer :: x
+ END TYPE type1
+ TYPE (type1) :: pdm_bps
+END module globals
+BLOCK DATA
+ use globals
+END BLOCK DATA
--- /dev/null
+! { dg-do compile }
+MODULE globals
+ TYPE :: type1
+ sequence
+ integer :: x
+ END TYPE type1
+ TYPE (type1) :: pdm_bps
+ common /co/ pdm_bps
+END module globals
+BLOCK DATA
+ use globals
+END BLOCK DATA
+
+program main
+ use globals
+ common /co/ pdm_bps ! { dg-error "already in a COMMON block" }
+end program main