summaryrefslogtreecommitdiff
path: root/mesonbuild/interpreter/primitives/string.py
diff options
context:
space:
mode:
authorPaolo Bonzini <pbonzini@redhat.com>2025-01-08 10:50:25 +0100
committerJussi Pakkanen <jussi.pakkanen@mailbox.org>2025-06-17 12:29:56 +0300
commit992a93bcef47972c75464d1878c4c4b0469b1fbf (patch)
treeb6dab1d7e16f05ab96a97cfe5bfafeb25a665019 /mesonbuild/interpreter/primitives/string.py
parent2be42a5423209a88551cf88dd3b49f8e4da50963 (diff)
downloadmeson-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.py34
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)