mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-18 13:36:36 +01:00
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:
parent
d77c800157
commit
986245daca
1 changed files with 71 additions and 22 deletions
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue