summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Kuhn <michael.kuhn@informatik.uni-hamburg.de>2020-06-06 23:18:48 +0200
committerGitHub <noreply@github.com>2020-06-06 16:18:48 -0500
commitad2dd4be01d7caae69455ff61d5e006efab83e30 (patch)
tree0098083b5871a3bb3f7d4e889572e233da1b8be1
parent543f9f91d4a4200cb653dd9c44588773e497f3b7 (diff)
downloadspack-ad2dd4be01d7caae69455ff61d5e006efab83e30.tar.gz
spack-ad2dd4be01d7caae69455ff61d5e006efab83e30.tar.bz2
spack-ad2dd4be01d7caae69455ff61d5e006efab83e30.tar.xz
spack-ad2dd4be01d7caae69455ff61d5e006efab83e30.zip
mongo-c-driver: Add 1.16.2 (#16956)
This also updates libbson to the corresponding version and adds a few missing older versions.
-rw-r--r--var/spack/repos/builtin/packages/libbson/package.py51
-rw-r--r--var/spack/repos/builtin/packages/mongo-c-driver/package.py75
2 files changed, 116 insertions, 10 deletions
diff --git a/var/spack/repos/builtin/packages/libbson/package.py b/var/spack/repos/builtin/packages/libbson/package.py
index 9f9a113884..e71cb2eb08 100644
--- a/var/spack/repos/builtin/packages/libbson/package.py
+++ b/var/spack/repos/builtin/packages/libbson/package.py
@@ -6,15 +6,19 @@
from spack import *
-class Libbson(AutotoolsPackage):
+class Libbson(Package):
"""libbson is a library providing useful routines related to building,
parsing, and iterating BSON documents."""
- homepage = "https://github.com/mongodb/libbson"
- url = "https://github.com/mongodb/libbson/releases/download/1.7.0/libbson-1.7.0.tar.gz"
+ homepage = "https://github.com/mongodb/mongo-c-driver"
+ url = "https://github.com/mongodb/mongo-c-driver/releases/download/1.16.2/mongo-c-driver-1.16.2.tar.gz"
maintainers = ['michaelkuhn']
+ version('1.16.2', sha256='0a722180e5b5c86c415b9256d753b2d5552901dc5d95c9f022072c3cd336887e')
+ version('1.9.5', sha256='6bb51b863a4641d6d7729e4b55df8f4389ed534c34eb3a1cda906a53df11072c')
+ version('1.9.4', sha256='c3cc230a3451bf7fedc5bb34c3191fd23d841e65ec415301f6c77e531924b769')
+ version('1.9.3', sha256='244e786c746fe6326433b1a6fcaadbdedc0da3d11c7b3168f0afa468f310e5f1')
version('1.9.1', sha256='236d9fcec0fe419c2201481081e497f49136eda2349b61cfede6233013bf7601')
version('1.8.1', sha256='9d18d14671b7890e27b2a5ce33a73a5ed5d33d39bba70209bae99c1dc7aa1ed4')
version('1.8.0', sha256='63dea744b265a2e17c7b5e289f7803c679721d98e2975ea7d56bc1e7b8586bc1')
@@ -23,12 +27,53 @@ class Libbson(AutotoolsPackage):
version('1.6.2', sha256='aad410123e4bd8a9804c3c3d79e03344e2df104872594dc2cf19605d492944ba')
version('1.6.1', sha256='5f160d44ea42ce9352a7a3607bc10d3b4b22d3271763aa3b3a12665e73e3a02d')
+ depends_on('cmake@3.1:', type='build', when='@1.10.0:')
+
depends_on('autoconf', type='build', when='@1.6.1')
depends_on('automake', type='build', when='@1.6.1')
depends_on('libtool', type='build', when='@1.6.1')
depends_on('m4', type='build', when='@1.6.1')
+ def url_for_version(self, version):
+ if version >= Version('1.10.0'):
+ url = 'https://github.com/mongodb/mongo-c-driver/releases/download/{0}/mongo-c-driver-{0}.tar.gz'
+ else:
+ url = 'https://github.com/mongodb/libbson/releases/download/{0}/libbson-{0}.tar.gz'
+
+ return url.format(version)
+
+ def cmake_args(self):
+ args = [
+ '-DENABLE_AUTOMATIC_INIT_AND_CLEANUP=OFF',
+ '-DENABLE_MONGOC=OFF'
+ ]
+
+ return args
+
+ def install(self, spec, prefix):
+ with working_dir('spack-build', create=True):
+ # We cannot simply do
+ # cmake('..', *std_cmake_args, *self.cmake_args())
+ # because that is not Python 2 compatible. Instead, collect
+ # arguments into a temporary buffer first.
+ args = []
+ args.extend(std_cmake_args)
+ args.extend(self.cmake_args())
+ cmake('..', *args)
+ make()
+ make('install')
+
@property
def force_autoreconf(self):
# 1.6.1 tarball is broken
return self.spec.satisfies('@1.6.1')
+
+ @when('@:1.9.99')
+ def install(self, spec, prefix):
+ configure('--prefix={0}'.format(prefix))
+ make()
+ if self.run_tests:
+ make('check')
+ make('install')
+ if self.run_tests:
+ make('installcheck')
diff --git a/var/spack/repos/builtin/packages/mongo-c-driver/package.py b/var/spack/repos/builtin/packages/mongo-c-driver/package.py
index 27008d7561..ee3fc581b9 100644
--- a/var/spack/repos/builtin/packages/mongo-c-driver/package.py
+++ b/var/spack/repos/builtin/packages/mongo-c-driver/package.py
@@ -6,7 +6,7 @@
from spack import *
-class MongoCDriver(AutotoolsPackage):
+class MongoCDriver(Package):
"""libmongoc is a client library written in C for MongoDB."""
homepage = "https://github.com/mongodb/mongo-c-driver"
@@ -14,6 +14,7 @@ class MongoCDriver(AutotoolsPackage):
maintainers = ['michaelkuhn']
+ version('1.16.2', sha256='0a722180e5b5c86c415b9256d753b2d5552901dc5d95c9f022072c3cd336887e')
version('1.9.5', sha256='4a4bd0b0375450250a3da50c050b84b9ba8950ce32e16555714e75ebae0b8019')
version('1.9.4', sha256='910c2f1b2e3df4d0ea39c2f242160028f90fcb8201f05339a730ec4ba70811fb')
version('1.9.3', sha256='c2c94ef63aaa09efabcbadc4ac3c8740faa102266bdd2559d550f1955b824398')
@@ -28,20 +29,73 @@ class MongoCDriver(AutotoolsPackage):
variant('ssl', default=True, description='Enable SSL support.')
variant('snappy', default=True, description='Enable Snappy support.')
variant('zlib', default=True, description='Enable zlib support.')
+ variant('zstd', default=True, description='Enable zstd support.')
patch('https://github.com/mongodb/mongo-c-driver/pull/466.patch', sha256='713a872217d11aba04a774785a2824d26b566543c270a1fa386114f5200fda20', when='@1.8.1')
+ depends_on('cmake@3.1:', type='build', when='@1.10.0:')
+
depends_on('autoconf', type='build', when='@1.8.1')
depends_on('automake', type='build', when='@1.8.1')
depends_on('libtool', type='build', when='@1.8.1')
depends_on('m4', type='build', when='@1.8.1')
+
depends_on('pkgconfig', type='build')
- depends_on('libbson')
+ # When updating mongo-c-driver, libbson has to be kept in sync.
+ depends_on('libbson@1.16.0:1.16.99', when='@1.16')
+ depends_on('libbson@1.9.0:1.9.99', when='@1.9')
+ depends_on('libbson@1.8.0:1.8.99', when='@1.8')
+ depends_on('libbson@1.7.0:1.7.99', when='@1.7')
+ depends_on('libbson@1.6.0:1.6.99', when='@1.6')
depends_on('openssl', when='+ssl')
depends_on('snappy', when='+snappy')
depends_on('zlib', when='+zlib')
+ depends_on('zstd', when='+zstd')
+
+ def cmake_args(self):
+ spec = self.spec
+
+ args = [
+ '-DENABLE_AUTOMATIC_INIT_AND_CLEANUP=OFF',
+ '-DENABLE_BSON=SYSTEM'
+ ]
+
+ if '+ssl' in spec:
+ args.append('-DENABLE_SSL=OPENSSL')
+ else:
+ args.append('-DENABLE_SSL=OFF')
+
+ if '+snappy' in spec:
+ args.append('-DENABLE_SNAPPY=ON')
+ else:
+ args.append('-DENABLE_SNAPPY=OFF')
+
+ if '+zlib' in spec:
+ args.append('-DENABLE_ZLIB=SYSTEM')
+ else:
+ args.append('-DENABLE_ZLIB=OFF')
+
+ if '+zstd' in spec:
+ args.append('-DENABLE_ZSTD=ON')
+ else:
+ args.append('-DENABLE_ZSTD=OFF')
+
+ return args
+
+ def install(self, spec, prefix):
+ with working_dir('spack-build', create=True):
+ # We cannot simply do
+ # cmake('..', *std_cmake_args, *self.cmake_args())
+ # because that is not Python 2 compatible. Instead, collect
+ # arguments into a temporary buffer first.
+ args = []
+ args.extend(std_cmake_args)
+ args.extend(self.cmake_args())
+ cmake('..', *args)
+ make()
+ make('install')
@property
def force_autoreconf(self):
@@ -52,7 +106,8 @@ class MongoCDriver(AutotoolsPackage):
spec = self.spec
args = [
- '--disable-automatic-init-and-cleanup'
+ '--disable-automatic-init-and-cleanup',
+ '--with-libbson=system'
]
if '+ssl' in spec:
@@ -72,8 +127,14 @@ class MongoCDriver(AutotoolsPackage):
elif spec.satisfies('@1.8.1:'):
args.append('--with-zlib=system')
- if spec.satisfies('@1.9.3:'):
- args.append('--with-libbson=auto')
- else:
- args.append('--with-libbson=system')
return args
+
+ @when('@:1.9.99')
+ def install(self, spec, prefix):
+ configure('--prefix={0}'.format(prefix), *self.configure_args())
+ make()
+ if self.run_tests:
+ make('check')
+ make('install')
+ if self.run_tests:
+ make('installcheck')