diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2020-07-23 12:45:49 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-07-23 12:45:49 +0300 |
commit | 587e159d6c96afd5ff32871e8ff99699b95f2802 (patch) | |
tree | ca0c4450b0bc055c9b48d63b02ac2dd7dfba971e /mesonbuild/dependencies/base.py | |
parent | 6e7d548b11ac4ae940c3e08e16d3118ac3a40420 (diff) | |
parent | 62f3aa1dadfe006174eabfd65bfa089c7331b0dc (diff) | |
download | meson-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.py | 10 |
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') |