summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIgor Goryachev via Guix-patches via <guix-patches@gnu.org>2024-09-19 19:39:12 +0300
committerAndrew Tropin <andrew@trop.in>2024-09-24 15:51:13 +0400
commit5fa4b5cb99bc328f807c83401f0e791b647061fe (patch)
tree5e02df939b073d3e8e1747825e6aaba72d176b46
parentd6211bd0c1d30fa0639953b5e3181c0d99843e72 (diff)
gnu: rebar3: Update to 3.24.0, make reproducible.
* gnu/packages/erlang.scm (rebar3): Update to 3.24.0. [arguments]<#:phases>: Modify 'make-escriptize-reproducible phase. Change-Id: I264515753f1ed0bdabdc4042a1c850d738c27738 Signed-off-by: Andrew Tropin <andrew@trop.in>
-rw-r--r--gnu/packages/erlang.scm31
1 files changed, 8 insertions, 23 deletions
diff --git a/gnu/packages/erlang.scm b/gnu/packages/erlang.scm
index 5d8516f311..026a7dd32e 100644
--- a/gnu/packages/erlang.scm
+++ b/gnu/packages/erlang.scm
@@ -637,7 +637,7 @@ Erlang.")
(define-public rebar3
(package
(name "rebar3")
- (version "3.23.0")
+ (version "3.24.0")
(source
(origin
(method git-fetch)
@@ -646,7 +646,7 @@ Erlang.")
(commit version)))
(file-name (git-file-name name version))
(sha256
- (base32 "0jinjx3mk5j1kczxmblixbvhf24q0yfwih2ggs11x5ykmrqpbckl"))))
+ (base32 "1l73csyzxwinhrcsyb8hg2003v35yz6pv98inl3wg1j5587f071s"))))
(build-system gnu-build-system)
;; TODO: remove vendored modules, install man-page, install lib(?)
(arguments
@@ -672,29 +672,14 @@ Erlang.")
"eunit_formatters" "getopt" "hex_core" "erlware_commons"
"parse_trans" "relx" "ssl_verify_fun" "providers"))))
(delete 'configure)
- ;; By default rebar3 produces escripts with embedded ZIP archives
- ;; with files with current timestamps which is not suitable for
- ;; reproducible builds. We fix it by setting predefined timestamps.
+ ;; Due to changes in Erlang 27.1 related to handling ZIP-archives
+ ;; we still need to patch rebar to make it generate reproducible
+ ;; escripts.
(add-before 'build 'make-escriptize-reproducible
(lambda _
- (let ((escriptize "apps/rebar/src/rebar_prv_escriptize.erl"))
- (substitute* escriptize
- (("\\[dir_entries\\(filename:dirname\\(Filename1\\)\\),")
- (string-append "FilePath = filename:join(Dir, Filename),"
- "{ok, FileInfo0} = file:read_file_info(FilePath),"
- "DateTime = {{1970, 1, 1}, {0, 0, 1}},"
- "FileInfo = FileInfo0#file_info{mtime = DateTime},"
- "[dir_entries(filename:dirname(Filename1)),")))
- (substitute* escriptize
- (((string-append
- "\\{Filename1, file_contents\\(filename:join\\(Dir, "
- "Filename\\)\\)\\}\\]."))
- "{Filename1, file_contents(FilePath), FileInfo}]."))
- (substitute* escriptize
- (((string-append "\\[\\{FName,FBin\\} \\|\\| \\{FName,FBin\\} <- "
- "Files, FBin =/= <<>>\\]\\."))
- (string-append "[{FName,FBin,FInfo} || {FName,FBin,FInfo} <- "
- "Files, FBin =/= <<>>]."))))))
+ (substitute* "apps/rebar/src/rebar_prv_escriptize.erl"
+ (("mtime = DateTime")
+ "atime = DateTime,ctime = DateTime,mtime = DateTime"))))
(replace 'build
(lambda _
(setenv "HOME" (getcwd))