* [PATCH] gnu: Add nfs-utils
@ 2016-09-07 20:20 John Darrington
2016-09-07 20:29 ` Danny Milosavljevic
2016-09-12 13:37 ` Ludovic Courtès
0 siblings, 2 replies; 4+ messages in thread
From: John Darrington @ 2016-09-07 20:20 UTC (permalink / raw)
To: guix-devel; +Cc: John Darrington
* gnu/packages/linux.scm (nfs-utils): New variable.
---
gnu/packages/linux.scm | 87 +++++++++++++++++++++++++++++++++++++++++++++++++-
1 file changed, 86 insertions(+), 1 deletion(-)
diff --git a/gnu/packages/linux.scm b/gnu/packages/linux.scm
index 030e35e..eb9cb03 100644
--- a/gnu/packages/linux.scm
+++ b/gnu/packages/linux.scm
@@ -55,9 +55,14 @@
#:use-module (gnu packages gnuzilla)
#:use-module (gnu packages gperf)
#:use-module (gnu packages gtk)
+ #:use-module (gnu packages gsasl)
+ #:use-module (gnu packages libevent)
#:use-module (gnu packages libusb)
#:use-module (gnu packages maths)
+ #:use-module (gnu packages mit-krb5)
#:use-module (gnu packages ncurses)
+ #:use-module (gnu packages networking)
+ #:use-module (gnu packages onc-rpc)
#:use-module (gnu packages perl)
#:use-module (gnu packages pciutils)
#:use-module (gnu packages pkg-config)
@@ -228,6 +233,86 @@ the default @code{nsswitch} and the experimental @code{umich_ldap}.")
(license (license:non-copyleft "file://COPYING"
"See COPYING in the distribution."))))
+(define-public nfs-utils
+ (package
+ (name "nfs-utils")
+ (version "1.3.4")
+ (source (origin
+ (method url-fetch)
+ (uri (string-append
+ "mirror://kernel.org/linux/utils/nfs-utils/" version
+ "/nfs-utils-" version ".tar.xz"))
+ (sha256
+ (base32
+ "0xarqhwy757vazv9gqhyrgxsrx083yhvkkih01jh83fqm305naml"))))
+ (build-system gnu-build-system)
+ (arguments
+ `(#:configure-flags
+ `("--without-tcp-wrappers"
+ ,(string-append "--with-start-statd="
+ (assoc-ref %outputs "out") "/sbin/start-statd")
+ ,(string-append "--with-krb5=" (assoc-ref %build-inputs "mit-krb5")))
+ #:phases (modify-phases %standard-phases
+ (add-before
+ 'configure 'mutate-source
+ (lambda _
+ ;; Eventually, we should provide our own start-statd
+ ;; script instead ... one which starts the rpc.statd
+ ;; service (which we don't yet have)
+ (substitute* `("utils/statd/start-statd")
+ (("^PATH=.*") "")
+ (("^flock")
+ (string-append
+ (assoc-ref %build-inputs "util-linux")
+ "/bin/flock"))
+ (("^exec rpc.statd")
+ (string-append "exec "
+ (assoc-ref %outputs "out") "/sbin/rpc.statd")))
+
+ ;; This hook tries to write to /var
+ ;; That needs to be done by a service too.
+ (substitute* `("Makefile.in")
+ (("^install-data-hook:")
+ "install-data-hook-disabled-for-guix:"))
+
+ ;; Replace some hard coded paths
+ (substitute* `("utils/nfsd/nfssvc.c")
+ (("/bin/mount")
+ (string-append
+ (assoc-ref %build-inputs "util-linux")
+ "/bin/mount")))
+ (substitute* `("utils/statd/statd.c")
+ (("/usr/sbin/")
+ (string-append (assoc-ref %outputs "out") "/sbin/")))
+ (substitute* `("utils/osd_login/Makefile.in"
+ "utils/mount/Makefile.in"
+ "utils/nfsdcltrack/Makefile.in")
+ (("^sbindir = /sbin")
+ (string-append "sbindir = "
+ (assoc-ref %outputs "out") "/sbin"))))))))
+ (inputs `(("libevent" ,libevent)
+ ("libnfsidmap" ,libnfsidmap)
+ ("sqlite" ,sqlite)
+ ("lvm2" ,lvm2)
+ ("gss" ,gss)
+ ("util-linux" ,util-linux)
+ ("mit-krb5" ,mit-krb5)
+ ("libtirpc" ,libtirpc)))
+ (native-inputs
+ `(("pkg-config" ,pkg-config)))
+ (home-page "http://www.kernel.org/pub/linux/utils/nfs-utils/")
+ (synopsis "Tools for loading and managing Linux NFS mounts")
+ (description "The Network File System (NFS) was developed to allow
+machines to mount a disk partition on a remote machine as if it were a local
+disk. It allows for fast, seamless sharing of files across a network.")
+ ;; It is hard to be sure what the licence is. Most of the source files
+ ;; contain no licence notice at all. A few have a licence notice for a 3
+ ;; clause non-copyleft licence. However the tarball has a COPYING file
+ ;; with the text of GPLv2 -- It seems then that GLPv2 is the most
+ ;; restrictive licence, and until advice to the contrary we must assume
+ ;; that is what is intended.
+ (license license:gpl2)))
+
(define %boot-logo-patch
;; Linux-Libre boot logo featuring Freedo and a gnu.
(origin
@@ -2183,7 +2268,7 @@ WLAN, Bluetooth and mobile broadband.")
(version "1.7")
(source (origin
(method url-fetch)
- (uri (string-append "mirror://sourceforge/acpiclient/acpiclient/"
+ (uri (string-append "mirror://sourceforge/acpiclient/acpiclient/"
version "/" name "-" version ".tar.gz"))
(sha256
(base32
--
2.1.4
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH] gnu: Add nfs-utils
2016-09-07 20:20 [PATCH] gnu: Add nfs-utils John Darrington
@ 2016-09-07 20:29 ` Danny Milosavljevic
2016-09-07 20:35 ` John Darrington
2016-09-12 13:37 ` Ludovic Courtès
1 sibling, 1 reply; 4+ messages in thread
From: Danny Milosavljevic @ 2016-09-07 20:29 UTC (permalink / raw)
To: John Darrington; +Cc: guix-devel
> + `("--without-tcp-wrappers"
^^^
Since you also provided tcp-wrappers in a seperate patch, was this on purpose?
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] gnu: Add nfs-utils
2016-09-07 20:20 [PATCH] gnu: Add nfs-utils John Darrington
2016-09-07 20:29 ` Danny Milosavljevic
@ 2016-09-12 13:37 ` Ludovic Courtès
1 sibling, 0 replies; 4+ messages in thread
From: Ludovic Courtès @ 2016-09-12 13:37 UTC (permalink / raw)
To: John Darrington; +Cc: guix-devel
John Darrington <jmd@gnu.org> skribis:
> * gnu/packages/linux.scm (nfs-utils): New variable.
(gnu packages linux) was meant for things that use non-portable
interfaces of the kernel Linux. I don’t think that is the case here?
So maybe this should go to (gnu packages onc-rpc) or (gnu packages nfs).
> + #:phases (modify-phases %standard-phases
> + (add-before
> + 'configure 'mutate-source
Move to line above.
Maybe ‘adjust-command-file-names’ would be more descriptive a phase
name?
> + (lambda _
> + ;; Eventually, we should provide our own start-statd
> + ;; script instead ... one which starts the rpc.statd
> + ;; service (which we don't yet have)
> + (substitute* `("utils/statd/start-statd")
> + (("^PATH=.*") "")
> + (("^flock")
> + (string-append
> + (assoc-ref %build-inputs "util-linux")
> + "/bin/flock"))
> + (("^exec rpc.statd")
> + (string-append "exec "
> + (assoc-ref %outputs "out") "/sbin/rpc.statd")))
I think the comment should probably mention something like “Remove FHS
assumptions from the 'start-statd' script.” The bit about the need for
a service is not really relevant here, IMO.
Please punctuate sentences too. :-)
> + ;; It is hard to be sure what the licence is. Most of the source files
> + ;; contain no licence notice at all. A few have a licence notice for a 3
> + ;; clause non-copyleft licence. However the tarball has a COPYING file
> + ;; with the text of GPLv2 -- It seems then that GLPv2 is the most
> + ;; restrictive licence, and until advice to the contrary we must assume
> + ;; that is what is intended.
> + (license license:gpl2)))
I think this should be gpl2+ unless the “or later version” wording has
been explicitly removed.
OK with these changes, thanks!
Ludo’.
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2016-09-12 13:38 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-09-07 20:20 [PATCH] gnu: Add nfs-utils John Darrington
2016-09-07 20:29 ` Danny Milosavljevic
2016-09-07 20:35 ` John Darrington
2016-09-12 13:37 ` Ludovic Courtès
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/guix.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.