diff options
author | Todd Gamblin <tgamblin@llnl.gov> | 2022-07-30 15:19:18 -0700 |
---|---|---|
committer | Todd Gamblin <tgamblin@llnl.gov> | 2022-07-31 13:29:20 -0700 |
commit | f52f6e99dbf1131886a80112b8c79dfc414afb7c (patch) | |
tree | 05cb7d64b2395922f2f24683da49f472075be12c /var/spack/repos/builtin/packages/curl/package.py | |
parent | 549ba1ed32372c67fc57271cde3797d58b7dec6e (diff) | |
download | spack-f52f6e99dbf1131886a80112b8c79dfc414afb7c.tar.gz spack-f52f6e99dbf1131886a80112b8c79dfc414afb7c.tar.bz2 spack-f52f6e99dbf1131886a80112b8c79dfc414afb7c.tar.xz spack-f52f6e99dbf1131886a80112b8c79dfc414afb7c.zip |
black: reformat entire repository with black
Diffstat (limited to 'var/spack/repos/builtin/packages/curl/package.py')
-rw-r--r-- | var/spack/repos/builtin/packages/curl/package.py | 295 |
1 files changed, 153 insertions, 142 deletions
diff --git a/var/spack/repos/builtin/packages/curl/package.py b/var/spack/repos/builtin/packages/curl/package.py index 03796e8407..437209d782 100644 --- a/var/spack/repos/builtin/packages/curl/package.py +++ b/var/spack/repos/builtin/packages/curl/package.py @@ -15,219 +15,230 @@ class Curl(AutotoolsPackage): homepage = "https://curl.se/" # URL must remain http:// so Spack can bootstrap curl - url = "http://curl.haxx.se/download/curl-7.78.0.tar.bz2" - - executables = ['^curl$'] - - version('7.84.0', sha256='702fb26e73190a3bd77071aa146f507b9817cc4dfce218d2ab87f00cd3bc059d') - version('7.83.0', sha256='247c7ec7521c4258e65634e529270d214fe32969971cccb72845e7aa46831f96') - version('7.82.0', sha256='46d9a0400a33408fd992770b04a44a7434b3036f2e8089ac28b57573d59d371f') - version('7.81.0', sha256='1e7a38d7018ec060f1f16df839854f0889e94e122c4cfa5d3a37c2dc56f1e258') - version('7.80.0', sha256='dd0d150e49cd950aff35e16b628edf04927f0289df42883750cf952bb858189c') - version('7.79.1', sha256='de62c4ab9a9316393962e8b94777a570bb9f71feb580fb4475e412f2f9387851') - version('7.79.0', sha256='d607a677f473f79f96c964100327125a6204a39d835dc00dab7fc0129b959f42') - version('7.78.0', sha256='98530b317dc95ccb324bbe4f834f07bb642fbc393b794ddf3434f246a71ea44a') - version('7.77.0', sha256='6c0c28868cb82593859fc43b9c8fdb769314c855c05cf1b56b023acf855df8ea') - version('7.76.1', sha256='7a8e184d7d31312c4ebf6a8cb59cd757e61b2b2833a9ed4f9bf708066e7695e9') - version('7.76.0', sha256='e29bfe3633701590d75b0071bbb649ee5ca4ca73f00649268bd389639531c49a') - version('7.75.0', sha256='50552d4501c178e4cc68baaecc487f466a3d6d19bbf4e50a01869effb316d026') - version('7.74.0', sha256='0f4d63e6681636539dc88fa8e929f934cd3a840c46e0bf28c73be11e521b77a5') - version('7.73.0', sha256='cf34fe0b07b800f1c01a499a6e8b2af548f6d0e044dca4a29d88a4bee146d131') - version('7.72.0', sha256='ad91970864102a59765e20ce16216efc9d6ad381471f7accceceab7d905703ef') - version('7.71.0', sha256='600f00ac2481a89548a4141ddf983fd9386165e1960bac91d0a1c81dca5dd341') - version('7.68.0', sha256='207f54917dd6a2dc733065ccf18d61bb5bebeaceb5df49cd9445483e8623eeb9') - version('7.64.0', sha256='d573ba1c2d1cf9d8533fadcce480d778417964e8d04ccddcc76e591d544cf2eb') - version('7.63.0', sha256='9bab7ed4ecff77020a312d84cc5fb7eb02d58419d218f267477a724a17fd8dd8') - version('7.60.0', sha256='897dfb2204bd99be328279f88f55b7c61592216b0542fcbe995c60aa92871e9b') - version('7.59.0', sha256='b5920ffd6a8c95585fb95070e0ced38322790cb335c39d0dab852d12e157b5a0') - version('7.56.0', sha256='de60a4725a3d461c70aa571d7d69c788f1816d9d1a8a2ef05f864ce8f01279df') - version('7.54.0', sha256='f50ebaf43c507fa7cc32be4b8108fa8bbd0f5022e90794388f3c7694a302ff06') - version('7.53.1', sha256='1c7207c06d75e9136a944a2e0528337ce76f15b9ec9ae4bb30d703b59bf530e8') - version('7.52.1', sha256='d16185a767cb2c1ba3d5b9096ec54e5ec198b213f45864a38b3bda4bbf87389b') - version('7.50.3', sha256='7b7347d976661d02c84a1f4d6daf40dee377efdc45b9e2c77dedb8acf140d8ec') - version('7.50.2', sha256='0c72105df4e9575d68bcf43aea1751056c1d29b1040df6194a49c5ac08f8e233') - version('7.50.1', sha256='3c12c5f54ccaa1d40abc65d672107dcc75d3e1fcb38c267484334280096e5156') - version('7.49.1', sha256='eb63cec4bef692eab9db459033f409533e6d10e20942f4b060b32819e81885f1') - version('7.47.1', sha256='ddc643ab9382e24bbe4747d43df189a0a6ce38fcb33df041b9cb0b3cd47ae98f') - version('7.46.0', sha256='b7d726cdd8ed4b6db0fa1b474a3c59ebbbe4dcd4c61ac5e7ade0e0270d3195ad') - version('7.45.0', sha256='65154e66b9f8a442b57c436904639507b4ac37ec13d6f8a48248f1b4012b98ea') - version('7.44.0', sha256='1e2541bae6582bb697c0fbae49e1d3e6fad5d05d5aa80dbd6f072e0a44341814') - version('7.43.0', sha256='baa654a1122530483ccc1c58cc112fec3724a82c11c6a389f1e6a37dc8858df9') - version('7.42.1', sha256='e2905973391ec2dfd7743a8034ad10eeb58dab8b3a297e7892a41a7999cac887') - - default_tls = 'openssl' - if sys.platform == 'darwin': - default_tls = 'secure_transport' + url = "http://curl.haxx.se/download/curl-7.78.0.tar.bz2" + + executables = ["^curl$"] + + version("7.84.0", sha256="702fb26e73190a3bd77071aa146f507b9817cc4dfce218d2ab87f00cd3bc059d") + version("7.83.0", sha256="247c7ec7521c4258e65634e529270d214fe32969971cccb72845e7aa46831f96") + version("7.82.0", sha256="46d9a0400a33408fd992770b04a44a7434b3036f2e8089ac28b57573d59d371f") + version("7.81.0", sha256="1e7a38d7018ec060f1f16df839854f0889e94e122c4cfa5d3a37c2dc56f1e258") + version("7.80.0", sha256="dd0d150e49cd950aff35e16b628edf04927f0289df42883750cf952bb858189c") + version("7.79.1", sha256="de62c4ab9a9316393962e8b94777a570bb9f71feb580fb4475e412f2f9387851") + version("7.79.0", sha256="d607a677f473f79f96c964100327125a6204a39d835dc00dab7fc0129b959f42") + version("7.78.0", sha256="98530b317dc95ccb324bbe4f834f07bb642fbc393b794ddf3434f246a71ea44a") + version("7.77.0", sha256="6c0c28868cb82593859fc43b9c8fdb769314c855c05cf1b56b023acf855df8ea") + version("7.76.1", sha256="7a8e184d7d31312c4ebf6a8cb59cd757e61b2b2833a9ed4f9bf708066e7695e9") + version("7.76.0", sha256="e29bfe3633701590d75b0071bbb649ee5ca4ca73f00649268bd389639531c49a") + version("7.75.0", sha256="50552d4501c178e4cc68baaecc487f466a3d6d19bbf4e50a01869effb316d026") + version("7.74.0", sha256="0f4d63e6681636539dc88fa8e929f934cd3a840c46e0bf28c73be11e521b77a5") + version("7.73.0", sha256="cf34fe0b07b800f1c01a499a6e8b2af548f6d0e044dca4a29d88a4bee146d131") + version("7.72.0", sha256="ad91970864102a59765e20ce16216efc9d6ad381471f7accceceab7d905703ef") + version("7.71.0", sha256="600f00ac2481a89548a4141ddf983fd9386165e1960bac91d0a1c81dca5dd341") + version("7.68.0", sha256="207f54917dd6a2dc733065ccf18d61bb5bebeaceb5df49cd9445483e8623eeb9") + version("7.64.0", sha256="d573ba1c2d1cf9d8533fadcce480d778417964e8d04ccddcc76e591d544cf2eb") + version("7.63.0", sha256="9bab7ed4ecff77020a312d84cc5fb7eb02d58419d218f267477a724a17fd8dd8") + version("7.60.0", sha256="897dfb2204bd99be328279f88f55b7c61592216b0542fcbe995c60aa92871e9b") + version("7.59.0", sha256="b5920ffd6a8c95585fb95070e0ced38322790cb335c39d0dab852d12e157b5a0") + version("7.56.0", sha256="de60a4725a3d461c70aa571d7d69c788f1816d9d1a8a2ef05f864ce8f01279df") + version("7.54.0", sha256="f50ebaf43c507fa7cc32be4b8108fa8bbd0f5022e90794388f3c7694a302ff06") + version("7.53.1", sha256="1c7207c06d75e9136a944a2e0528337ce76f15b9ec9ae4bb30d703b59bf530e8") + version("7.52.1", sha256="d16185a767cb2c1ba3d5b9096ec54e5ec198b213f45864a38b3bda4bbf87389b") + version("7.50.3", sha256="7b7347d976661d02c84a1f4d6daf40dee377efdc45b9e2c77dedb8acf140d8ec") + version("7.50.2", sha256="0c72105df4e9575d68bcf43aea1751056c1d29b1040df6194a49c5ac08f8e233") + version("7.50.1", sha256="3c12c5f54ccaa1d40abc65d672107dcc75d3e1fcb38c267484334280096e5156") + version("7.49.1", sha256="eb63cec4bef692eab9db459033f409533e6d10e20942f4b060b32819e81885f1") + version("7.47.1", sha256="ddc643ab9382e24bbe4747d43df189a0a6ce38fcb33df041b9cb0b3cd47ae98f") + version("7.46.0", sha256="b7d726cdd8ed4b6db0fa1b474a3c59ebbbe4dcd4c61ac5e7ade0e0270d3195ad") + version("7.45.0", sha256="65154e66b9f8a442b57c436904639507b4ac37ec13d6f8a48248f1b4012b98ea") + version("7.44.0", sha256="1e2541bae6582bb697c0fbae49e1d3e6fad5d05d5aa80dbd6f072e0a44341814") + version("7.43.0", sha256="baa654a1122530483ccc1c58cc112fec3724a82c11c6a389f1e6a37dc8858df9") + version("7.42.1", sha256="e2905973391ec2dfd7743a8034ad10eeb58dab8b3a297e7892a41a7999cac887") + + default_tls = "openssl" + if sys.platform == "darwin": + default_tls = "secure_transport" # TODO: add dependencies for other possible TLS backends - variant('tls', default=default_tls, description='TLS backend', - values=( - # 'amissl', - # 'bearssl', - 'gnutls', - conditional('mbedtls', when='@7.46:'), - # 'mesalink', - conditional('nss', when='@:7.81'), - 'openssl', - # 'rustls', - # 'schannel', - 'secure_transport', - # 'wolfssl', - ), - multi=True) - variant('nghttp2', default=False, description='build nghttp2 library (requires C++11)') - variant('libssh2', default=False, description='enable libssh2 support') - variant('libssh', default=False, description='enable libssh support') # , when='7.58:') - variant('gssapi', default=False, description='enable Kerberos support') - variant('librtmp', default=False, description='enable Rtmp support') - variant('ldap', default=False, description='enable ldap support') - variant('libidn2', default=False, description='enable libidn2 support') - variant('libs', default='shared,static', values=('shared', 'static'), - multi=True, description='Build shared libs, static libs or both') - - conflicts('+libssh', when='@:7.57') + variant( + "tls", + default=default_tls, + description="TLS backend", + values=( + # 'amissl', + # 'bearssl', + "gnutls", + conditional("mbedtls", when="@7.46:"), + # 'mesalink', + conditional("nss", when="@:7.81"), + "openssl", + # 'rustls', + # 'schannel', + "secure_transport", + # 'wolfssl', + ), + multi=True, + ) + variant("nghttp2", default=False, description="build nghttp2 library (requires C++11)") + variant("libssh2", default=False, description="enable libssh2 support") + variant("libssh", default=False, description="enable libssh support") # , when='7.58:') + variant("gssapi", default=False, description="enable Kerberos support") + variant("librtmp", default=False, description="enable Rtmp support") + variant("ldap", default=False, description="enable ldap support") + variant("libidn2", default=False, description="enable libidn2 support") + variant( + "libs", + default="shared,static", + values=("shared", "static"), + multi=True, + description="Build shared libs, static libs or both", + ) + + conflicts("+libssh", when="@:7.57") # on OSX and --with-ssh the configure steps fails with # one or more libs available at link-time are not available run-time # unless the libssh are installed externally (e.g. via homebrew), even # though spack isn't supposed to know about such a libssh installation. # C.f. https://github.com/spack/spack/issues/7777 - conflicts('platform=darwin', when='+libssh2') - conflicts('platform=darwin', when='+libssh') - conflicts('platform=cray', when='tls=secure_transport', msg='Only supported on macOS') - conflicts('platform=linux', when='tls=secure_transport', msg='Only supported on macOS') - - depends_on('gnutls', when='tls=gnutls') - depends_on('mbedtls@3: +pic', when='@7.79: tls=mbedtls') - depends_on('mbedtls@:2 +pic', when='@:7.78 tls=mbedtls') - depends_on('nss', when='tls=nss') - depends_on('openssl', when='tls=openssl') - depends_on('libidn2', when='+libidn2') - depends_on('zlib') - depends_on('nghttp2', when='+nghttp2') - depends_on('libssh2', when='+libssh2') - depends_on('libssh', when='+libssh') - depends_on('krb5', when='+gssapi') + conflicts("platform=darwin", when="+libssh2") + conflicts("platform=darwin", when="+libssh") + conflicts("platform=cray", when="tls=secure_transport", msg="Only supported on macOS") + conflicts("platform=linux", when="tls=secure_transport", msg="Only supported on macOS") + + depends_on("gnutls", when="tls=gnutls") + depends_on("mbedtls@3: +pic", when="@7.79: tls=mbedtls") + depends_on("mbedtls@:2 +pic", when="@:7.78 tls=mbedtls") + depends_on("nss", when="tls=nss") + depends_on("openssl", when="tls=openssl") + depends_on("libidn2", when="+libidn2") + depends_on("zlib") + depends_on("nghttp2", when="+nghttp2") + depends_on("libssh2", when="+libssh2") + depends_on("libssh", when="+libssh") + depends_on("krb5", when="+gssapi") # curl queries pkgconfig for openssl compilation flags - depends_on('pkgconfig', type='build') + depends_on("pkgconfig", type="build") @classmethod def determine_version(cls, exe): curl = Executable(exe) - output = curl('--version', output=str, error=str) - match = re.match(r'curl ([\d.]+)', output) + output = curl("--version", output=str, error=str) + match = re.match(r"curl ([\d.]+)", output) return match.group(1) if match else None @classmethod def determine_variants(cls, exes, version): for exe in exes: - variants = '' + variants = "" curl = Executable(exe) - output = curl('--version', output=str, error='str') - if 'nghttp2' in output: - variants += '+nghttp2' - protocols_match = re.search(r'Protocols: (.*)\n', output) + output = curl("--version", output=str, error="str") + if "nghttp2" in output: + variants += "+nghttp2" + protocols_match = re.search(r"Protocols: (.*)\n", output) if protocols_match: - protocols = protocols_match.group(1).strip().split(' ') - if 'ldap' in protocols: - variants += '+ldap' - features_match = re.search(r'Features: (.*)\n', output) + protocols = protocols_match.group(1).strip().split(" ") + if "ldap" in protocols: + variants += "+ldap" + features_match = re.search(r"Features: (.*)\n", output) if features_match: - features = features_match.group(1).strip().split(' ') - if 'GSS-API' in features: - variants += '+gssapi' + features = features_match.group(1).strip().split(" ") + if "GSS-API" in features: + variants += "+gssapi" # TODO: Determine TLS backend if needed. # TODO: Determine more variants. return variants @property def command(self): - return Executable(self.prefix.bin.join('curl-config')) + return Executable(self.prefix.bin.join("curl-config")) def configure_args(self): spec = self.spec args = [ - '--with-zlib=' + spec['zlib'].prefix, + "--with-zlib=" + spec["zlib"].prefix, # Prevent unintentional linking against system libraries: we could # add variants for these in the future - '--without-brotli', - '--without-libgsasl', - '--without-libpsl', - '--without-zstd', + "--without-brotli", + "--without-libgsasl", + "--without-libpsl", + "--without-zstd", ] - args += self.enable_or_disable('libs') + args += self.enable_or_disable("libs") # Make gnutls / openssl decide what certs are trusted. # TODO: certs for other tls options. - if spec.satisfies('tls=gnutls') or spec.satisfies('tls=openssl'): - args.extend([ - '--without-ca-bundle', - '--without-ca-path', - '--with-ca-fallback', - ]) + if spec.satisfies("tls=gnutls") or spec.satisfies("tls=openssl"): + args.extend( + [ + "--without-ca-bundle", + "--without-ca-path", + "--with-ca-fallback", + ] + ) # https://daniel.haxx.se/blog/2021/06/07/bye-bye-metalink-in-curl/ # We always disable it explicitly, but the flag is gone in newer # versions. - if spec.satisfies('@:7.77'): - args.append('--without-libmetalink') + if spec.satisfies("@:7.77"): + args.append("--without-libmetalink") - if spec.satisfies('+gssapi'): - args.append('--with-gssapi=' + spec['krb5'].prefix) + if spec.satisfies("+gssapi"): + args.append("--with-gssapi=" + spec["krb5"].prefix) else: - args.append('--without-gssapi') + args.append("--without-gssapi") - args += self.with_or_without('tls') - args += self.with_or_without('libidn2', 'prefix') - args += self.with_or_without('librtmp') - args += self.with_or_without('nghttp2') - args += self.with_or_without('libssh2') - args += self.with_or_without('libssh') - args += self.enable_or_disable('ldap') + args += self.with_or_without("tls") + args += self.with_or_without("libidn2", "prefix") + args += self.with_or_without("librtmp") + args += self.with_or_without("nghttp2") + args += self.with_or_without("libssh2") + args += self.with_or_without("libssh") + args += self.enable_or_disable("ldap") return args def with_or_without_gnutls(self, activated): if activated: - return '--with-gnutls=' + self.spec['gnutls'].prefix + return "--with-gnutls=" + self.spec["gnutls"].prefix else: - return '--without-gnutls' + return "--without-gnutls" def with_or_without_mbedtls(self, activated): - if self.spec.satisfies('@7.46:'): + if self.spec.satisfies("@7.46:"): if activated: - return '--with-mbedtls=' + self.spec['mbedtls'].prefix + return "--with-mbedtls=" + self.spec["mbedtls"].prefix else: - return '--without-mbedtls' + return "--without-mbedtls" def with_or_without_nss(self, activated): if activated: - return '--with-nss=' + self.spec['nss'].prefix + return "--with-nss=" + self.spec["nss"].prefix else: - return '--without-nss' + return "--without-nss" def with_or_without_openssl(self, activated): - if self.spec.satisfies('@7.77:'): + if self.spec.satisfies("@7.77:"): if activated: - return '--with-openssl=' + self.spec['openssl'].prefix + return "--with-openssl=" + self.spec["openssl"].prefix else: - return '--without-openssl' + return "--without-openssl" else: if activated: - return '--with-ssl=' + self.spec['openssl'].prefix + return "--with-ssl=" + self.spec["openssl"].prefix else: - return '--without-ssl' + return "--without-ssl" def with_or_without_secure_transport(self, activated): - if self.spec.satisfies('@7.65:'): + if self.spec.satisfies("@7.65:"): if activated: - return '--with-secure-transport' + return "--with-secure-transport" else: - return '--without-secure-transport' + return "--without-secure-transport" else: if activated: - return '--with-darwinssl' + return "--with-darwinssl" else: - return '--without-darwinssl' + return "--without-darwinssl" |