mirror of
https://github.com/dashpay/dash.git
synced 2024-12-25 12:02:48 +01:00
Merge #20937: guix: Make nsis reproducible by respecting SOURCE-DATE-EPOCH
1fca9811e1331ac5dae8188f6178cc37da4929a7 lint: Skip whitespace lint for guix patches (Carl Dong) a91c46c57d88fc399432afab7bb0fb14c3e490a7 guix: Make nsis reproducible by respecting SOURCE-DATE-EPOCH (Carl Dong) Pull request description: ``` When building nsis, if VERSION is not specified, it defaults to cvs_version which is non-deterministic as it includes the current date. This patches nsis to default to SOURCE_DATE_EPOCH if it exists so that nsis is reproducible. Upstream change: https://github.com/kichik/nsis/pull/13 ``` Sidenote: also a good demonstration of how Guix allows us to flexibly patch our tools! Note to reviewers: if you want to compare hashes, please build after Jan 16th 2021 without my substitute server enabled! ACKs for top commit: fanquake: ACK 1fca9811e1331ac5dae8188f6178cc37da4929a7 Tree-SHA512: b800e0ce5f73827ad353739effb9167ec3a6bdb362c725ae20dd3f025ce78660f85c70ce1d75cd0896facf1e8fe38a9e058459ed13dec71ab3a2fe41e20eaa5d
This commit is contained in:
parent
d4d19b539b
commit
1c79710e65
@ -26,6 +26,13 @@
|
|||||||
(guix profiles)
|
(guix profiles)
|
||||||
(guix utils))
|
(guix utils))
|
||||||
|
|
||||||
|
(define-syntax-rule (search-our-patches file-name ...)
|
||||||
|
"Return the list of absolute file names corresponding to each
|
||||||
|
FILE-NAME found in ./patches relative to the current file."
|
||||||
|
(parameterize
|
||||||
|
((%patch-path (list (string-append (dirname (current-filename)) "/patches"))))
|
||||||
|
(list (search-patch file-name) ...)))
|
||||||
|
|
||||||
(define (make-ssp-fixed-gcc xgcc)
|
(define (make-ssp-fixed-gcc xgcc)
|
||||||
"Given a XGCC package, return a modified package that uses the SSP function
|
"Given a XGCC package, return a modified package that uses the SSP function
|
||||||
from glibc instead of from libssp.so. Our `symbol-check' script will complain if
|
from glibc instead of from libssp.so. Our `symbol-check' script will complain if
|
||||||
@ -151,6 +158,10 @@ chain for " target " development."))
|
|||||||
(home-page (package-home-page pthreads-xgcc))
|
(home-page (package-home-page pthreads-xgcc))
|
||||||
(license (package-license pthreads-xgcc)))))
|
(license (package-license pthreads-xgcc)))))
|
||||||
|
|
||||||
|
(define (make-nsis-with-sde-support base-nsis)
|
||||||
|
(package-with-extra-patches base-nsis
|
||||||
|
(search-our-patches "nsis-SConstruct-sde-support.patch")))
|
||||||
|
|
||||||
|
|
||||||
(packages->manifest
|
(packages->manifest
|
||||||
(append
|
(append
|
||||||
@ -191,7 +202,9 @@ chain for " target " development."))
|
|||||||
(let ((target (getenv "HOST")))
|
(let ((target (getenv "HOST")))
|
||||||
(cond ((string-suffix? "-mingw32" target)
|
(cond ((string-suffix? "-mingw32" target)
|
||||||
;; Windows
|
;; Windows
|
||||||
(list zip (make-mingw-pthreads-cross-toolchain "x86_64-w64-mingw32") nsis-x86_64))
|
(list zip
|
||||||
|
(make-mingw-pthreads-cross-toolchain "x86_64-w64-mingw32")
|
||||||
|
(make-nsis-with-sde-support nsis-x86_64)))
|
||||||
((string-contains target "riscv64-linux-")
|
((string-contains target "riscv64-linux-")
|
||||||
(list (make-bitcoin-cross-toolchain "riscv64-linux-gnu"
|
(list (make-bitcoin-cross-toolchain "riscv64-linux-gnu"
|
||||||
#:base-gcc-for-libc gcc-7)))
|
#:base-gcc-for-libc gcc-7)))
|
||||||
|
15
contrib/guix/patches/nsis-SConstruct-sde-support.patch
Normal file
15
contrib/guix/patches/nsis-SConstruct-sde-support.patch
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
diff --git a/SConstruct b/SConstruct
|
||||||
|
index e8252c9..41786f2 100755
|
||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -95,8 +95,8 @@ default_doctype = 'html'
|
||||||
|
if defenv.WhereIs('hhc', os.environ['PATH']):
|
||||||
|
default_doctype = 'chm'
|
||||||
|
|
||||||
|
-from time import strftime, gmtime
|
||||||
|
-cvs_version = strftime('%d-%b-%Y.cvs', gmtime())
|
||||||
|
+import time
|
||||||
|
+cvs_version = time.strftime('%d-%b-%Y.cvs', time.gmtime(int(os.environ.get('SOURCE_DATE_EPOCH', time.time()))))
|
||||||
|
|
||||||
|
opts = Variables()
|
||||||
|
|
@ -31,7 +31,7 @@ if [ -z "${COMMIT_RANGE}" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
showdiff() {
|
showdiff() {
|
||||||
if ! git diff -U0 "${COMMIT_RANGE}" -- "." ":(exclude)depends/patches/" ":(exclude)src/dashbls/" ":(exclude)src/immer/" ":(exclude)src/leveldb/" ":(exclude)src/crc32c/" ":(exclude)src/secp256k1/" ":(exclude)src/univalue/" ":(exclude)doc/release-notes/"; then
|
if ! git diff -U0 "${COMMIT_RANGE}" -- "." ":(exclude)depends/patches/" ":(exclude)contrib/guix/patches/" ":(exclude)src/dashbls/" ":(exclude)src/immer/" ":(exclude)src/leveldb/" ":(exclude)src/crc32c/" ":(exclude)src/secp256k1/" ":(exclude)src/univalue/" ":(exclude)doc/release-notes/"; then
|
||||||
echo "Failed to get a diff"
|
echo "Failed to get a diff"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
Loading…
Reference in New Issue
Block a user