Commit 7d76d73a by Tobias Schlüter Committed by Tobias Schlüter

expr.c (gfc_check_pointer_assign): Verify that rank of the LHS and RHS match.

* expr.c (gfc_check_pointer_assign): Verify that rank of the LHS
and RHS match. Return early if the RHS is NULL().

From-SVN: r84458
parent 290e757a
2004-07-10 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de> 2004-07-10 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
* expr.c (gfc_check_pointer_assign): Verify that rank of the LHS
and RHS match. Return early if the RHS is NULL().
2004-07-10 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
* trans-common.c: Fix whitespace issues, make variable names * trans-common.c: Fix whitespace issues, make variable names
more readable. more readable.
(create_common): Additionally, make loop logic more obvious. (create_common): Additionally, make loop logic more obvious.
......
...@@ -1807,39 +1807,42 @@ gfc_check_pointer_assign (gfc_expr * lvalue, gfc_expr * rvalue) ...@@ -1807,39 +1807,42 @@ gfc_check_pointer_assign (gfc_expr * lvalue, gfc_expr * rvalue)
/* If rvalue is a NULL() or NULLIFY, we're done. Otherwise the type, /* If rvalue is a NULL() or NULLIFY, we're done. Otherwise the type,
kind, etc for lvalue and rvalue must match, and rvalue must be a kind, etc for lvalue and rvalue must match, and rvalue must be a
pure variable if we're in a pure function. */ pure variable if we're in a pure function. */
if (rvalue->expr_type != EXPR_NULL) if (rvalue->expr_type == EXPR_NULL)
return SUCCESS;
if (!gfc_compare_types (&lvalue->ts, &rvalue->ts))
{ {
gfc_error ("Different types in pointer assignment at %L",
&lvalue->where);
return FAILURE;
}
if (!gfc_compare_types (&lvalue->ts, &rvalue->ts)) if (lvalue->ts.kind != rvalue->ts.kind)
{ {
gfc_error ("Different types in pointer assignment at %L", gfc_error ("Different kind type parameters in pointer "
&lvalue->where); "assignment at %L", &lvalue->where);
return FAILURE; return FAILURE;
} }
if (lvalue->ts.kind != rvalue->ts.kind) attr = gfc_expr_attr (rvalue);
{ if (!attr.target && !attr.pointer)
gfc_error {
("Different kind type parameters in pointer assignment at %L", gfc_error ("Pointer assignment target is neither TARGET "
&lvalue->where); "nor POINTER at %L", &rvalue->where);
return FAILURE; return FAILURE;
} }
attr = gfc_expr_attr (rvalue); if (is_pure && gfc_impure_variable (rvalue->symtree->n.sym))
if (!attr.target && !attr.pointer) {
{ gfc_error ("Bad target in pointer assignment in PURE "
gfc_error "procedure at %L", &rvalue->where);
("Pointer assignment target is neither TARGET nor POINTER at " }
"%L", &rvalue->where);
return FAILURE;
}
if (is_pure && gfc_impure_variable (rvalue->symtree->n.sym)) if (lvalue->rank != rvalue->rank)
{ {
gfc_error gfc_error ("Unequal ranks %d and %d in pointer assignment at %L",
("Bad target in pointer assignment in PURE procedure at %L", lvalue->rank, rvalue->rank, &rvalue->where);
&rvalue->where); return FAILURE;
}
} }
return SUCCESS; return SUCCESS;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment