trans-types.c (gfc_sym_type, [...]): For sym->attr.result check sym->ns->proc_name...
authorJakub Jelinek <jakub@redhat.com>
Mon, 30 Mar 2009 14:38:08 +0000 (16:38 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Mon, 30 Mar 2009 14:38:08 +0000 (16:38 +0200)
* trans-types.c (gfc_sym_type, gfc_return_by_reference): For
sym->attr.result check sym->ns->proc_name->attr.is_bind_c.

* gfortran.dg/bind_c_usage_19.f90: New test.

From-SVN: r145294

gcc/fortran/ChangeLog
gcc/fortran/trans-types.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/bind_c_usage_19.f90 [new file with mode: 0644]

index d4a24ddc1f95ae375d0edaa8cd925aa96f56a51a..bcb3a6022f29f531b98798f62b3d9dde4d60ddbb 100644 (file)
@@ -1,3 +1,8 @@
+2009-03-30  Jakub Jelinek  <jakub@redhat.com>
+
+       * trans-types.c (gfc_sym_type, gfc_return_by_reference): For
+       sym->attr.result check sym->ns->proc_name->attr.is_bind_c.
+
 2009-03-30  Joseph Myers  <joseph@codesourcery.com>
 
        PR rtl-optimization/323
index de76486ab030adc9eb9028185ce554424271fac1..717859c5360f61f0683610a696309f4a7a5b0230 100644 (file)
@@ -1632,8 +1632,11 @@ gfc_sym_type (gfc_symbol * sym)
   if (sym->backend_decl && !sym->attr.function)
     return TREE_TYPE (sym->backend_decl);
 
-  if (sym->ts.type == BT_CHARACTER && sym->attr.is_bind_c
-      && (sym->attr.function || sym->attr.result))
+  if (sym->ts.type == BT_CHARACTER
+      && ((sym->attr.function && sym->attr.is_bind_c)
+         || (sym->attr.result
+             && sym->ns->proc_name
+             && sym->ns->proc_name->attr.is_bind_c)))
     type = gfc_character1_type_node;
   else
     type = gfc_typenode_for_spec (&sym->ts);
@@ -1962,7 +1965,11 @@ gfc_return_by_reference (gfc_symbol * sym)
   if (sym->attr.dimension)
     return 1;
 
-  if (sym->ts.type == BT_CHARACTER && !sym->attr.is_bind_c)
+  if (sym->ts.type == BT_CHARACTER
+      && !sym->attr.is_bind_c
+      && (!sym->attr.result
+         || !sym->ns->proc_name
+         || !sym->ns->proc_name->attr.is_bind_c))
     return 1;
 
   /* Possibly return complex numbers by reference for g77 compatibility.
index 37dcc216915beca0b0bd719b4fdd7cd0d814e243..d672724fbbdc7fab9d3ded16521d8e066105d331 100644 (file)
@@ -1,3 +1,7 @@
+2009-03-30  Jakub Jelinek  <jakub@redhat.com>
+
+       * gfortran.dg/bind_c_usage_19.f90: New test.
+
 2009-03-30  Joseph Myers  <joseph@codesourcery.com>
 
        PR rtl-optimization/323
diff --git a/gcc/testsuite/gfortran.dg/bind_c_usage_19.f90 b/gcc/testsuite/gfortran.dg/bind_c_usage_19.f90
new file mode 100644 (file)
index 0000000..30f9f5e
--- /dev/null
@@ -0,0 +1,31 @@
+! { dg-do compile }
+function return_char1(i) bind(c,name='return_char1')
+  use iso_c_binding
+  implicit none
+  integer(c_int) :: i
+  character(c_char) :: j
+  character(c_char) :: return_char1
+
+  j = achar(i)
+  return_char1 = j
+end function return_char1
+function return_char2(i) result(output) bind(c,name='return_char2')
+  use iso_c_binding
+  implicit none
+  integer(c_int) :: i
+  character(c_char) :: j
+  character(c_char) :: output
+
+  j = achar(i)
+  output = j
+end function return_char2
+function return_char3(i) bind(c,name='return_char3') result(output)
+  use iso_c_binding
+  implicit none
+  integer(c_int) :: i
+  character(c_char) :: j
+  character(c_char) :: output
+
+  j = achar(i)
+  output = j
+end function return_char3