diff options
Diffstat (limited to 'libre/openssl-static/PKGBUILD')
-rw-r--r-- | libre/openssl-static/PKGBUILD | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/libre/openssl-static/PKGBUILD b/libre/openssl-static/PKGBUILD new file mode 100644 index 000000000..d4b15641e --- /dev/null +++ b/libre/openssl-static/PKGBUILD @@ -0,0 +1,78 @@ +# Maintainer: Márcio Silva <coadde@parabola.nu> +# based of openssl + +_pkgname=openssl +pkgname=openssl-static +_ver=1.0.2g +# use a pacman compatible version scheme +pkgver=${_ver/[a-z]/.${_ver//[0-9.]/}} +#pkgver=$_ver +pkgrel=3 +pkgdesc='The Open Source toolkit for Secure Sockets Layer and Transport Layer Security (static libraries only)' +arch=('i686' 'x86_64' 'armv7h') +url='https://www.openssl.org' +license=('custom:BSD') +depends=('perl-static' 'openssl') +options=('!makeflags' 'staticlibs') +source=("https://www.openssl.org/source/${_pkgname}-${_ver}.tar.gz" + "https://www.openssl.org/source/${_pkgname}-${_ver}.tar.gz.asc" + 'no-rpath.patch' + 'ssl3-test-failure.patch' + 'ca-dir.patch') +md5sums=('f3c710c045cdee5fd114feb69feba7aa' + 'SKIP' + 'dc78d3d06baffc16217519242ce92478' + '62fc492252edd3283871632bb77fadbe' + '3bf51be3a1bbd262be46dc619f92aa90') +validpgpkeys=('8657ABB260F056B1E5190839D9C4D26D0E604491') + +prepare() { + cd $srcdir/$_pkgname-$_ver + + # remove rpath: http://bugs.archlinux.org/task/14367 + patch -p0 -i $srcdir/no-rpath.patch + + # disable a test that fails when ssl3 is disabled + patch -p1 -i $srcdir/ssl3-test-failure.patch + + # set ca dir to /etc/ssl by default + patch -p0 -i $srcdir/ca-dir.patch +} + +build() { + cd $srcdir/$_pkgname-$_ver + + if [ "${CARCH}" == 'x86_64' ]; then + openssltarget='linux-x86_64' + optflags='enable-ec_nistp_64_gcc_128' + elif [ "${CARCH}" == 'i686' ]; then + openssltarget='linux-elf' + optflags='' + fi + + # mark stack as non-executable: http://bugs.archlinux.org/task/12434 + ./Configure --prefix=/usr --libdir=lib \ + no-ssl3-method ${optflags} \ + "${openssltarget}" \ + "-Wa,--noexecstack ${CPPFLAGS} ${CFLAGS} ${LDFLAGS}" + + make depend + make +} + +check() { + cd $srcdir/$_pkgname-$_ver + # the test fails due to missing write permissions in /etc/ssl + # revert this patch for make test + patch -p0 -R -i $srcdir/ca-dir.patch + make test + patch -p0 -i $srcdir/ca-dir.patch +} + +package() { + cd $srcdir/$_pkgname-$_ver + make INSTALL_PREFIX=$pkgdir install + + # remove conflicting files + rm -vr ${pkgdir}/usr/{bin,include,lib/pkgconfig,ssl} +} |