summaryrefslogtreecommitdiff
path: root/var
diff options
context:
space:
mode:
authorAxel Huebl <axel.huebl@plasma.ninja>2017-09-25 19:47:55 +0200
committerscheibelp <scheibel1@llnl.gov>2017-09-25 10:47:55 -0700
commit28dd6b378cdf5859e0ab7980b0e57ede6e3227db (patch)
tree07df2e0040552a281a20cf9c395b8b5bd3f5766f /var
parent8864d145e9925a412bd8f023d2e7bd651b2445a4 (diff)
downloadspack-28dd6b378cdf5859e0ab7980b0e57ede6e3227db.tar.gz
spack-28dd6b378cdf5859e0ab7980b0e57ede6e3227db.tar.bz2
spack-28dd6b378cdf5859e0ab7980b0e57ede6e3227db.tar.xz
spack-28dd6b378cdf5859e0ab7980b0e57ede6e3227db.zip
Fix Protobuf URLs (#5373)
The default implementation of Package.fetch_remote_versions will take a URL like https://github.com/google/protobuf/archive/ and automatically search https://github.com/google/protobuf/releases/ for new package versions. In the case of protobuf the release/ path contains release artifacts for a version and the archive/ path contains the desired source. Since both are associated with the version, and Package.fetch_remote_versions only stores one URL for a given version, the two paths are in conflict; previously the URL returned for a given version was arbitrarily chosen between the two paths. This updates the definition for the Protobuf package to always search for URLs in https://github.com/google/protobuf/archive/
Diffstat (limited to 'var')
-rw-r--r--var/spack/repos/builtin/packages/protobuf/package.py18
1 files changed, 15 insertions, 3 deletions
diff --git a/var/spack/repos/builtin/packages/protobuf/package.py b/var/spack/repos/builtin/packages/protobuf/package.py
index eff24fdb72..eafb6a33d2 100644
--- a/var/spack/repos/builtin/packages/protobuf/package.py
+++ b/var/spack/repos/builtin/packages/protobuf/package.py
@@ -23,6 +23,7 @@
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
##############################################################################
from spack import *
+import spack.util.web
class Protobuf(CMakePackage):
@@ -33,9 +34,10 @@ class Protobuf(CMakePackage):
root_cmakelists_dir = "cmake"
version('3.4.0', '1d077a7d4db3d75681f5c333f2de9b1a')
- version('3.2.0', '61d899b8369781f6dd1e62370813392d')
- version('3.1.0', '14a532a7538551d5def317bfca41dace')
- version('3.0.2', '845b39e4b7681a2ddfd8c7f528299fbb')
+ version('3.3.0', 'f0f712e98de3db0c65c0c417f5e7aca8')
+ version('3.2.0', 'efaa08ae635664fb5e7f31421a41a995')
+ version('3.1.0', '39d6a4fa549c0cce164aa3064b1492dc')
+ version('3.0.2', '7349a7f43433d72c6d805c6ca22b7eeb')
# does not build with CMake:
# version('2.5.0', '9c21577a03adc1879aba5b52d06e25cf')
@@ -46,6 +48,16 @@ class Protobuf(CMakePackage):
# first fixed in 3.4.0: https://github.com/google/protobuf/pull/3406
patch('pkgconfig.patch', when='@:3.3.2')
+ def fetch_remote_versions(self):
+ """Ignore additional source artifacts uploaded with releases,
+ only keep known versions
+ fix for https://github.com/LLNL/spack/issues/5356"""
+ return dict(map(
+ lambda u: (u, self.url_for_version(u)),
+ spack.util.web.find_versions_of_archive(
+ self.all_urls, self.list_url, self.list_depth)
+ ))
+
def cmake_args(self):
args = [
'-Dprotobuf_BUILD_TESTS:BOOL=OFF',