mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 14:16:55 -05:00
gnu: racket: Ignore bytecode checksums in the store.
Fixes <https://debbugs.gnu.org/30680>. * gnu/packages/patches/racket-store-checksum-override.patch: New file. * gnu/packages/scheme.scm (racket)[sources]: Add it.
This commit is contained in:
parent
5a0696b2e3
commit
e3fc9bcce2
2 changed files with 44 additions and 1 deletions
42
gnu/packages/patches/racket-store-checksum-override.patch
Normal file
42
gnu/packages/patches/racket-store-checksum-override.patch
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
Racket uses checksums to test if it needs to recompile its source
|
||||||
|
files to bytecode. If Racket is updated by grafting, the source and
|
||||||
|
bytecode files get updated, but the checksum stays the same. Since
|
||||||
|
the checksum no longer matches the source file, Racket tries to
|
||||||
|
regenerate the bytecode and write it to the store, causing errors
|
||||||
|
because the store is immutable. This patch makes Racket ignore
|
||||||
|
checksums for files in the store.
|
||||||
|
|
||||||
|
See <https://debbugs.gnu.org/30680> for details.
|
||||||
|
|
||||||
|
diff -ruN racket-6.12/collects/compiler/cm.rkt racket-6.12-patched/collects/compiler/cm.rkt
|
||||||
|
--- racket-6.12/collects/compiler/cm.rkt 1969-12-31 19:00:00.000000000 -0500
|
||||||
|
+++ racket-6.12-patched/collects/compiler/cm.rkt 2018-08-12 06:36:46.061142149 -0400
|
||||||
|
@@ -7,6 +7,7 @@
|
||||||
|
racket/list
|
||||||
|
racket/path
|
||||||
|
racket/promise
|
||||||
|
+ racket/string
|
||||||
|
openssl/sha1
|
||||||
|
racket/place
|
||||||
|
setup/collects
|
||||||
|
@@ -627,6 +628,10 @@
|
||||||
|
#f
|
||||||
|
(list src-hash recorded-hash)))
|
||||||
|
|
||||||
|
+(define (store-reference? path)
|
||||||
|
+ (let ([store-prefix (or (getenv "NIX_STORE") "/gnu/store")])
|
||||||
|
+ (string-prefix? (path->string path) store-prefix)))
|
||||||
|
+
|
||||||
|
(define (rkt->ss p)
|
||||||
|
(if (path-has-extension? p #".rkt")
|
||||||
|
(path-replace-extension p #".ss")
|
||||||
|
@@ -679,7 +684,8 @@
|
||||||
|
(trace-printf "newer src... ~a > ~a" path-time path-zo-time)
|
||||||
|
;; If `sha1-only?', then `maybe-compile-zo' returns a #f or thunk:
|
||||||
|
(maybe-compile-zo sha1-only? deps path->mode roots path orig-path read-src-syntax up-to-date collection-cache new-seen)]
|
||||||
|
- [(different-source-sha1-and-dep-recorded path deps)
|
||||||
|
+ [(and (not (store-reference? path))
|
||||||
|
+ (different-source-sha1-and-dep-recorded path deps))
|
||||||
|
=> (lambda (difference)
|
||||||
|
(trace-printf "different src hash... ~a" difference)
|
||||||
|
;; If `sha1-only?', then `maybe-compile-zo' returns a #f or thunk:
|
|
@ -421,7 +421,8 @@ (define-public racket
|
||||||
(patches (search-patches
|
(patches (search-patches
|
||||||
;; See: https://github.com/racket/racket/issues/1962
|
;; See: https://github.com/racket/racket/issues/1962
|
||||||
;; This can be removed in whatever Racket release comes after 6.12
|
;; This can be removed in whatever Racket release comes after 6.12
|
||||||
"racket-fix-xform-issue.patch"))))
|
"racket-fix-xform-issue.patch"
|
||||||
|
"racket-store-checksum-override.patch"))))
|
||||||
(build-system gnu-build-system)
|
(build-system gnu-build-system)
|
||||||
(arguments
|
(arguments
|
||||||
'(#:phases
|
'(#:phases
|
||||||
|
|
Loading…
Reference in a new issue