gnu: clamav: Unbundle rust dependencies.

* gnu/packages/antivirus.scm (clamav)
[origin]<snippet>: Unbundle rust dependencies.
[build-system]: Switch to cargo-build-system.
[arguments]: Adapt to the change of base build-system.
[native-inputs]: Add cmake-minimal. Remove rust and rust:cargo.

Signed-off-by: Efraim Flashner <efraim@flashner.co.il>
Change-Id: Ibcd53f61e51e8a099050e98ca89371f9af243753
This commit is contained in:
Nicolas Graves 2024-11-06 00:15:08 +01:00 committed by Efraim Flashner
parent d77c800157
commit 986245daca
No known key found for this signature in database
GPG key ID: 41AAE7DCCA3D8351

View file

@ -31,12 +31,18 @@ (define-module (gnu packages antivirus)
#:use-module (gnu packages) #:use-module (gnu packages)
#:use-module (gnu packages check) #:use-module (gnu packages check)
#:use-module (gnu packages compression) #:use-module (gnu packages compression)
#:use-module (gnu packages cmake)
#:use-module (gnu packages crates-compression)
#:use-module (gnu packages crates-crypto)
#:use-module (gnu packages crates-graphics)
#:use-module (gnu packages crates-io)
#:use-module (gnu packages curl) #:use-module (gnu packages curl)
#:use-module (gnu packages ncurses) #:use-module (gnu packages ncurses)
#:use-module (gnu packages pcre) #:use-module (gnu packages pcre)
#:use-module (gnu packages pkg-config) #:use-module (gnu packages pkg-config)
#:use-module (gnu packages python) #:use-module (gnu packages python)
#:use-module (gnu packages python-check) #:use-module (gnu packages python-check)
#:use-module (gnu packages rust-apps)
#:use-module (gnu packages rust) #:use-module (gnu packages rust)
#:use-module (gnu packages tls) #:use-module (gnu packages tls)
#:use-module (gnu packages web) #:use-module (gnu packages web)
@ -61,34 +67,78 @@ (define-public clamav
(modules '((guix build utils))) (modules '((guix build utils)))
(snippet (snippet
'(begin '(begin
(delete-file "Cargo.lock")
(for-each
delete-file
(find-files ".cargo/vendor" ".cargo-checksum\\.json"))
(for-each delete-file-recursively (for-each delete-file-recursively
'("win32" ; unnecessary '(".cargo" ; vendored rust inputs
"win32" ; unnecessary
"libclamunrar")))))) ; non-free license "libclamunrar")))))) ; non-free license
(build-system cmake-build-system) (build-system cargo-build-system)
(arguments (arguments
(list (list
#:configure-flags #:install-source? #f
#~(list "-DENABLE_MILTER=OFF" "-DENABLE_UNRAR=OFF") #:cargo-inputs
#:imported-modules `((guix build cargo-utils) `(("rust-flate2" ,rust-flate2-1)
,@%cmake-build-system-modules) ("rust-hex" ,rust-hex-0.4)
("rust-libc" ,rust-libc-0.2)
("rust-log" ,rust-log-0.4)
("rust-sha2" ,rust-sha2-0.10)
("rust-tempfile" ,rust-tempfile-3)
("rust-thiserror" ,rust-thiserror-1)
("rust-image" ,rust-image-0.24)
("rust-rustdct" ,rust-rustdct-0.7)
("rust-transpose" ,rust-transpose-0.2)
("rust-num-traits" ,rust-num-traits-0.2)
("rust-base64" ,rust-base64-0.21)
("rust-sha1" ,rust-sha1-0.10)
("rust-unicode-segmentation" ,rust-unicode-segmentation-1)
("rust-bindgen" ,rust-bindgen-0.65)
("rust-onenote-parser-for-clamav" ,rust-onenote-parser-for-clamav)
("rust-hex-literal" ,rust-hex-literal-0.4)
("rust-inflate" ,rust-inflate-0.4)
("rust-bzip2-rs" ,rust-bzip2-rs-0.1)
("rust-byteorder" ,rust-byteorder-1)
("rust-delharc" ,rust-delharc-0.6)
("rust-cbindgen" ,rust-cbindgen))
#:vendor-dir ".cargo/vendor"
#:imported-modules `(,@%cmake-build-system-modules
,@%cargo-build-system-modules)
#:modules '((guix build cargo-build-system)
((guix build cmake-build-system) #:prefix cmake:)
(guix build utils))
#:phases #:phases
#~(modify-phases %standard-phases #~(modify-phases %standard-phases
(add-after 'unpack 'inject-rust-onenote ;; There is a test.exe file used in unit tests.
(delete 'check-for-pregenerated-files)
(add-after 'configure 'fix-cargo-inputs-vendoring
(lambda _
;; Reproduce the original layout, fails with config.
(rename-file ".cargo/config" ".cargo/config.toml")
;; Wrongly placed by configure
(delete-file-recursively
(string-append ".cargo/vendor/clamav-" #$version ".tar.zst"))))
(add-after 'patch-cargo-checksums 'cmake-configure
(lambda* (#:key outputs #:allow-other-keys)
((assoc-ref cmake:%standard-phases 'configure)
#:configure-flags
(list "-DENABLE_MILTER=OFF" "-DENABLE_UNRAR=OFF")
#:outputs outputs)))
(replace 'build
(assoc-ref cmake:%standard-phases 'build))
(add-after 'patch-cargo-checksums 'patch-rust-requirements
(lambda _ (lambda _
(substitute* "libclamav_rust/Cargo.toml" (substitute* "libclamav_rust/Cargo.toml"
;; We make sure we use their fork.
(("onenote_parser = .*") (("onenote_parser = .*")
"onenote_parser = \"0.3.1\"\n")))) "onenote_parser = \"*\"\n")
(add-after 'patch-source-shebangs 'patch-cargo-checksums ;; As long as it builds later versions of (c)bindgen are fine
(lambda _ (("cbindgen = \\{ version =\".*\",")
(use-modules "cbindgen = { version = \"*\","))))
(srfi srfi-1) (ice-9 ftw) (guix build cargo-utils)) (replace 'install
(with-directory-excursion ".cargo/vendor" (assoc-ref cmake:%standard-phases 'install))
(for-each generate-all-checksums (replace 'check
(delete "." (delete ".." (scandir "."))))))) (lambda* (#:key tests? #:allow-other-keys)
((assoc-ref cmake:%standard-phases 'check)
#:tests? tests?
#:test-target "test")))
(add-after 'unpack 'skip-clamd-tests (add-after 'unpack 'skip-clamd-tests
;; XXX: The check?_clamd tests fail inside the build ;; XXX: The check?_clamd tests fail inside the build
;; chroot, but pass outside. ;; chroot, but pass outside.
@ -100,11 +150,10 @@ (define-public clamav
test " -k \"not test_clamd_08_VirusEvent\""))))))))) test " -k \"not test_clamd_08_VirusEvent\"")))))))))
(native-inputs (native-inputs
(list check ; for tests (list check ; for tests
cmake-minimal
pkg-config pkg-config
python-minimal python-minimal
python-pytest python-pytest))
rust
(list rust "cargo")))
(inputs (inputs
(list bzip2 (list bzip2
curl curl