[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
06/07: gnu: Add mergerfs.
From: |
guix-commits |
Subject: |
06/07: gnu: Add mergerfs. |
Date: |
Wed, 3 Jun 2020 12:06:48 -0400 (EDT) |
civodul pushed a commit to branch master
in repository guix.
commit 639bcf205d55c7a0c6d0894b4e7a814a86d3b9a9
Author: Lars-Dominik Braun <lars@6xq.net>
AuthorDate: Sat May 30 19:10:30 2020 +0200
gnu: Add mergerfs.
* gnu/packages/storage.scm (mergerfs): New variable.
Signed-off-by: Ludovic Courtès <ludo@gnu.org>
---
gnu/packages/file-systems.scm | 47 +++++++++++++++++++++++++++++++++++++++++++
1 file changed, 47 insertions(+)
diff --git a/gnu/packages/file-systems.scm b/gnu/packages/file-systems.scm
index 1f58917..bb435d7 100644
--- a/gnu/packages/file-systems.scm
+++ b/gnu/packages/file-systems.scm
@@ -682,3 +682,50 @@ APFS.")
originally developed for Solaris and is now maintained by the OpenZFS
community.")
(license license:cddl1.0)))
+
+(define-public mergerfs
+ (package
+ (name "mergerfs")
+ (version "2.29.0")
+ (source
+ (origin
+ (method url-fetch)
+ (uri (string-append
"https://github.com/trapexit/mergerfs/releases/download/"
+ version "/mergerfs-" version ".tar.gz"))
+ (sha256
+ (base32
+ "17gizw4vgbqqjd2ykkfpp276942jb5qclp0lkiwkmq1yjgyjqfmk"))))
+ (build-system gnu-build-system)
+ (arguments
+ `(#:tests? #f ; No tests exist.
+ #:phases
+ (modify-phases %standard-phases
+ (delete 'configure)
+ (add-after 'unpack 'fix-paths
+ (lambda* (#:key inputs outputs #:allow-other-keys)
+ (setenv "CC" "gcc")
+ ;; These were copied from the package libfuse.
+ (substitute* '("libfuse/lib/mount_util.c"
"libfuse/util/mount_util.c")
+ (("/bin/(u?)mount" _ maybe-u)
+ (string-append (assoc-ref inputs "util-linux")
+ "/bin/" maybe-u "mount")))
+ (substitute* '("libfuse/util/mount.mergerfs.c")
+ (("/bin/sh")
+ (which "sh")))
+ ;; The Makefile does not allow overriding PREFIX via make
variables.
+ (substitute* '("Makefile" "libfuse/Makefile")
+ (("= /usr/local") (string-append "= " (assoc-ref outputs
"out")))
+ ;; cannot chown as build user
+ (("chown root:root") "true"))
+ #t)))))
+ ;; mergerfs bundles a heavily modified copy of libfuse.
+ (inputs `(("util-linux" ,util-linux)))
+ (home-page "https://github.com/trapexit/mergerfs")
+ (synopsis "Featureful union filesystem")
+ (description "mergerfs is a union filesystem geared towards simplifying
+storage and management of files across numerous commodity storage devices. It
+is similar to mhddfs, unionfs, and aufs.")
+ (license (list
+ license:isc ; mergerfs
+ license:gpl2 license:lgpl2.0 ; Imported libfuse code.
+ ))))
- branch master updated (19b464f -> 4960a95), guix-commits, 2020/06/03
- 01/07: gnu: shepherd: Update to 0.8.1., guix-commits, 2020/06/03
- 02/07: doc: Mention Btrfs compression., guix-commits, 2020/06/03
- 05/07: gnu: Add Polish hunspell dictionary., guix-commits, 2020/06/03
- 03/07: gnu: java-openjfx-build: Add helpful patch., guix-commits, 2020/06/03
- 04/07: gnu: java-openjfx-build: Fix indentation., guix-commits, 2020/06/03
- 06/07: gnu: Add mergerfs.,
guix-commits <=
- 07/07: gnu: Add mergerfs-tools., guix-commits, 2020/06/03