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

commit ba3e2aa125522cee9bc2fdbb5d7a83da07369246
Author: Mikael Morin <mik...@gcc.gnu.org>
Date:   Sun Aug 17 17:05:28 2025 +0200

    Factorisation set_dimension_bounds/shift_dimension_bounds 
gfc_set_descriptor_for_assign_realloc
    
    Revert partiel

Diff:
---
 gcc/fortran/trans-descriptor.cc | 39 +++++++++++----------------------------
 1 file changed, 11 insertions(+), 28 deletions(-)

diff --git a/gcc/fortran/trans-descriptor.cc b/gcc/fortran/trans-descriptor.cc
index f2fbe4e77045..510fc984de34 100644
--- a/gcc/fortran/trans-descriptor.cc
+++ b/gcc/fortran/trans-descriptor.cc
@@ -2492,38 +2492,21 @@ gfc_set_descriptor_for_assign_realloc (stmtblock_t 
*block, gfc_loopinfo *loop,
       tree tmp = fold_build2_loc (input_location, MINUS_EXPR,
                                  gfc_array_index_type,
                                  loop->to[n], loop->from[n]);
-      tmp = fold_build2_loc (input_location, PLUS_EXPR,
-                            gfc_array_index_type,
-                            tmp, gfc_index_one_node);
-
-      tree lbound = gfc_index_one_node;
-      tree ubound = tmp;
+      tree ubound = fold_build2_loc (input_location, PLUS_EXPR,
+                                    gfc_array_index_type,
+                                    tmp, gfc_index_one_node);
 
       if (as)
-       {
-         tree lbd = get_std_lbound (expr2, desc2, n,
-                                    as->type == AS_ASSUMED_SIZE);
-         ubound = fold_build2_loc (input_location,
-                                   MINUS_EXPR,
-                                   gfc_array_index_type,
-                                   ubound, lbound);
-         ubound = fold_build2_loc (input_location,
-                                   PLUS_EXPR,
-                                   gfc_array_index_type,
-                                   ubound, lbd);
-         lbound = lbd;
-       }
+       shift_dimension_fields (block, desc, gfc_rank_cst[n],
+                               get_std_lbound (expr2, desc2, n,
+                                               as->type == AS_ASSUMED_SIZE),
+                               gfc_index_one_node, ubound, size1, &offset);
+      else
+       set_dimension_fields (block, desc, gfc_rank_cst[n], gfc_index_one_node,
+                             ubound, size1, &offset);
 
-      gfc_conv_descriptor_lbound_set (block, desc, gfc_rank_cst[n], lbound);
-      gfc_conv_descriptor_ubound_set (block, desc, gfc_rank_cst[n], ubound);
-      gfc_conv_descriptor_stride_set (block, desc, gfc_rank_cst[n], size1);
-      lbound = gfc_conv_descriptor_lbound_get (desc, gfc_rank_cst[n]);
-      tree tmp2 = fold_build2_loc (input_location, MULT_EXPR, 
gfc_array_index_type,
-                                  lbound, size1);
-      offset = fold_build2_loc (input_location, MINUS_EXPR,
-                               gfc_array_index_type, offset, tmp2);
       size1 = fold_build2_loc (input_location, MULT_EXPR, gfc_array_index_type,
-                              tmp, size1);
+                              ubound, size1);
     }
 
   /* Set the lhs descriptor and scalarizer offsets.  For rank > 1,

Reply via email to