mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-27 21:49:34 -05:00
gnu: crypto++: Update to 8.8.0.
* gnu/packages/crypto.scm (crypto++): Update to 8.8.0. [arguments]: Update to new style. Remove .so symbolic link installation as the project does it now. Fix cross-compilation for GNU/Linux and MinGW targets. Signed-off-by: Christopher Baines <mail@cbaines.net>
This commit is contained in:
parent
0e467b7b0b
commit
1138445494
1 changed files with 28 additions and 55 deletions
|
@ -26,6 +26,7 @@
|
||||||
;;; Copyright © 2022 Maxim Cournoyer <maxim.cournoyer@gmail.com>
|
;;; Copyright © 2022 Maxim Cournoyer <maxim.cournoyer@gmail.com>
|
||||||
;;; Copyright © 2022 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
|
;;; Copyright © 2022 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
|
||||||
;;; Copyright © 2023 Ivan Vilata-i-Balaguer <ivan@selidor.net>
|
;;; Copyright © 2023 Ivan Vilata-i-Balaguer <ivan@selidor.net>
|
||||||
|
;;; Copyright © 2023 Foundation Devices, Inc. <hello@foundationdevices.com>
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -742,7 +743,7 @@ (define-public perl-math-random-secure
|
||||||
(define-public crypto++
|
(define-public crypto++
|
||||||
(package
|
(package
|
||||||
(name "crypto++")
|
(name "crypto++")
|
||||||
(version "8.6.0")
|
(version "8.8.0")
|
||||||
(source (origin
|
(source (origin
|
||||||
(method git-fetch)
|
(method git-fetch)
|
||||||
(uri
|
(uri
|
||||||
|
@ -754,62 +755,34 @@ (define-public crypto++
|
||||||
(file-name (git-file-name name version))
|
(file-name (git-file-name name version))
|
||||||
(sha256
|
(sha256
|
||||||
(base32
|
(base32
|
||||||
"1vm821wpx59ccz6gr4xplqpxj3f1qq3jijyybj2g4npqmmldhx3b"))))
|
"11gfnsqbb531zwgzpm0x9hsgshzcj1j049vg0zqsaqf8lvky03l6"))))
|
||||||
(build-system gnu-build-system)
|
(build-system gnu-build-system)
|
||||||
(arguments
|
(arguments
|
||||||
`(#:make-flags
|
(list #:make-flags
|
||||||
(list (string-append "PREFIX=" (assoc-ref %outputs "out"))
|
#~(list (string-append "PREFIX=" #$output)
|
||||||
;; Override "/sbin/ldconfig" with simply "echo" since
|
(string-append "CC=" #$(cc-for-target))
|
||||||
;; we don't need ldconfig(8).
|
(string-append "CXX=" #$(cxx-for-target))
|
||||||
"LDCONF=echo")
|
(string-append "AR=" #$(ar-for-target))
|
||||||
#:phases
|
;; Override "/sbin/ldconfig" with simply "echo" since
|
||||||
(modify-phases %standard-phases
|
;; we don't need ldconfig(8).
|
||||||
(add-after 'unpack 'disable-native-optimisation
|
"LDCONF=echo")
|
||||||
;; This package installs more than just headers. Ensure that the
|
#:phases
|
||||||
;; cryptest.exe binary & static library aren't CPU model specific.
|
#~(modify-phases %standard-phases
|
||||||
(lambda _
|
(delete 'configure)
|
||||||
(substitute* "GNUmakefile"
|
(replace 'build
|
||||||
((" -march=native") ""))
|
;; By default, only the static library is built.
|
||||||
#t))
|
(lambda* (#:key make-flags parallel-build?
|
||||||
(delete 'configure)
|
#:allow-other-keys)
|
||||||
(replace 'build
|
(let* ((job-count (if parallel-build?
|
||||||
;; By default, only the static library is built.
|
(number->string (parallel-job-count))
|
||||||
(lambda* (#:key (make-flags '()) #:allow-other-keys)
|
1))
|
||||||
(apply invoke "make" "shared"
|
(jobs (string-append "-j" job-count))
|
||||||
"-j" (number->string (parallel-job-count))
|
(target #$(if (target-mingw?)
|
||||||
make-flags)))
|
"static"
|
||||||
(add-after 'install 'install-shared-library-links
|
"shared")))
|
||||||
;; By default, only .so and .so.x.y.z are installed.
|
(apply invoke "make" target jobs make-flags)
|
||||||
;; Create all the ‘intermediates’ expected by dependent packages.
|
(apply invoke "make" "libcryptopp.pc" jobs
|
||||||
(lambda* (#:key outputs #:allow-other-keys)
|
make-flags)))))))
|
||||||
(let* ((out (assoc-ref outputs "out"))
|
|
||||||
(lib (string-append out "/lib"))
|
|
||||||
(prefix "libcryptopp.so.")
|
|
||||||
(target (string-append prefix ,version)))
|
|
||||||
(with-directory-excursion lib
|
|
||||||
(symlink target
|
|
||||||
(string-append prefix ,(version-major+minor version)))
|
|
||||||
(symlink target
|
|
||||||
(string-append prefix ,(version-major version)))
|
|
||||||
#t))))
|
|
||||||
(add-after 'install 'install-pkg-config
|
|
||||||
(lambda* (#:key outputs #:allow-other-keys)
|
|
||||||
(let* ((out (assoc-ref outputs "out"))
|
|
||||||
(pkg-dir (string-append out "/lib/pkgconfig")))
|
|
||||||
(mkdir-p pkg-dir)
|
|
||||||
(with-output-to-file (string-append pkg-dir "/libcrypto++.pc")
|
|
||||||
(lambda _
|
|
||||||
(display
|
|
||||||
(string-append
|
|
||||||
"prefix=" out "\n"
|
|
||||||
"libdir=" out "/lib\n"
|
|
||||||
"includedir=" out "/include\n\n"
|
|
||||||
"Name: libcrypto++-" ,version "\n"
|
|
||||||
"Description: Class library of cryptographic schemes\n"
|
|
||||||
"Version: " ,version "\n"
|
|
||||||
"Libs: -L${libdir} -lcryptopp\n"
|
|
||||||
"Cflags: -I${includedir}\n"))
|
|
||||||
#t))))))))
|
|
||||||
(native-inputs
|
(native-inputs
|
||||||
(list unzip))
|
(list unzip))
|
||||||
(home-page "https://cryptopp.com/")
|
(home-page "https://cryptopp.com/")
|
||||||
|
|
Loading…
Reference in a new issue