1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
|
# Copyright 1999-2005 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/app-crypt/gnupg/gnupg-1.4.2-r3.ebuild,v 1.7 2005/11/28 22:31:08 dragonheart Exp $
inherit eutils flag-o-matic linux-info
ECCVER=0.1.6
ECCVER_GNUPG=1.4.0
DESCRIPTION="The GNU Privacy Guard, a GPL pgp replacement"
HOMEPAGE="http://www.gnupg.org/"
SRC_URI="mirror://gnupg/gnupg/${P}.tar.bz2
idea? ( ftp://ftp.gnupg.dk/pub/contrib-dk/idea.c.gz )
ecc? ( http://alumnes.eps.udl.es/%7Ed4372211/src/${PN}-${ECCVER_GNUPG}-ecc${ECCVER}.diff.bz2 )"
LICENSE="GPL-2"
SLOT="0"
KEYWORDS="~alpha amd64 ~arm hppa ~ia64 ~mips ~ppc ~ppc-macos ppc64 ~s390 sparc x86"
IUSE="bzip2 caps curl ecc idea ldap nls readline selinux smartcard static usb zlib X"
COMMON_DEPEND="
ldap? ( net-nds/openldap )
bzip2? ( app-arch/bzip2 )
zlib? ( sys-libs/zlib )
nls? ( sys-devel/gettext )
curl? ( net-misc/curl )
virtual/libc
virtual/mta
readline? ( sys-libs/readline )
smartcard? ( dev-libs/libusb )
usb? ( dev-libs/libusb )"
RDEPEND="!static? (
${COMMON_DEPEND}
X? ( || ( media-gfx/xloadimage media-gfx/xli ) )
)
selinux? ( sec-policy/selinux-gnupg )"
DEPEND="${COMMON_DEPEND}
dev-lang/perl"
pkg_setup() {
# fix bug #113474 - no compiled kernel needed now
get_running_version
}
src_unpack() {
unpack ${A}
# Jari's patch to boost iterated key setup by factor of 128
EPATCH_OPTS="-p1 -d ${S}" epatch ${FILESDIR}/${P}-jari.patch
if use idea; then
ewarn "Please read http://www.gnupg.org/why-not-idea.html"
mv ${WORKDIR}/idea.c ${S}/cipher/idea.c || \
ewarn "failed to insert IDEA module"
fi
if use ecc; then
# this trickery is because the only reject in the 1.4.0 patch is the
# version number!
local eccpatch=${WORKDIR}/${PN}-${ECCVER_GNUPG}-ecc${ECCVER}.diff
if [ "${ECCVER_GNUPG}" != "${PV}" ]; then
einfo "Tweaking PV in ECC patch"
sed -i "s/ VERSION='${ECCVER_GNUPG}/ VERSION='${PV}/g" $eccpatch
fi
EPATCH_OPTS="-p1 -d ${S}" epatch $eccpatch
fi
# maketest fix
epatch ${FILESDIR}/${P}-selftest.patch
# install RU man page in right location
epatch ${FILESDIR}/${P}-badruman.patch
cd ${S}
# keyserver fix
epatch ${FILESDIR}/${P}-keyserver.patch
epatch ${FILESDIR}/${P}-mpicoder.patch
# Fix PIC definitions
sed -i -e 's:PIC:__PIC__:' mpi/i386/mpih-{add,sub}1.S intl/relocatable.c
sed -i -e 's:if PIC:ifdef __PIC__:' mpi/sparc32v8/mpih-mul{1,2}.S
}
src_compile() {
# Certain sparc32 machines seem to have trouble building correctly with
# -mcpu enabled. While this is not a gnupg problem, it is a temporary
# fix until the gcc problem can be tracked down.
if [ "${ARCH}" == "sparc" ] && [ "${PROFILE_ARCH}" == "sparc" ]; then
filter-flags -mcpu=supersparc -mcpu=v8 -mcpu=v7
fi
# 'USE=static' support was requested in #29299
use static &&append-ldflags -static
# Still needed?
# Bug #6387, --enable-m-guard causes bus error on sparcs
use sparc || myconf="${myconf} --enable-m-guard"
use ppc-macos || append-ldflags -Wl,-z,now
# configure doesn't trean --disable-asm correctly
use x86 && myconf="${myconf} --enable-asm"
# fix compile problem on ppc64
use ppc64 && myconf="${myconf} --disable-asm"
econf \
$(use_enable ldap) \
--enable-mailto \
--enable-hkp \
--enable-finger \
$(use_with !zlib included-zlib) \
$(use_with curl libcurl /usr) \
$(use_enable nls) \
$(use_enable bzip2) \
$(use_enable smartcard card-support) \
$(use_enable selinux selinux-support) \
$(use_with caps capabilities) \
$(use_with readline) \
$(use_with usb libusb /usr) \
$(use_enable static) \
$(use_enable X photo-viewers) \
--enable-static-rnd=linux \
--libexecdir=/usr/libexec \
--enable-sha512 \
${myconf} || die
# this is because it will run some tests directly
gnupg_fixcheckperms
emake || die
}
src_install() {
gnupg_fixcheckperms
make DESTDIR=${D} install || die
# caps support makes life easier
if ! use caps && kernel_is lt 2 6 9
then
ewarn "installing gpg suid for memory space protection"
fperms u+s,go-r /usr/bin/gpg
fi
# keep the documentation in /usr/share/doc/...
rm -rf "${D}/usr/share/gnupg/FAQ" "${D}/usr/share/gnupg/faq.html"
dodoc AUTHORS BUGS ChangeLog NEWS PROJECTS README THANKS \
TODO VERSION doc/{FAQ,HACKING,DETAILS,ChangeLog,OpenPGP,faq.raw}
docinto sgml
dodoc doc/*.sgml
dohtml doc/faq.html
# install RU documentation in right location
if use linguas_ru
then
cp doc/gpg.ru.1 ${T}/gpg.1
doman -i18n=ru ${T}/gpg.1
fi
# Remove collissions
if use ppc-macos; then
rm ${D}/usr/lib/charset.alias ${D}/usr/share/locale/locale.alias
fi
}
gnupg_fixcheckperms() {
# GnuPG does weird things for testing that it build correctly
# as we as for the additional tests. It WILL fail with perms 770 :-(.
# See bug #80044
if has userpriv ${FEATURES}; then
einfo "Fixing permissions in check directory"
chown -R portage:portage ${S}/checks
chmod -R ugo+rw ${S}/checks
chmod ugo+rw ${S}/checks
fi
}
src_test() {
gnupg_fixcheckperms
einfo "Running tests"
emake check
ret=$?
if [ $ret -ne 0 ]; then
die "Some tests failed! Please report to the Gentoo Bugzilla"
fi
}
pkg_postinst() {
if ! use caps && kernel_is lt 2 6 9
then
chmod u+s,go-r ${ROOT}/usr/bin/gpg
einfo "gpg is installed suid root to make use of protected memory space"
einfo "This is needed in order to have a secure place to store your"
einfo "passphrases, etc. at runtime but may make some sysadmins nervous."
else
chmod u-s,go-r ${ROOT}/usr/bin/gpg
fi
echo
if use idea; then
einfo "-----------------------------------------------------------------------------------"
einfo "IDEA"
ewarn "you have compiled ${PN} with support for the IDEA algorithm, this code"
ewarn "is distributed under the GPL in countries where it is permitted to do so"
ewarn "by law."
einfo
einfo "Please read http://www.gnupg.org/why-not-idea.html for more information."
einfo
ewarn "If you are in a country where the IDEA algorithm is patented, you are permitted"
ewarn "to use it at no cost for 'non revenue generating data transfer between private"
ewarn "individuals'."
einfo
einfo "Countries where the patent applies are listed here"
einfo "http://www.mediacrypt.com/_contents/10_idea/101030_ea_pi.asp"
einfo
einfo "Further information and other licenses are availble from http://www.mediacrypt.com/"
einfo "-----------------------------------------------------------------------------------"
fi
if use ecc; then
einfo
ewarn "The elliptical curves patch is experimental"
einfo "Further info available at http://alumnes.eps.udl.es/%7Ed4372211/index.en.html"
fi
if use caps; then
einfo
ewarn "Capabilities code is experimental"
fi
einfo
einfo "See http://www.gentoo.org/doc/en/gnupg-user.xml for documentation on gnupg"
einfo
}
|