aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/interpreter.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2016-11-12 11:35:57 -0500
committerGitHub <noreply@github.com>2016-11-12 11:35:57 -0500
commit434bb03743c06f222c5d285e53744155f159e7bd (patch)
tree0f6a41b060e6bbff21bec389489d103afafc8b8f /mesonbuild/interpreter.py
parent4fbc5bcb4433298330192ef42a8e4c224f7a71b2 (diff)
parent627d859809f87feac758bcd2e52104548f147df4 (diff)
downloadmeson-434bb03743c06f222c5d285e53744155f159e7bd.zip
meson-434bb03743c06f222c5d285e53744155f159e7bd.tar.gz
meson-434bb03743c06f222c5d285e53744155f159e7bd.tar.bz2
Merge pull request #997 from tp-m/copy-mutable-variables-on-assignment
Copy mutable variables on assignment (configuration_data and environment)
Diffstat (limited to 'mesonbuild/interpreter.py')
-rw-r--r--mesonbuild/interpreter.py15
1 files changed, 9 insertions, 6 deletions
diff --git a/mesonbuild/interpreter.py b/mesonbuild/interpreter.py
index 0030660..7b1cb52 100644
--- a/mesonbuild/interpreter.py
+++ b/mesonbuild/interpreter.py
@@ -92,6 +92,10 @@ class InterpreterObject():
return self.methods[method_name](args, kwargs)
raise InvalidCode('Unknown method "%s" in object.' % method_name)
+class MutableInterpreterObject(InterpreterObject):
+ def __init__(self):
+ super().__init__()
+
class TryRunResultHolder(InterpreterObject):
def __init__(self, res):
super().__init__()
@@ -182,14 +186,13 @@ class ConfigureFileHolder(InterpreterObject):
self.held_object = build.ConfigureFile(subdir, sourcename, targetname, configuration_data)
-class EnvironmentVariablesHolder(InterpreterObject):
+class EnvironmentVariablesHolder(MutableInterpreterObject):
def __init__(self):
super().__init__()
self.held_object = build.EnvironmentVariables()
self.methods.update({'set': self.set_method,
'append': self.append_method,
'prepend' : self.prepend_method,
- 'copy' : self.copy_method,
})
@stringArgs
@@ -212,11 +215,8 @@ class EnvironmentVariablesHolder(InterpreterObject):
def prepend_method(self, args, kwargs):
self.add_var(self.held_object.prepend, args, kwargs)
- def copy_method(self, args, kwargs):
- return copy.deepcopy(self)
-
-class ConfigurationDataHolder(InterpreterObject):
+class ConfigurationDataHolder(MutableInterpreterObject):
def __init__(self):
super().__init__()
self.used = False # These objects become immutable after use in configure_file.
@@ -2461,6 +2461,9 @@ requirements use the version keyword argument instead.''')
value = self.to_native(value)
if not self.is_assignable(value):
raise InvalidCode('Tried to assign an invalid value to variable.')
+ # For mutable objects we need to make a copy on assignment
+ if isinstance(value, MutableInterpreterObject):
+ value = copy.deepcopy(value)
self.set_variable(var_name, value)
return value