]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
Remove ada_binop_in_bounds
authorTom Tromey <tromey@adacore.com>
Mon, 8 Sep 2025 16:27:40 +0000 (10:27 -0600)
committerTom Tromey <tromey@adacore.com>
Tue, 9 Sep 2025 15:28:40 +0000 (09:28 -0600)
ada_binop_in_bounds can be merged with its sole caller.

Approved-By: Simon Marchi <simon.marchi@efficios.com>
gdb/ada-exp.h
gdb/ada-lang.c

index 6703a54ef55782abbc513cf961f3b82ad794c65b..7354d654c0fa8eb3f9d64b108add4c1441ab24ef 100644 (file)
@@ -38,11 +38,6 @@ extern struct value *ada_mult_binop (struct type *expect_type,
                                     struct expression *exp,
                                     enum noside noside, enum exp_opcode op,
                                     struct value *arg1, struct value *arg2);
-extern struct value *ada_binop_in_bounds (struct expression *exp,
-                                         enum noside noside,
-                                         struct value *arg1,
-                                         struct value *arg2,
-                                         int n);
 extern struct value *ada_binop_minmax (struct type *expect_type,
                                       struct expression *exp,
                                       enum noside noside, enum exp_opcode op,
@@ -304,13 +299,7 @@ public:
 
   value *evaluate (struct type *expect_type,
                   struct expression *exp,
-                  enum noside noside) override
-  {
-    value *arg1 = std::get<0> (m_storage)->evaluate (nullptr, exp, noside);
-    value *arg2 = std::get<1> (m_storage)->evaluate (nullptr, exp, noside);
-    return ada_binop_in_bounds (exp, noside, arg1, arg2,
-                               std::get<2> (m_storage));
-  }
+                  enum noside noside) override;
 
   enum exp_opcode opcode () const override
   { return BINOP_IN_BOUNDS; }
index 323abee7c9e1633ab98e793a955c5631ead42773..b7039fdddfe8142e58766d77c6e01541dda75db0 100644 (file)
@@ -10284,14 +10284,17 @@ ada_ternop_slice_operation::evaluate (struct type *expect_type,
                            longest_to_int (high_bound));
 }
 
-} /* namespace expr */
-
-/* A helper function for BINOP_IN_BOUNDS.  */
+/* Implement BINOP_IN_BOUNDS.  */
 
 value *
-ada_binop_in_bounds (struct expression *exp, enum noside noside,
-                    struct value *arg1, struct value *arg2, int n)
+ada_binop_in_bounds_operation::evaluate (struct type *expect_type,
+                                        struct expression *exp,
+                                        enum noside noside)
 {
+  value *arg1 = std::get<0> (m_storage)->evaluate (nullptr, exp, noside);
+  value *arg2 = std::get<1> (m_storage)->evaluate (nullptr, exp, noside);
+  int n = std::get<2> (m_storage);
+
   if (noside == EVAL_AVOID_SIDE_EFFECTS)
     {
       struct type *type = language_bool_type (exp->language_defn,
@@ -10316,6 +10319,8 @@ ada_binop_in_bounds (struct expression *exp, enum noside noside,
                                 || value_equal (arg2, arg1)));
 }
 
+} /* namespace expr */
+
 /* A helper function for some attribute operations.  */
 
 static value *