summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorpinskia <pinskia@138bc75d-0d04-0410-961f-82ee72b054a4>2006-01-09 20:42:26 +0000
committerpinskia <pinskia@138bc75d-0d04-0410-961f-82ee72b054a4>2006-01-09 20:42:26 +0000
commit46a7a3ea53fc6f23084ce8efdcf2279d859fdf7c (patch)
treea5d3f403cbfa0722378e9d7854026ac228c089ec /gcc
parent96f342ebc77d49969947a679b57a5c42b2885cb3 (diff)
downloadgcc-46a7a3ea53fc6f23084ce8efdcf2279d859fdf7c.tar.gz
2006-01-09 Andrew Pinski <pinskia@physics.uc.edu>
fortran/24936 * trans-stmt.c (gfc_trans_pointer_assign_need_temp): Use fold_convert to avoid type mismatch. 2006-01-09 Andrew Pinski <pinskia@physics.uc.edu> fortran/24936 * gfortran.dg/forall_3.f90: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@109508 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/trans-stmt.c3
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/forall_3.f9018
4 files changed, 31 insertions, 1 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 9c92709abcb..44f6a481aeb 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,5 +1,11 @@
2006-01-09 Andrew Pinski <pinskia@physics.uc.edu>
+ fortran/24936
+ * trans-stmt.c (gfc_trans_pointer_assign_need_temp): Use fold_convert
+ to avoid type mismatch.
+
+2006-01-09 Andrew Pinski <pinskia@physics.uc.edu>
+
PR fortran/21977
* trans-decl.c (gfc_generate_function_code): Move the NULLing of
current_fake_result_decl down to below generate_local_vars.
diff --git a/gcc/fortran/trans-stmt.c b/gcc/fortran/trans-stmt.c
index cf88918b586..df93db618b2 100644
--- a/gcc/fortran/trans-stmt.c
+++ b/gcc/fortran/trans-stmt.c
@@ -2122,7 +2122,8 @@ gfc_trans_pointer_assign_need_temp (gfc_expr * expr1, gfc_expr * expr2,
rse.want_pointer = 1;
gfc_conv_expr (&rse, expr2);
gfc_add_block_to_block (&body, &rse.pre);
- gfc_add_modify_expr (&body, lse.expr, rse.expr);
+ gfc_add_modify_expr (&body, lse.expr,
+ fold_convert (TREE_TYPE (lse.expr), rse.expr));
gfc_add_block_to_block (&body, &rse.post);
/* Increment count. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 92f7e0205e5..d2a59cbc9f8 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2006-01-09 Andrew Pinski <pinskia@physics.uc.edu>
+ fortran/24936
+ * gfortran.dg/forall_3.f90: New test.
+
+2006-01-09 Andrew Pinski <pinskia@physics.uc.edu>
+
PR fortran/21977
* gfortran.dg/nesting_2.f90: New test.
* gfortran.dg/nesting_3.f90: New test.
diff --git a/gcc/testsuite/gfortran.dg/forall_3.f90 b/gcc/testsuite/gfortran.dg/forall_3.f90
new file mode 100644
index 00000000000..bc5e58c8077
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/forall_3.f90
@@ -0,0 +1,18 @@
+! the problem here was that we had forgot to call
+! fold_convert in gfc_trans_pointer_assign_need_temp
+! so that we got a pointer to char instead of a
+! pointer to an array
+! we really don't need a temp here.
+! { dg-do compile }
+
+ program test_forall
+ type element
+ character(32), pointer :: name
+ end type element
+ type(element) :: charts(50)
+ character(32), target :: names(50)
+ forall(i=1:50)
+ charts(i)%name => names(i)
+ end forall
+ end
+