------- Comment #1 from pault at gcc dot gnu dot org  2008-06-07 16:17 -------
(In reply to comment #0)

This comes about, indirectly, because of simplification.  Change the the index
of the first item in the data list for 'c' to 2, for example.  This can be
tracked back to resolve.c (check_data_variable), where the call to
gfc_check_assign is gfc_check_assign (var->expr, values.vnode->expr, 0); The
rvalue, values.vnode->expr, is used for the locus in the error.  Since it has
been simplfied here, the error results.  Using the lvalue expression at least
hits the data statement.

I notice that the only customer for gfc_check_assign with 'conform' == 0 is
check_data_variable.  It might be better to take account of this in the call.

I'll do it.

Paul


-- 

pault at gcc dot gnu dot org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
         AssignedTo|unassigned at gcc dot gnu   |pault at gcc dot gnu dot org
                   |dot org                     |
             Status|NEW                         |ASSIGNED
   Last reconfirmed|2008-05-29 21:05:37         |2008-06-07 16:17:12
               date|                            |


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=36371

Reply via email to