diff options
author | alalazo <massimiliano.culpo@googlemail.com> | 2016-01-28 11:26:01 +0100 |
---|---|---|
committer | alalazo <massimiliano.culpo@googlemail.com> | 2016-01-28 11:26:01 +0100 |
commit | e76b722e28eedd94277e5d8ea42beeb5a8d5048e (patch) | |
tree | 647b1eb7202d973cadb0bf16bb3797da679cccdd /var/spack/repos/builtin/packages/openssl/package.py | |
parent | bf4231dd4b906f20d522b9df5f2cae2ba6291174 (diff) | |
parent | c2bb00ca2f925c1a8c4b49f7b0a7b22e7c0b43a8 (diff) | |
download | spack-e76b722e28eedd94277e5d8ea42beeb5a8d5048e.tar.gz spack-e76b722e28eedd94277e5d8ea42beeb5a8d5048e.tar.bz2 spack-e76b722e28eedd94277e5d8ea42beeb5a8d5048e.tar.xz spack-e76b722e28eedd94277e5d8ea42beeb5a8d5048e.zip |
Merge branch 'develop' of https://github.com/LLNL/spack into enhancement/os_detection
Diffstat (limited to 'var/spack/repos/builtin/packages/openssl/package.py')
-rw-r--r-- | var/spack/repos/builtin/packages/openssl/package.py | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/var/spack/repos/builtin/packages/openssl/package.py b/var/spack/repos/builtin/packages/openssl/package.py new file mode 100644 index 0000000000..8f0427796b --- /dev/null +++ b/var/spack/repos/builtin/packages/openssl/package.py @@ -0,0 +1,55 @@ +from spack import * + +import spack.util.architecture as arch + +class Openssl(Package): + """The OpenSSL Project is a collaborative effort to develop a + robust, commercial-grade, full-featured, and Open Source + toolkit implementing the Secure Sockets Layer (SSL v2/v3) and + Transport Layer Security (TLS v1) protocols as well as a + full-strength general purpose cryptography library.""" + homepage = "http://www.openssl.org" + url = "http://www.openssl.org/source/openssl-1.0.1h.tar.gz" + + version('1.0.1h', '8d6d684a9430d5cc98a62a5d8fbda8cf') + version('1.0.2d', '38dd619b2e77cbac69b99f52a053d25a') + version('1.0.2e', '5262bfa25b60ed9de9f28d5d52d77fc5') + + depends_on("zlib") + parallel = False + + def install(self, spec, prefix): + # OpenSSL uses a variable APPS in its Makefile. If it happens to be set + # in the environment, then this will override what is set in the + # Makefile, leading to build errors. + env.pop('APPS', None) + if spec.satisfies("=darwin-x86_64") or spec.satisfies("=ppc64"): + # This needs to be done for all 64-bit architectures (except Linux, + # where it happens automatically?) + env['KERNEL_BITS'] = '64' + config = Executable("./config") + config("--prefix=%s" % prefix, + "--openssldir=%s" % join_path(prefix, 'etc', 'openssl'), + "zlib", + "no-krb5", + "shared") + # Remove non-standard compiler options if present. These options are + # present e.g. on Darwin. They are non-standard, i.e. most compilers + # (e.g. gcc) will not accept them. + filter_file(r'-arch x86_64', '', 'Makefile') + + make() + make("install") + + @when(arch.os_is_in('darwin')) + def install(self, spec, prefix): + perl = which('perl') + perl("./Configure", + "--prefix=%s" % prefix, + "--openssldir=%s/etc/openssl" % prefix, + "zlib", + "no-krb5", + "shared", + "darwin64-x86_64-cc") + filter_file(r'-arch x86_64', '', 'Makefile') + |