OSDN Git Service

2010-08-19 Jerry DeLisle <jvdelisle@gcc.gnu.org>
authorjvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 19 Aug 2010 02:35:45 +0000 (02:35 +0000)
committerjvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 19 Aug 2010 02:35:45 +0000 (02:35 +0000)
PR fortran/41859
* resolve.c (resolve_transfer): Traverse operands and set expression
to be checked to a non EXPR_OP type.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@163363 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/fortran/ChangeLog
gcc/fortran/resolve.c

index cfc71c1..24e2084 100644 (file)
@@ -1,3 +1,9 @@
+2010-08-19  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
+
+       PR fortran/41859
+       * resolve.c (resolve_transfer): Traverse operands and set expression
+       to be checked to a non EXPR_OP type.
+
 2010-08-19  Janus Weil  <janus@gcc.gnu.org>
 
        PR fortran/45290
index f770f60..63d33ce 100644 (file)
@@ -7747,7 +7747,12 @@ resolve_transfer (gfc_code *code)
 
   exp = code->expr1;
 
-  if (exp->expr_type != EXPR_VARIABLE && exp->expr_type != EXPR_FUNCTION)
+  while (exp != NULL && exp->expr_type == EXPR_OP
+        && exp->value.op.op == INTRINSIC_PARENTHESES)
+    exp = exp->value.op.op1;
+
+  if (exp == NULL || (exp->expr_type != EXPR_VARIABLE
+                     && exp->expr_type != EXPR_FUNCTION))
     return;
 
   sym = exp->symtree->n.sym;