# Copyright 1999-2024 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI=8 WX_GTK_VER="3.2-gtk3" inherit desktop flag-o-matic linux-info pax-utils toolchain-funcs wxwidgets DESCRIPTION="Disk encryption with strong security based on TrueCrypt" HOMEPAGE="https://www.veracrypt.fr/en/Home.html" SRC_URI="https://github.com/${PN}/VeraCrypt/archive/VeraCrypt_${PV}.tar.gz -> ${P}.tar.gz" S="${WORKDIR}/VeraCrypt-VeraCrypt_${PV}/src" # The modules not linked against in Linux include (but not limited to): # libzip, chacha-xmm, chacha256, chachaRng, rdrand, t1ha2 # Tested by actually removing the source files and performing a build # For this reason, we don't have to worry about their licenses LICENSE="Apache-2.0 BSD RSA truecrypt-3.0" SLOT="0" KEYWORDS="~amd64" IUSE="+asm cpu_flags_x86_sse2 cpu_flags_x86_sse4_1 cpu_flags_x86_ssse3 doc X" RESTRICT="bindist mirror" RDEPEND=" app-admin/sudo sys-apps/pcsc-lite sys-fs/fuse:0 sys-fs/lvm2 x11-libs/wxGTK:${WX_GTK_VER}[X?]" DEPEND="${RDEPEND}" BDEPEND=" asm? ( dev-lang/yasm ) virtual/pkgconfig" CONFIG_CHECK="~BLK_DEV_DM ~CRYPTO ~CRYPTO_XTS ~DM_CRYPT ~FUSE_FS" src_configure() { setup-wxwidgets # https://bugs.gentoo.org/786741 # std::byte clashes with src/Common/Tcdefs.h typedef append-cxxflags -std=c++14 } src_compile() { local myemakeargs=( NOSTRIP=1 NOTEST=1 VERBOSE=1 CC="$(tc-getCC)" CXX="$(tc-getCXX)" AR="$(tc-getAR)" RANLIB="$(tc-getRANLIB)" TC_EXTRA_CFLAGS="${CFLAGS}" TC_EXTRA_CXXFLAGS="${CXXFLAGS}" TC_EXTRA_LFLAGS="${LDFLAGS}" WX_CONFIG="${WX_CONFIG}" $(usex X "" "NOGUI=1") $(usex asm "" "NOASM=1") $(usex cpu_flags_x86_sse2 "" "NOSSE2=1") $(usex cpu_flags_x86_sse4_1 "SSE41=1" "") $(usex cpu_flags_x86_ssse3 "SSSE3=1" "") ) emake "${myemakeargs[@]}" } src_test() { ./Main/veracrypt --text --test || die "tests failed" } src_install() { local DOCS=( Readme.txt ) dobin Main/veracrypt if use doc; then DOCS+=( "${S}"/../doc/EFI-DCS ) docompress -x /usr/share/doc/${PF}/EFI-DCS HTML_DOCS=( "${S}"/../doc/html/. ) fi einstalldocs newinitd "${FILESDIR}"/veracrypt.init veracrypt if use X; then local s for s in 16 48 128 256; do newicon -s ${s} Resources/Icons/VeraCrypt-${s}x${s}.xpm veracrypt.xpm done make_desktop_entry veracrypt "VeraCrypt" veracrypt "Utility;Security" fi pax-mark -m "${ED}"/usr/bin/veracrypt } pkg_postinst() { local version ewarn "VeraCrypt has a very restrictive license. Please be explicitly aware" ewarn "of the limitations on redistribution of binaries or modified source." # Remove this when we remove veracrypt-1.25.9.ebuild from the tree. for version in ${REPLACING_VERSIONS}; do if ver_test "${version}" -lt "1.26.7"; then ewarn "Starting with 1.26.7, TrueCrypt volumes are no longer supported." ewarn "Please explore alternatives such as dm-crypt to mount truecrypt volumes." ewarn "Moreover, support for RIPEMD160 and GOST89 is dropped." ewarn "Volumes using these algoritms will no longer mount." fi done }