aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2021-10-29 18:25:22 +0300
committerJussi Pakkanen <jpakkane@gmail.com>2021-10-29 22:47:06 +0300
commitc1b686e39568784a9db572dd3b6a4e4e254daaa7 (patch)
treeaf00dddf1de95d9f9d1496fe78f66098d6922eb8 /mesonbuild
parentaf85738dafc8b371c8b6dbcfba23e1cdb621dc8c (diff)
downloadmeson-c1b686e39568784a9db572dd3b6a4e4e254daaa7.zip
meson-c1b686e39568784a9db572dd3b6a4e4e254daaa7.tar.gz
meson-c1b686e39568784a9db572dd3b6a4e4e254daaa7.tar.bz2
Make environment objects hash deterministically.
Diffstat (limited to 'mesonbuild')
-rw-r--r--mesonbuild/backend/backends.py11
-rw-r--r--mesonbuild/build.py8
2 files changed, 16 insertions, 3 deletions
diff --git a/mesonbuild/backend/backends.py b/mesonbuild/backend/backends.py
index 3d8654e..1d04c91 100644
--- a/mesonbuild/backend/backends.py
+++ b/mesonbuild/backend/backends.py
@@ -648,9 +648,14 @@ class Backend:
# avoids collisions and also makes the name deterministic over
# regenerations which avoids a rebuild by Ninja because the cmdline
# stays the same.
- data = bytes(str(es.env) + str(es.cmd_args) + str(es.workdir) + str(capture) + str(feed),
- encoding='utf-8')
- digest = hashlib.sha1(data).hexdigest()
+ hasher = hashlib.sha1()
+ if es.env:
+ es.env.hash(hasher)
+ hasher.update(bytes(str(es.cmd_args), encoding='utf-8'))
+ hasher.update(bytes(str(es.workdir), encoding='utf-8'))
+ hasher.update(bytes(str(capture), encoding='utf-8'))
+ hasher.update(bytes(str(feed), encoding='utf-8'))
+ digest = hasher.hexdigest()
scratch_file = f'meson_exe_{basename}_{digest}.dat'
exe_data = os.path.join(self.environment.get_scratch_dir(), scratch_file)
with open(exe_data, 'wb') as f:
diff --git a/mesonbuild/build.py b/mesonbuild/build.py
index 02e8da9..dd55fc6 100644
--- a/mesonbuild/build.py
+++ b/mesonbuild/build.py
@@ -468,6 +468,14 @@ class EnvironmentVariables(HoldableObject):
repr_str = "<{0}: {1}>"
return repr_str.format(self.__class__.__name__, self.envvars)
+ def hash(self, hasher: T.Any):
+ myenv = self.get_env({})
+ for key in sorted(myenv.keys()):
+ hasher.update(bytes(key, encoding='utf-8'))
+ hasher.update(b',')
+ hasher.update(bytes(myenv[key], encoding='utf-8'))
+ hasher.update(b';')
+
def has_name(self, name: str) -> bool:
return name in self.varnames