guix-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[shepherd] 01/04: herd: 'herd status' now sorts the result.


From: Ludovic Courtès
Subject: [shepherd] 01/04: herd: 'herd status' now sorts the result.
Date: Sun, 4 Feb 2018 17:45:28 -0500 (EST)

civodul pushed a commit to branch master
in repository shepherd.

commit cc9564586729a5bb90dd5d2722b543fdde9ab821
Author: Ludovic Courtès <address@hidden>
Date:   Sun Feb 4 21:56:36 2018 +0100

    herd: 'herd status' now sorts the result.
    
    Partly fixes <https://bugs.gnu.org/30299>.
    Reported by Mark H Weaver <address@hidden>.
    
    Previously 'tests/basic.sh' could occasionally fail on:
    
      test "`$herd status`" == "$pristine_status"
    
    because the order of stopped services were not always the same.  Indeed,
    those services come from 'service-list' on the shepherd side, which uses
    'hash-fold' to traverse the service hash table, and the traversal order
    of 'hash-fold' is undefined.
    
    * modules/shepherd/scripts/herd.scm (display-status-summary)[service<?]:
    New procedure.
    [display-services]: Call 'sort' and use the above.
---
 modules/shepherd/scripts/herd.scm | 8 ++++++--
 modules/shepherd/service.scm      | 5 +++--
 2 files changed, 9 insertions(+), 4 deletions(-)

diff --git a/modules/shepherd/scripts/herd.scm 
b/modules/shepherd/scripts/herd.scm
index ebcd1e1..697446c 100644
--- a/modules/shepherd/scripts/herd.scm
+++ b/modules/shepherd/scripts/herd.scm
@@ -1,5 +1,5 @@
 ;; herd.scm -- The program to herd the Shepherd.
-;; Copyright (C) 2013, 2014, 2016 Ludovic Courtès <address@hidden>
+;; Copyright (C) 2013, 2014, 2016, 2018 Ludovic Courtès <address@hidden>
 ;; Copyright (C) 2002, 2003 Wolfgang Jährling <address@hidden>
 ;;
 ;; This file is part of the GNU Shepherd.
@@ -46,13 +46,17 @@ of pairs."
 
 (define (display-status-summary services)
   "Display a summary of the status of all of SERVICES."
+  (define (service<? service1 service2)
+    (string<? (symbol->string (service-canonical-name service1))
+              (symbol->string (service-canonical-name service2))))
+
   (define (display-services header bullet services)
     (unless (null? services)
       (display header)
       (for-each (lambda (service)
                   (format #t " ~a ~a~%" bullet
                           (service-canonical-name service)))
-                services)))
+                (sort services service<?))))      ;get deterministic output
   (call-with-values
       (lambda ()
         (partition (match-lambda
diff --git a/modules/shepherd/service.scm b/modules/shepherd/service.scm
index 0ad28a0..83600e4 100644
--- a/modules/shepherd/service.scm
+++ b/modules/shepherd/service.scm
@@ -1,5 +1,5 @@
 ;; service.scm -- Representation of services.
-;; Copyright (C) 2013, 2014, 2015, 2016, 2017 Ludovic Courtès <address@hidden>
+;; Copyright (C) 2013, 2014, 2015, 2016, 2017, 2018 Ludovic Courtès 
<address@hidden>
 ;; Copyright (C) 2002, 2003 Wolfgang Järling <address@hidden>
 ;; Copyright (C) 2014 Alex Sassmannshausen <address@hidden>
 ;; Copyright (C) 2016 Alex Kost <address@hidden>
@@ -949,7 +949,8 @@ Return #f if service is not found."
                  %services))
 
 (define (service-list)
-  "Return the list of services currently defined."
+  "Return the list of services currently defined.  Note: The order of the list
+returned in unspecified."
   (hash-fold (lambda (name services result)
                (let ((service (lookup-canonical-service name services)))
                  (if service



reply via email to

[Prev in Thread] Current Thread [Next in Thread]