summaryrefslogtreecommitdiff
path: root/mesonbuild/interpreter/primitives/integer.py
diff options
context:
space:
mode:
authorPaolo Bonzini <pbonzini@redhat.com>2025-01-22 14:18:18 +0100
committerJussi Pakkanen <jussi.pakkanen@mailbox.org>2025-06-17 12:29:56 +0300
commitf3366a7e543f69844bd3658db65c28295912db79 (patch)
treec845b67716730a01ff7b7d3f3f7c30a50f679daa /mesonbuild/interpreter/primitives/integer.py
parent992a93bcef47972c75464d1878c4c4b0469b1fbf (diff)
downloadmeson-f3366a7e543f69844bd3658db65c28295912db79.tar.gz
interpreter: make trivial_operators per-class
Do not call update() and Enum.__hash__ a gazillion times; trivial operators are the same for every instance of the class. Introduce the infrastructure to build the MRO-resolved operators (so the outcome same as if one called super().__init__) for each subclass of InterpreterObject. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'mesonbuild/interpreter/primitives/integer.py')
-rw-r--r--mesonbuild/interpreter/primitives/integer.py33
1 files changed, 17 insertions, 16 deletions
diff --git a/mesonbuild/interpreter/primitives/integer.py b/mesonbuild/interpreter/primitives/integer.py
index 2d0915f7b..48ada78ad 100644
--- a/mesonbuild/interpreter/primitives/integer.py
+++ b/mesonbuild/interpreter/primitives/integer.py
@@ -15,6 +15,23 @@ if T.TYPE_CHECKING:
from ...interpreterbase import TYPE_var, TYPE_kwargs
class IntegerHolder(ObjectHolder[int]):
+ # Operators that only require type checks
+ TRIVIAL_OPERATORS = {
+ # Arithmetic
+ MesonOperator.UMINUS: (None, lambda obj, x: -obj.held_object),
+ MesonOperator.PLUS: (int, lambda obj, x: obj.held_object + x),
+ MesonOperator.MINUS: (int, lambda obj, x: obj.held_object - x),
+ MesonOperator.TIMES: (int, lambda obj, x: obj.held_object * x),
+
+ # Comparison
+ MesonOperator.EQUALS: (int, lambda obj, x: obj.held_object == x),
+ MesonOperator.NOT_EQUALS: (int, lambda obj, x: obj.held_object != x),
+ MesonOperator.GREATER: (int, lambda obj, x: obj.held_object > x),
+ MesonOperator.LESS: (int, lambda obj, x: obj.held_object < x),
+ MesonOperator.GREATER_EQUALS: (int, lambda obj, x: obj.held_object >= x),
+ MesonOperator.LESS_EQUALS: (int, lambda obj, x: obj.held_object <= x),
+ }
+
def __init__(self, obj: int, interpreter: 'Interpreter') -> None:
super().__init__(obj, interpreter)
self.methods.update({
@@ -23,22 +40,6 @@ class IntegerHolder(ObjectHolder[int]):
'to_string': self.to_string_method,
})
- self.trivial_operators.update({
- # Arithmetic
- MesonOperator.UMINUS: (None, lambda obj, x: -obj.held_object),
- MesonOperator.PLUS: (int, lambda obj, x: obj.held_object + x),
- MesonOperator.MINUS: (int, lambda obj, x: obj.held_object - x),
- MesonOperator.TIMES: (int, lambda obj, x: obj.held_object * x),
-
- # Comparison
- MesonOperator.EQUALS: (int, lambda obj, x: obj.held_object == x),
- MesonOperator.NOT_EQUALS: (int, lambda obj, x: obj.held_object != x),
- MesonOperator.GREATER: (int, lambda obj, x: obj.held_object > x),
- MesonOperator.LESS: (int, lambda obj, x: obj.held_object < x),
- MesonOperator.GREATER_EQUALS: (int, lambda obj, x: obj.held_object >= x),
- MesonOperator.LESS_EQUALS: (int, lambda obj, x: obj.held_object <= x),
- })
-
# Use actual methods for functions that require additional checks
self.operators.update({
MesonOperator.DIV: IntegerHolder.op_div,