Install this version:
emerge -a =app-crypt/veracrypt-1.26.29-r4
| Version | EAPI | Keywords | Slot |
|---|---|---|---|
| 1.26.29-r4 | 8 | amd64 | 0 |
# Copyright 2026 Gentoo Authors
# Distributed under the terms of the BSD 3-Clause License
EAPI=8
WX_GTK_VER="3.2-gtk3"
inherit desktop eapi9-ver 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"
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="
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_prepare() {
# -march=x86-64-v3 defines __AVX2__; Crypto/cpu.h also re-enables it via
# #pragma GCC target. Insert undefs directly before blamka-round-opt.h
# so the SSE2 branch (which defines BLAKE2_ROUND) is always selected.
sed -i \
's|^#include "blake2/blamka-round-opt.h"$|#undef __AVX2__\n#undef __AVX512F__\n&|' \
Crypto/Argon2/src/opt_sse2.c || die
eapply_user
}
src_configure() {
setup-wxwidgets
}
src_compile() {
local myemakeargs=(
"SOURCE_DATE_EPOCH=${SOURCE_DATE_EPOCH:-$(date -r "${S}/Common/Tcdefs.h" +%s)}"
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}.png veracrypt.png
done
make_desktop_entry veracrypt "VeraCrypt" veracrypt "Utility;Security"
fi
pax-mark -m "${ED}"/usr/bin/veracrypt
}
pkg_postinst() {
ewarn "VeraCrypt has a very restrictive license. Please be explicitly aware"
ewarn "of the limitations on redistribution of binaries or modified source."
if ver_replacing -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
}
Manage flags for this package:
euse -i <flag> -p app-crypt/veracrypt |
euse -E <flag> -p app-crypt/veracrypt |
euse -D <flag> -p app-crypt/veracrypt
sys-apps/pcsc-lite sys-fs/fuse:0 sys-fs/lvm2 x11-libs/wxGTK:3.2-gtk3=[X?]
sys-apps/pcsc-lite sys-fs/fuse:0 sys-fs/lvm2 x11-libs/wxGTK:3.2-gtk3=[X?]
asm? ( dev-lang/yasm ) virtual/pkgconfig