summary refs log tree commit diff
path: root/gnu/services/shepherd.scm
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2016-08-31 12:38:38 +0200
committerLudovic Courtès <ludo@gnu.org>2016-08-31 15:44:20 +0200
commita5d78eb64bcb87440a0b3ff25eec5568df0bc47c (patch)
tree0e358fc5568bfd4ac5577c91de3eaca235aacbf1 /gnu/services/shepherd.scm
parentb8692e4696d0d2b36466827da1e0d25d69a298af (diff)
downloadguix-a5d78eb64bcb87440a0b3ff25eec5568df0bc47c.tar.gz
services: shepherd: Add 'shepherd-service-lookup-procedure'.
* gnu/services/shepherd.scm (shepherd-service-lookup-procedure): New
procedure.
(shepherd-service-back-edges)[provision->service]: Use it.
* tests/services.scm ("shepherd-service-lookup-procedure"): New test.
Diffstat (limited to 'gnu/services/shepherd.scm')
-rw-r--r--gnu/services/shepherd.scm30
1 files changed, 20 insertions, 10 deletions
diff --git a/gnu/services/shepherd.scm b/gnu/services/shepherd.scm
index a14f51592a..3cfca8574e 100644
--- a/gnu/services/shepherd.scm
+++ b/gnu/services/shepherd.scm
@@ -52,6 +52,7 @@
 
             shepherd-service-file
 
+            shepherd-service-lookup-procedure
             shepherd-service-back-edges))
 
 ;;; Commentary:
@@ -249,20 +250,29 @@ stored."
 
     (gexp->file "shepherd.conf" config)))
 
+(define* (shepherd-service-lookup-procedure services
+                                            #:optional
+                                            (provision
+                                             shepherd-service-provision))
+  "Return a procedure that, when passed a symbol, return the item among
+SERVICES that provides this symbol.  PROVISION must be a one-argument
+procedure that takes a service and returns the list of symbols it provides."
+  (let ((services (fold (lambda (service result)
+                          (fold (cut vhash-consq <> service <>)
+                                result
+                                (provision service)))
+                        vlist-null
+                        services)))
+    (lambda (name)
+      (match (vhash-assq name services)
+        ((_ . service) service)
+        (#f            #f)))))
+
 (define (shepherd-service-back-edges services)
   "Return a procedure that, when given a <shepherd-service> from SERVICES,
 returns the list of <shepherd-service> that depend on it."
   (define provision->service
-    (let ((services (fold (lambda (service result)
-                            (fold (cut vhash-consq <> service <>)
-                                  result
-                                  (shepherd-service-provision service)))
-                          vlist-null
-                          services)))
-      (lambda (name)
-        (match (vhash-assq name services)
-          ((_ . service) service)
-          (#f            #f)))))
+    (shepherd-service-lookup-procedure services))
 
   (define edges
     (fold (lambda (service edges)