2012-08-20 Tobias Burnus <burnus@net-b.de>
authorburnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 20 Aug 2012 19:49:46 +0000 (19:49 +0000)
committerburnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 20 Aug 2012 19:49:46 +0000 (19:49 +0000)
        PR fortran/54301
        * expr.c (gfc_check_pointer_assign): Warn when a pointer,
        which is a function result, might outlive its target.

2012-08-20  Tobias Burnus  <burnus@net-b.de>

        PR fortran/54301
        * gfortran.dg/warn_target_lifetime_2.f90: New.

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

gcc/fortran/ChangeLog
gcc/fortran/expr.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/warn_target_lifetime_2.f90 [new file with mode: 0644]

index de255ea..4992ecf 100644 (file)
@@ -1,6 +1,12 @@
 2012-08-20  Tobias Burnus  <burnus@net-b.de>
 
        PR fortran/54301
+       * expr.c (gfc_check_pointer_assign): Warn when a pointer,
+       which is a function result, might outlive its target.
+
+2012-08-20  Tobias Burnus  <burnus@net-b.de>
+
+       PR fortran/54301
        * expr.c (gfc_check_pointer_assign): Warn when the pointer
        might outlive its target.
        * gfortran.h (struct gfc_option_t): Add warn_target_lifetime.
index 6f1283d..bc1f5e3 100644 (file)
@@ -3673,6 +3673,7 @@ gfc_check_pointer_assign (gfc_expr *lvalue, gfc_expr *rvalue)
 
       warn = lvalue->symtree->n.sym->attr.dummy
             || lvalue->symtree->n.sym->attr.result
+            || lvalue->symtree->n.sym->attr.function
             || lvalue->symtree->n.sym->attr.host_assoc
             || lvalue->symtree->n.sym->attr.use_assoc
             || lvalue->symtree->n.sym->attr.in_common;
index 686e041..0b1bf5a 100644 (file)
@@ -1,3 +1,8 @@
+2012-08-20  Tobias Burnus  <burnus@net-b.de>
+
+       PR fortran/54301
+       * gfortran.dg/warn_target_lifetime_2.f90: New.
+
 2012-08-20  Paolo Carlini  <paolo.carlini@oracle.com>
 
        PR c++/10416
diff --git a/gcc/testsuite/gfortran.dg/warn_target_lifetime_2.f90 b/gcc/testsuite/gfortran.dg/warn_target_lifetime_2.f90
new file mode 100644 (file)
index 0000000..bfcb7ac
--- /dev/null
@@ -0,0 +1,10 @@
+! { dg-do compile }
+! { dg-options "-Wtarget-lifetime" }
+!
+! PR fortran/54301
+!
+function f()
+  integer, pointer :: f
+  integer, target :: t
+  f => t ! { dg-warning "Pointer at .1. in pointer assignment might outlive the pointer target" }
+end