diff options
| author | Paolo Bonzini <pbonzini@redhat.com> | 2025-01-08 10:50:25 +0100 |
|---|---|---|
| committer | Jussi Pakkanen <jussi.pakkanen@mailbox.org> | 2025-06-17 12:29:56 +0300 |
| commit | 992a93bcef47972c75464d1878c4c4b0469b1fbf (patch) | |
| tree | b6dab1d7e16f05ab96a97cfe5bfafeb25a665019 /mesonbuild/interpreter/primitives/string.py | |
| parent | 2be42a5423209a88551cf88dd3b49f8e4da50963 (diff) | |
| download | meson-992a93bcef47972c75464d1878c4c4b0469b1fbf.tar.gz | |
interpreter: make operator functions binary
In preparation for moving them to the class, make the operator functions
binary. Adjust the lambdas for trivial operators, and store unbound
methods for non-trivial ones.
Note that this requires adding operators manually for every override,
even subclasses. It's decidedly ugly at this temporary stage; later
it will result in just an extra @InterpreterObject.operator decorator
on the subclasses.
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'mesonbuild/interpreter/primitives/string.py')
| -rw-r--r-- | mesonbuild/interpreter/primitives/string.py | 34 |
1 files changed, 23 insertions, 11 deletions
diff --git a/mesonbuild/interpreter/primitives/string.py b/mesonbuild/interpreter/primitives/string.py index a224dfac8..3cb78b310 100644 --- a/mesonbuild/interpreter/primitives/string.py +++ b/mesonbuild/interpreter/primitives/string.py @@ -51,23 +51,23 @@ class StringHolder(ObjectHolder[str]): self.trivial_operators.update({ # Arithmetic - MesonOperator.PLUS: (str, lambda x: self.held_object + x), + MesonOperator.PLUS: (str, lambda obj, x: obj.held_object + x), # Comparison - MesonOperator.EQUALS: (str, lambda x: self.held_object == x), - MesonOperator.NOT_EQUALS: (str, lambda x: self.held_object != x), - MesonOperator.GREATER: (str, lambda x: self.held_object > x), - MesonOperator.LESS: (str, lambda x: self.held_object < x), - MesonOperator.GREATER_EQUALS: (str, lambda x: self.held_object >= x), - MesonOperator.LESS_EQUALS: (str, lambda x: self.held_object <= x), + MesonOperator.EQUALS: (str, lambda obj, x: obj.held_object == x), + MesonOperator.NOT_EQUALS: (str, lambda obj, x: obj.held_object != x), + MesonOperator.GREATER: (str, lambda obj, x: obj.held_object > x), + MesonOperator.LESS: (str, lambda obj, x: obj.held_object < x), + MesonOperator.GREATER_EQUALS: (str, lambda obj, x: obj.held_object >= x), + MesonOperator.LESS_EQUALS: (str, lambda obj, x: obj.held_object <= x), }) # Use actual methods for functions that require additional checks self.operators.update({ - MesonOperator.DIV: self.op_div, - MesonOperator.INDEX: self.op_index, - MesonOperator.IN: self.op_in, - MesonOperator.NOT_IN: self.op_notin, + MesonOperator.DIV: StringHolder.op_div, + MesonOperator.INDEX: StringHolder.op_index, + MesonOperator.IN: StringHolder.op_in, + MesonOperator.NOT_IN: StringHolder.op_notin, }) def display_name(self) -> str: @@ -221,6 +221,12 @@ class DependencyVariableString(str): pass class DependencyVariableStringHolder(StringHolder): + def __init__(self, obj: str, interpreter: Interpreter) -> None: + super().__init__(obj, interpreter) + self.operators.update({ + MesonOperator.DIV: DependencyVariableStringHolder.op_div, + }) + def op_div(self, other: str) -> T.Union[str, DependencyVariableString]: ret = super().op_div(other) if '..' in other: @@ -243,6 +249,12 @@ class OptionString(str): class OptionStringHolder(StringHolder): held_object: OptionString + def __init__(self, obj: str, interpreter: Interpreter) -> None: + super().__init__(obj, interpreter) + self.operators.update({ + MesonOperator.DIV: OptionStringHolder.op_div, + }) + def op_div(self, other: str) -> T.Union[str, OptionString]: ret = super().op_div(other) name = self._op_div(self.held_object.optname, other) |
