blob: 726dab6f521c503370d6ed12bb8798261e613d7b (
plain)
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
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
|
# Copyright 2004-2024 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
PYTHON_COMPAT=( python3_{10..12} )
# NEED_BOOTSTRAP is for developers to quickly generate a tarball
# for publishing to the tree.
NEED_BOOTSTRAP="no"
inherit crossdev multibuild multilib python-any-r1 flag-o-matic toolchain-funcs multilib-minimal
DESCRIPTION="Extended crypt library for descrypt, md5crypt, bcrypt, and others"
HOMEPAGE="https://github.com/besser82/libxcrypt"
if [[ ${NEED_BOOTSTRAP} == "yes" ]] ; then
inherit autotools
SRC_URI="https://github.com/besser82/libxcrypt/releases/download/v${PV}/${P}.tar.xz"
else
SRC_URI="https://dev.gentoo.org/~sam/distfiles/${CATEGORY}/${PN}/${P}-autotools.tar.xz"
fi
LICENSE="LGPL-2.1+ public-domain BSD BSD-2"
SLOT="0/1"
KEYWORDS="~alpha amd64 arm arm64 ~hppa ~ia64 ~loong ~m68k ~mips ppc ppc64 ~riscv ~s390 ~sparc x86"
IUSE="+compat static-libs +system test headers-only"
RESTRICT="!test? ( test )"
DEPEND="
system? (
elibc_glibc? (
${CATEGORY}/glibc[-crypt(-)]
!${CATEGORY}/glibc[crypt(-)]
)
elibc_musl? (
${CATEGORY}/musl[-crypt(+)]
!${CATEGORY}/musl[crypt(+)]
)
)
"
RDEPEND="${DEPEND}"
BDEPEND="
dev-lang/perl
test? ( $(python_gen_any_dep 'dev-python/passlib[${PYTHON_USEDEP}]') )
"
python_check_deps() {
python_has_version "dev-python/passlib[${PYTHON_USEDEP}]"
}
pkg_pretend() {
if has "distcc" ${FEATURES} ; then
ewarn "Please verify all distcc nodes are using the same versions of GCC (>= 10) and Binutils!"
ewarn "Older/mismatched versions of GCC may lead to a misbehaving library: bug #823179."
if [[ ${BUILD_TYPE} != "binary" ]] && tc-is-gcc && [[ $(gcc-major-version) -lt 10 ]] ; then
die "libxcrypt is known to fail to build or be broken at runtime with < GCC 10 (bug #823179)!"
fi
fi
}
pkg_setup() {
:
}
src_prepare() {
default
# WARNING: Please read on bumping or applying patches!
#
# There are two circular dependencies to be aware of:
# 1)
# if we're bootstrapping configure and makefiles:
# libxcrypt -> automake -> perl -> libxcrypt
#
# mitigation:
# toolchain@ manually runs `make dist` after running autoconf + `./configure`
# and the ebuild uses that.
# (Don't include the pre-generated Perl artefacts.)
#
# solution for future:
# Upstream are working on producing `make dist` tarballs.
# https://github.com/besser82/libxcrypt/issues/134#issuecomment-871833573
#
# 2)
# configure *unconditionally* needs Perl at build time to generate
# a list of enabled algorithms based on the set passed to `configure`:
# libxcrypt -> perl -> libxcrypt
#
# mitigation:
# None at the moment.
#
# solution for future:
# Not possible right now. Upstream intend on depending on Perl for further
# configuration options.
# https://github.com/besser82/libxcrypt/issues/134#issuecomment-871833573
#
# Therefore, on changes (inc. bumps):
# * You must check whether upstream have started providing tarballs with bootstrapped
# auto{conf,make};
#
# * diff the build system changes!
#
if [[ ${NEED_BOOTSTRAP} == "yes" ]] ; then
# Facilitate our split variant build for compat + non-compat
eapply "${FILESDIR}"/${PN}-4.4.19-multibuild.patch
eautoreconf
fi
}
src_configure() {
MULTIBUILD_VARIANTS=(
$(usev compat 'xcrypt_compat')
xcrypt_nocompat
)
MYPREFIX=${EPREFIX}
MYSYSROOT=${ESYSROOT}
if target_is_not_host; then
local CHOST=${CTARGET}
MYPREFIX=
MYSYSROOT=${ESYSROOT}/usr/${CTARGET}
# Ensure we get compatible libdir
unset DEFAULT_ABI MULTILIB_ABIS
multilib_env
ABI=${DEFAULT_ABI}
tc-getCC >/dev/null
if [[ ${CC} != ${CHOST}-* ]]; then
unset CC
tc-getCC >/dev/null
fi
strip-unsupported-flags
fi
if use headers-only; then
# Nothing is compiled here which would affect the headers for the target.
# So forcing CC is sane.
local -x CC="$(tc-getBUILD_CC)"
fi
# Avoid possible "illegal instruction" errors with gold
# bug #821496
tc-ld-disable-gold
# Doesn't work with LTO: bug #852917.
# https://github.com/besser82/libxcrypt/issues/24
filter-lto
append-ldflags $(test-flags-CCLD -Wl,--undefined-version)
if use test; then
python_setup
fi
multibuild_foreach_variant multilib-minimal_src_configure
}
multilib_src_configure() {
local myconf=(
--disable-werror
--prefix="${MYPREFIX}/usr"
--libdir="${MYPREFIX}/usr/$(get_libdir)$(usev !system /xcrypt)"
--includedir="${MYPREFIX}/usr/include$(usev !system /xcrypt)"
--with-pkgconfigdir="${MYPREFIX}/usr/$(get_libdir)/pkgconfig"
--with-sysroot="${MYSYSROOT}"
)
tc-export PKG_CONFIG
case "${MULTIBUILD_ID}" in
xcrypt_compat-*)
myconf+=(
--disable-static
--disable-xcrypt-compat-files
--enable-obsolete-api=yes
)
;;
xcrypt_nocompat-*)
myconf+=(
--enable-obsolete-api=no
$(use_enable static-libs static)
)
;;
*) die "Unexpected MULTIBUILD_ID: ${MULTIBUILD_ID}";;
esac
ECONF_SOURCE="${S}" econf "${myconf[@]}"
}
src_compile() {
use headers-only && return
multibuild_foreach_variant multilib-minimal_src_compile
}
multilib_src_test() {
emake check
}
src_test() {
multibuild_foreach_variant multilib-minimal_src_test
}
src_install() {
local DESTDIR=${D}
if target_is_not_host; then
DESTDIR=${ED}/usr/${CTARGET}
fi
multibuild_foreach_variant multilib-minimal_src_install
find "${ED}" -name '*.la' -delete || die
if target_is_not_host; then
insinto /usr/${CTARGET}/usr/share
doins -r "${ED}/usr/share/doc"
rm -r "${ED}/usr/share/doc" || die
rmdir "${ED}/usr/share" || die
fi
}
multilib_src_install() {
if use headers-only; then
emake DESTDIR="${DESTDIR}" install-nodist_includeHEADERS
else
emake DESTDIR="${DESTDIR}" install
# Conflicts with sys-apps/man-pages
rm "${DESTDIR}${MYPREFIX}"/usr/share/man/man3/crypt{,_r}.3 || die
fi
}
pkg_preinst() {
# Verify we're not in a bad case like bug #843209 with broken symlinks.
# This can be dropped when, if ever, the split-usr && system && compat case
# is cleaned up in *_src_install.
local broken_symlinks=()
mapfile -d '' broken_symlinks < <(
find "${ED}" -xtype l -print0
)
if [[ ${#broken_symlinks[@]} -gt 0 ]]; then
eerror "Broken symlinks found before merging!"
local symlink target resolved
for symlink in "${broken_symlinks[@]}" ; do
target="$(readlink "${symlink}")"
resolved="$(readlink -f "${symlink}")"
eerror " '${symlink}' -> '${target}' (${resolved})"
done
die "Broken symlinks found! Aborting to avoid damaging system. Please report a bug."
fi
}
|