commit:     61aeb7fdda5a91abd4d7968e7f88b6c168a54398
Author:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 27 17:12:05 2025 +0000
Commit:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
CommitDate: Wed Aug 27 17:20:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=61aeb7fd

app-crypt/hashcat: add 7.1.2

Bridges (rust, python currently) are not yet building.

Signed-off-by: Patrick Lauer <patrick <AT> gentoo.org>

 app-crypt/hashcat/Manifest             |   1 +
 app-crypt/hashcat/hashcat-7.1.2.ebuild | 119 +++++++++++++++++++++++++++++++++
 2 files changed, 120 insertions(+)

diff --git a/app-crypt/hashcat/Manifest b/app-crypt/hashcat/Manifest
index 526ecd2eb137..7d5d29363b59 100644
--- a/app-crypt/hashcat/Manifest
+++ b/app-crypt/hashcat/Manifest
@@ -1 +1,2 @@
 DIST hashcat-6.2.6.tar.gz 14234640 BLAKE2B 
fbbebc0a35b920442d4e1fb5822a8b9867db62bcc2404fba514fe1f06f0aa859a116cbe204eed71d340ad826dcfffffadca6963e5eec875ae2fee59068968b61
 SHA512 
b5e4f40fb5ed0a47977243e1f95bf1deae0b04bd5ca26338395305c42573fe5b17557835f6f5d8b7402812e8eadda2b260d6b927ce99429fd1b87eb26f002f8a
+DIST hashcat-7.1.2.tar.gz 19125734 BLAKE2B 
9418d591148655ae6fd585ced8bac319c17af1a0429f485d4f2ce5c9e3cb78c3d0eb8bfe599486e458783fc79a10f2709ca59c312f8219afef637eaf4ba72d95
 SHA512 
89213058aaa2be3aa62dfab8acd5c61a7c8bd58a63ce2c3c1472960e122ca554f63482cb201f4e285acb97d94b1c1038bc93a203d66bd5a428f31ad8c709873c

diff --git a/app-crypt/hashcat/hashcat-7.1.2.ebuild 
b/app-crypt/hashcat/hashcat-7.1.2.ebuild
new file mode 100644
index 000000000000..c27aabfcc5c3
--- /dev/null
+++ b/app-crypt/hashcat/hashcat-7.1.2.ebuild
@@ -0,0 +1,119 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit pax-utils toolchain-funcs
+
+DESCRIPTION="World's fastest and most advanced password recovery utility"
+HOMEPAGE="https://github.com/hashcat/hashcat";
+if [[ ${PV} == "9999" ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/hashcat/hashcat.git";
+else
+       KEYWORDS="~amd64"
+       SRC_URI="https://github.com/hashcat/hashcat/archive/v${PV}.tar.gz -> 
${P}.tar.gz"
+fi
+
+LICENSE="MIT"
+SLOT="0"
+IUSE="brain video_cards_nvidia"
+RESTRICT=test
+
+DEPEND="app-arch/lzma
+       >=app-arch/unrar-7
+       sys-libs/zlib[minizip]
+       brain? ( dev-libs/xxhash )
+       video_cards_nvidia? (
+               >x11-drivers/nvidia-drivers-440.64
+               || (
+                       dev-util/nvidia-cuda-toolkit
+                       virtual/opencl
+               )
+       )
+       !video_cards_nvidia? (
+               virtual/opencl
+               dev-util/opencl-headers
+       )"
+RDEPEND="${DEPEND}"
+
+src_prepare() {
+       # Remove bundled stuff
+       rm -r deps/OpenCL-Headers || die "Failed to remove bundled OpenCL 
Headers"
+       rm -r deps/xxHash || die "Failed to remove bundled xxHash"
+
+       # TODO: Gentoo's app-arch/lzma doesn't install the needed files
+       #rm -r deps/LZMA-SDK || die "Failed to remove bundled LZMA-SDK"
+       #rm -r deps || die "Failed to remove bundled deps"
+
+       # Do not strip
+       sed -i "/LFLAGS                  += -s/d" src/Makefile || die
+
+       # Do not add random CFLAGS
+       sed -i "s/-O2//" src/Makefile || die
+
+       #sed -i "#LZMA_SDK_INCLUDE#d" src/Makefile || die
+
+       # Respect CC, CXX, AR
+       sed -i \
+               -e 's/:= gcc/:= $(CC)/' \
+               -e 's/:= g++/:= $(CXX)/' \
+               -e 's/:= ar/:= $(AR)/' \
+               src/Makefile || die
+
+       export PREFIX="${EPREFIX}"/usr
+       export LIBRARY_FOLDER="/usr/$(get_libdir)"
+       export DOCUMENT_FOLDER="/usr/share/doc/${PF}"
+
+       default
+}
+
+src_compile() {
+       tc-export CC CXX AR
+
+       # Use bundled unrar for now, bug #792720
+       emake \
+               SHARED=1 \
+               PRODUCTION=1 \
+               ENABLE_BRAIN=$(usex brain 1 0) \
+               USE_SYSTEM_LZMA=0 \
+               USE_SYSTEM_OPENCL=1 \
+               USE_SYSTEM_UNRAR=1 \
+               USE_SYSTEM_ZLIB=1 \
+               USE_SYSTEM_XXHASH=1 \
+               VERSION_PURE="${PV}"
+
+       pax-mark -mr hashcat
+}
+
+src_test() {
+       if use video_cards_nvidia; then
+               addwrite /dev/nvidia0
+               addwrite /dev/nvidiactl
+               addwrite /dev/nvidia-uvm
+
+               if [[ ! -w /dev/nvidia0 ]]; then
+                       einfo "To run these tests, portage likely must be in 
the video group."
+                       einfo "Please run \"gpasswd -a portage video\" if the 
tests will fail"
+               fi
+       fi
+
+       # This always exits with 255 despite success
+       #./hashcat -b -m 2500 || die "Test failed"
+       LD_PRELOAD=./libhashcat.so.${PV} ./hashcat -a 3 -m 1500 nQCk49SiErOgk 
|| die "Test failed"
+}
+
+src_install() {
+       emake \
+               DESTDIR="${ED}" \
+               SHARED=1 \
+               PRODUCTION=1 \
+               ENABLE_BRAIN=$(usex brain 1 0) \
+               USE_SYSTEM_LZMA=0 \
+               USE_SYSTEM_OPENCL=1 \
+               USE_SYSTEM_UNRAR=1 \
+               USE_SYSTEM_ZLIB=1 \
+               USE_SYSTEM_XXHASH=1 \
+               VERSION_PURE="${PV}" \
+               install
+}

Reply via email to