summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/curl/package.py
diff options
context:
space:
mode:
authorTodd Gamblin <tgamblin@llnl.gov>2022-07-30 15:19:18 -0700
committerTodd Gamblin <tgamblin@llnl.gov>2022-07-31 13:29:20 -0700
commitf52f6e99dbf1131886a80112b8c79dfc414afb7c (patch)
tree05cb7d64b2395922f2f24683da49f472075be12c /var/spack/repos/builtin/packages/curl/package.py
parent549ba1ed32372c67fc57271cde3797d58b7dec6e (diff)
downloadspack-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.py295
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"