aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/dependencies/base.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2020-07-23 12:45:49 +0300
committerGitHub <noreply@github.com>2020-07-23 12:45:49 +0300
commit587e159d6c96afd5ff32871e8ff99699b95f2802 (patch)
treeca0c4450b0bc055c9b48d63b02ac2dd7dfba971e /mesonbuild/dependencies/base.py
parent6e7d548b11ac4ae940c3e08e16d3118ac3a40420 (diff)
parent62f3aa1dadfe006174eabfd65bfa089c7331b0dc (diff)
downloadmeson-587e159d6c96afd5ff32871e8ff99699b95f2802.zip
meson-587e159d6c96afd5ff32871e8ff99699b95f2802.tar.gz
meson-587e159d6c96afd5ff32871e8ff99699b95f2802.tar.bz2
Merge pull request #7460 from mensinda/fixDeepcpy
deps: Do not deepcopy internal libraries (fixes #7457)
Diffstat (limited to 'mesonbuild/dependencies/base.py')
-rw-r--r--mesonbuild/dependencies/base.py10
1 files changed, 10 insertions, 0 deletions
diff --git a/mesonbuild/dependencies/base.py b/mesonbuild/dependencies/base.py
index 23701da..1bb71f7 100644
--- a/mesonbuild/dependencies/base.py
+++ b/mesonbuild/dependencies/base.py
@@ -252,6 +252,16 @@ class InternalDependency(Dependency):
self.ext_deps = ext_deps
self.variables = variables
+ def __deepcopy__(self, memo: dict) -> 'InternalDependency':
+ result = self.__class__.__new__(self.__class__)
+ memo[id(self)] = result
+ for k, v in self.__dict__.items():
+ if k in ['libraries', 'whole_libraries']:
+ setattr(result, k, copy.copy(v))
+ else:
+ setattr(result, k, copy.deepcopy(v, memo))
+ return result
+
def get_pkgconfig_variable(self, variable_name, kwargs):
raise DependencyException('Method "get_pkgconfig_variable()" is '
'invalid for an internal dependency')