diff options
| author | Paolo Bonzini <pbonzini@redhat.com> | 2025-01-22 14:18:18 +0100 |
|---|---|---|
| committer | Jussi Pakkanen <jussi.pakkanen@mailbox.org> | 2025-06-17 12:29:56 +0300 |
| commit | f3366a7e543f69844bd3658db65c28295912db79 (patch) | |
| tree | c845b67716730a01ff7b7d3f3f7c30a50f679daa /mesonbuild/interpreter/primitives/integer.py | |
| parent | 992a93bcef47972c75464d1878c4c4b0469b1fbf (diff) | |
| download | meson-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.py | 33 |
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, |
