https://gcc.gnu.org/g:ba485b825736e5a6661605e8d618484182f6bef6

commit ba485b825736e5a6661605e8d618484182f6bef6
Author: Mikael Morin <mik...@gcc.gnu.org>
Date:   Tue Jul 15 19:13:46 2025 +0200

    Utilisation gfc_clear_descriptor pour initialiser les résultats de type 
class

Diff:
---
 gcc/fortran/trans-decl.cc | 4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)

diff --git a/gcc/fortran/trans-decl.cc b/gcc/fortran/trans-decl.cc
index 2996dd72e6aa..f0c1f0947558 100644
--- a/gcc/fortran/trans-decl.cc
+++ b/gcc/fortran/trans-decl.cc
@@ -4773,14 +4773,12 @@ gfc_trans_deferred_vars (gfc_symbol * proc_sym, 
gfc_wrapped_block * block)
   else if (proc_sym == proc_sym->result && IS_CLASS_ARRAY (proc_sym))
     {
       /* Nullify explicit return class arrays on entry.  */
-      tree type;
       tmp = get_proc_result (proc_sym);
       if (tmp && GFC_CLASS_TYPE_P (TREE_TYPE (tmp)))
        {
          gfc_start_block (&init);
          tmp = gfc_class_data_get (tmp);
-         type = TREE_TYPE (gfc_conv_descriptor_data_get (tmp));
-         gfc_conv_descriptor_data_set (&init, tmp, build_int_cst (type, 0));
+         gfc_clear_descriptor (&init, proc_sym, tmp);
          gfc_add_init_cleanup (block, gfc_finish_block (&init), NULL_TREE);
        }
     }

Reply via email to