# Copyright 1999-2021 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI=6 inherit flag-o-matic libtool toolchain-funcs multilib MY_PN=imap MY_P="${MY_PN}-${PV}" S=${WORKDIR}/${MY_P} CHAPPA_PL=115 DESCRIPTION="UW IMAP c-client library" HOMEPAGE="http://www.washington.edu/imap/" SRC_URI="ftp://ftp.cac.washington.edu/imap/${MY_P}.tar.Z chappa? ( mirror://gentoo/${P}-chappa-${CHAPPA_PL}-all.patch.gz )" LICENSE="Apache-2.0" SLOT="0" KEYWORDS="~alpha amd64 arm arm64 ~hppa ~ia64 ~mips ppc ppc64 ~s390 sparc x86" IUSE="doc +ipv6 kerberos kernel_linux kernel_FreeBSD libressl pam ssl static-libs topal chappa" RDEPEND=" ssl? ( !libressl? ( dev-libs/openssl:0= ) libressl? ( dev-libs/libressl:0= ) ) !net-mail/uw-imap kerberos? ( app-crypt/mit-krb5 ) " DEPEND="${RDEPEND} kernel_linux? ( pam? ( >=sys-libs/pam-0.72 ) ) " PATCHES=( # Apply a patch to only build the stuff we need for c-client "${FILESDIR}/${PN}-2006k_GENTOO_Makefile.patch" # Apply patch to add the compilation of a .so for PHP # This was previously conditional, but is more widely useful. "${FILESDIR}/${PN}-2006k_GENTOO_amd64-so-fix.patch" # Respect LDFLAGS "${FILESDIR}/${PN}-2007f-ldflags.patch" # openssl-1.1 build fix #647616 "${FILESDIR}/${PN}-2007f-openssl-1.1.patch" ) src_prepare() { use topal && PATCHES+=( "${FILESDIR}/${P}-topal.patch" ) default use chappa && eapply -p2 "${WORKDIR}/${P}-chappa-${CHAPPA_PL}-all.patch" # Tarball packed with bad file perms chmod -R u+rwX,go-w . || die "failed to fix permissions" # lots of things need -fPIC, including various platforms, and this library # generally should be built with it anyway. append-flags -fPIC # Modifications so we can build it optimally and correctly sed \ -e "s:BASECFLAGS=\".*\":BASECFLAGS=:g" \ -e 's:SSLDIR=/usr/local/ssl:SSLDIR=/usr:g' \ -e 's:SSLCERTS=$(SSLDIR)/certs:SSLCERTS=/etc/ssl/certs:g' \ -i src/osdep/unix/Makefile \ || die "failed to fix compiler flags and SSL paths in the Makefile" # Make the build system more multilib aware sed \ -e "s:^SSLLIB=\$(SSLDIR)/lib:SSLLIB=\$(SSLDIR)/$(get_libdir):" \ -e "s:^AFSLIB=\$(AFSDIR)/lib:AFSLIB=\$(AFSDIR)/$(get_libdir):" \ -i src/osdep/unix/Makefile \ || die "failed to fix our libdir in the Makefile" # Targets should use the Gentoo (ie linux) fs sed -e '/^bsf:/,/^$/ s:ACTIVEFILE=.*:ACTIVEFILE=/var/lib/news/active:g' \ -i src/osdep/unix/Makefile \ || die "failed to fix the FreeBSD ACTIVEFILE path in the Makefile" # Remove the pesky checks about SSL stuff sed -e '/read.*exit/d' -i Makefile \ || die "failed to disable SSL warning in the Makefile" sed -e "s:CC=cc:CC=$(tc-getCC):" \ -e "s:ARRC=ar:ARRC=$(tc-getAR):" \ -e "s:RANLIB=ranlib:RANLIB=$(tc-getRANLIB):" \ -i src/osdep/unix/Makefile \ || die "failed to fix build flags support in the Makefile" elibtoolize } src_compile() { local mymake ipver ssltype target passwdtype ipver='IP=4' if use ipv6 ; then ipver="IP=6" touch ip6 || die "failed to create ip6 file" fi use ssl && ssltype="unix" || ssltype="none" if use kernel_linux ; then # Fall back to "slx" when USE=pam is not set. This ensures that # we link in libcrypt to get the crypt() routine (bug #456928). use pam && target=lnp passwdtype=pam || target=slx passwdtype=std elif use kernel_FreeBSD ; then target=bsf passwdtype=pam fi use kerberos \ && mymake="EXTRAAUTHENTICATORS=gss" \ && EXTRALIBS="-lgssapi_krb5 -lkrb5 -lk5crypto -lcom_err" \ # no parallel builds supported! emake -j1 SSLTYPE=${ssltype} $target \ PASSWDTYPE=${passwdtype} ${ipver} ${mymake} \ EXTRACFLAGS="${CFLAGS}" \ EXTRALDFLAGS="${LDFLAGS}" \ EXTRALIBS="${EXTRALIBS}" \ GSSDIR=/usr } src_install() { if use static-libs; then # Library binary dolib.a c-client/c-client.a dosym c-client.a "/usr/$(get_libdir)/libc-client.a" fi # Now the shared library dolib.so c-client/libc-client.so.1.0.0 dosym libc-client.so.1.0.0 "/usr/$(get_libdir)/libc-client.so" dosym libc-client.so.1.0.0 "/usr/$(get_libdir)/libc-client.so.1" # Headers insinto /usr/include/imap doins src/osdep/unix/*.h doins src/c-client/*.h doins c-client/linkage.h doins c-client/linkage.c doins c-client/osdep.h if use ssl; then echo " ssl_onceonlyinit ();" >> "${D}"/usr/include/imap/linkage.c \ || die "failed to add ssl init statement to linkage.c" fi # Documentation dodoc README docs/*.txt docs/BUILD docs/CONFIG docs/RELNOTES docs/SSLBUILD if use doc; then docinto rfc dodoc docs/rfc/*.txt docinto draft dodoc docs/draft/* fi }