gnupg-2.4.7.ebuild (5060B)
1 # Copyright 1999-2024 Gentoo Authors 2 # Distributed under the terms of the GNU General Public License v2 3 4 EAPI=8 5 6 # Maintainers should: 7 # 1. Join the "Gentoo" project at https://dev.gnupg.org/project/view/27/ 8 # 2. Subscribe to release tasks like https://dev.gnupg.org/T6159 9 # (find the one for the current release then subscribe to it + 10 # any subsequent ones linked within so you're covered for a while.) 11 12 VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/gnupg.asc 13 # in-source builds are not supported: https://dev.gnupg.org/T6313#166339 14 inherit flag-o-matic out-of-source multiprocessing systemd toolchain-funcs verify-sig 15 16 MY_P="${P/_/-}" 17 18 DESCRIPTION="The GNU Privacy Guard, a GPL OpenPGP implementation" 19 HOMEPAGE="https://gnupg.org/" 20 SRC_URI="mirror://gnupg/gnupg/${MY_P}.tar.bz2" 21 SRC_URI+=" verify-sig? ( mirror://gnupg/gnupg/${P}.tar.bz2.sig )" 22 S="${WORKDIR}/${MY_P}" 23 24 LICENSE="GPL-3+" 25 SLOT="0" 26 KEYWORDS="~alpha amd64 arm arm64 ~hppa ~ia64 ~loong ~m68k ~mips ppc~ppc64 ~riscv ~s390 sparc x86 ~amd64-linux ~x86-linux ~arm64-macos ~ppc-macos ~x64-macos ~x64-solaris" 27 IUSE="bzip2 doc ldap nls readline selinux +smartcard ssl test +tofu tpm tools usb user-socket wks-server" 28 RESTRICT="!test? ( test )" 29 REQUIRED_USE="test? ( tofu )" 30 31 # Existence of executables is checked during configuration. 32 # Note: On each bump, update dep bounds on each version from configure.ac! 33 DEPEND=" 34 >=dev-libs/libassuan-2.5.0:= 35 >=dev-libs/libgcrypt-1.9.1:= 36 >=dev-libs/libgpg-error-1.46 37 >=dev-libs/libksba-1.6.3 38 >=dev-libs/npth-1.2 39 >=net-misc/curl-7.10 40 sys-libs/zlib 41 bzip2? ( app-arch/bzip2 ) 42 ldap? ( net-nds/openldap:= ) 43 readline? ( sys-libs/readline:0= ) 44 smartcard? ( usb? ( virtual/libusb:1 ) ) 45 tofu? ( >=dev-db/sqlite-3.27 ) 46 tpm? ( >=app-crypt/tpm2-tss-2.4.0:= ) 47 ssl? ( >=net-libs/gnutls-3.2:0= ) 48 " 49 RDEPEND=" 50 ${DEPEND} 51 nls? ( virtual/libintl ) 52 selinux? ( sec-policy/selinux-gpg ) 53 wks-server? ( virtual/mta ) 54 " 55 PDEPEND=" 56 || ( 57 app-crypt/pinentry 58 app-crypt/pinentry-dmenu 59 ) 60 " 61 BDEPEND=" 62 virtual/pkgconfig 63 doc? ( sys-apps/texinfo ) 64 nls? ( sys-devel/gettext ) 65 verify-sig? ( sec-keys/openpgp-keys-gnupg ) 66 " 67 68 DOCS=( 69 ChangeLog NEWS README THANKS TODO VERSION 70 doc/FAQ doc/DETAILS doc/HACKING doc/TRANSLATE doc/OpenPGP doc/KEYSERVER 71 ) 72 73 PATCHES=( 74 "${FILESDIR}"/${PN}-2.1.20-gpgscm-Use-shorter-socket-path-lengts-to-improve-tes.patch 75 "${FILESDIR}"/${PN}-2.4.5-revert-rfc4880bis.patch # bug #926186 76 ) 77 78 src_prepare() { 79 default 80 } 81 82 my_src_configure() { 83 # Upstream don't support LTO, bug #854222. 84 filter-lto 85 86 local myconf=( 87 $(use_enable bzip2) 88 $(use_enable nls) 89 $(use_enable smartcard scdaemon) 90 $(use_enable ssl gnutls) 91 $(use_enable test all-tests) 92 $(use_enable test tests) 93 $(use_enable tofu) 94 $(use_enable tofu keyboxd) 95 $(use_enable tofu sqlite) 96 $(usex tpm '--with-tss=intel' '--disable-tpm2d') 97 $(use smartcard && use_enable usb ccid-driver || echo '--disable-ccid-driver') 98 $(use_enable wks-server wks-tools) 99 $(use_with ldap) 100 $(use_with readline) 101 102 # Hardcode mailprog to /usr/libexec/sendmail even if it does not exist. 103 # As of GnuPG 2.3, the mailprog substitution is used for the binary called 104 # by wks-client & wks-server; and if it's autodetected but not not exist at 105 # build time, then then 'gpg-wks-client --send' functionality will not 106 # work. This has an unwanted side-effect in stage3 builds: there was a 107 # [R]DEPEND on virtual/mta, which also brought in virtual/logger, bloating 108 # the build where the install guide previously make the user chose the 109 # logger & mta early in the install. 110 --with-mailprog=/usr/libexec/sendmail 111 112 --disable-ntbtls 113 --enable-gpgsm 114 --enable-large-secmem 115 116 CC_FOR_BUILD="$(tc-getBUILD_CC)" 117 GPGRT_CONFIG="${ESYSROOT}/usr/bin/${CHOST}-gpgrt-config" 118 119 $("${S}/configure" --help | grep -o -- '--without-.*-prefix') 120 ) 121 122 if use prefix && use usb; then 123 # bug #649598 124 append-cppflags -I"${ESYSROOT}/usr/include/libusb-1.0" 125 fi 126 127 if [[ ${CHOST} == *-solaris* ]] ; then 128 # https://dev.gnupg.org/T7368 129 export ac_cv_should_define__xopen_source=yes 130 fi 131 132 # bug #663142 133 if use user-socket; then 134 myconf+=( --enable-run-gnupg-user-socket ) 135 fi 136 137 # glib fails and picks up clang's internal stdint.h causing weird errors 138 tc-is-clang && export gl_cv_absolute_stdint_h="${ESYSROOT}"/usr/include/stdint.h 139 140 econf "${myconf[@]}" 141 } 142 143 my_src_compile() { 144 default 145 146 use doc && emake -C doc html 147 } 148 149 my_src_test() { 150 export TESTFLAGS="--parallel=$(makeopts_jobs)" 151 152 default 153 } 154 155 my_src_install() { 156 emake DESTDIR="${D}" install 157 158 use tools && dobin tools/{gpgconf,gpgsplit,gpg-check-pattern} tools/make-dns-cert 159 160 dosym gpg /usr/bin/gpg2 161 dosym gpgv /usr/bin/gpgv2 162 echo ".so man1/gpg.1" > "${ED}"/usr/share/man/man1/gpg2.1 || die 163 echo ".so man1/gpgv.1" > "${ED}"/usr/share/man/man1/gpgv2.1 || die 164 165 dodir /etc/env.d 166 echo "CONFIG_PROTECT=/usr/share/gnupg/qualified.txt" >> "${ED}"/etc/env.d/30gnupg || die 167 168 use doc && dodoc doc/gnupg.html/* 169 } 170 171 my_src_install_all() { 172 einstalldocs 173 174 use tools && dobin tools/{convert-from-106,mail-signed-keys,lspgpot} 175 use doc && dodoc doc/*.png 176 }