guix-devel
[Top][All Lists]
Advanced

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

[PATCH] list-packages: Display package usage count.


From: Eric Bavier
Subject: [PATCH] list-packages: Display package usage count.
Date: Mon, 20 Oct 2014 12:15:33 -0500
User-agent: mu4e 0.9.9.5; emacs 23.3.1

This patch adds a simple message like "used by X other packages" to each
packages description on
https://www.gnu.org/software/guix/package-list.html.

>From 41a3599bcdc3888085379801e9a7f05430ffe0c3 Mon Sep 17 00:00:00 2001
From: Eric Bavier <address@hidden>
Date: Mon, 20 Oct 2014 12:12:28 -0500
Subject: [PATCH] list-packages: Display package usage count.

* gnu/packages.scm (find-packages, find-package-by-name*): New
  procedures.
* build-aux/list-packages.scm (package->sxml)[users]: New local
  procedure.
---
 build-aux/list-packages.scm |    8 ++++++++
 gnu/packages.scm            |   12 ++++++++----
 2 files changed, 16 insertions(+), 4 deletions(-)

diff --git a/build-aux/list-packages.scm b/build-aux/list-packages.scm
index 7b046fe..276c153 100755
--- a/build-aux/list-packages.scm
+++ b/build-aux/list-packages.scm
@@ -166,6 +166,13 @@ decreasing, is 1."
           ,(url "i686-linux") " "
           ,(url "mips64el-linux")))
 
+  (define (users package)
+    (let ((n (length (package-transitive-dependents
+                      (find-packages-by-name* (package-name package)
+                                              (package-version package))))))
+      (and (> n 0)
+           `(div "used by " ,n " other " ,(if (= n 1) "package" "packages")))))
+
   (define (package-logo name)
     (and=> (lookup-gnu-package name)
            gnu-package-logo))
@@ -206,6 +213,7 @@ description-ids as formal parameters."
                        ,(package-home-page package))
                     ,(status package)
                     ,(patches package)
+                    ,(users package)
                     ,(if js?
                          (insert-js-call description-ids)
                          ""))))))
diff --git a/gnu/packages.scm b/gnu/packages.scm
index d3a064c..2ec160a 100644
--- a/gnu/packages.scm
+++ b/gnu/packages.scm
@@ -41,6 +41,7 @@
             fold-packages*
 
             find-packages-by-name
+            find-packages-by-name*
             find-best-packages-by-name
             find-newest-available-packages
 
@@ -192,11 +193,11 @@ guaranteed to never traverse the same package twice."
         (filter package? inputs))))
    (fold-packages cons '())))
 
-(define find-packages-by-name
+(define (find-packages fold)
   (let ((packages (delay
-                    (fold-packages (lambda (p r)
-                                     (vhash-cons (package-name p) p r))
-                                   vlist-null))))
+                    (fold (lambda (p r)
+                            (vhash-cons (package-name p) p r))
+                          vlist-null))))
     (lambda* (name #:optional version)
       "Return the list of packages with the given NAME.  If VERSION is not #f,
 then only return packages whose version is equal to VERSION."
@@ -207,6 +208,9 @@ then only return packages whose version is equal to 
VERSION."
                     matching)
             matching)))))
 
+(define find-packages-by-name  (find-packages fold-packages))
+(define find-packages-by-name* (find-packages fold-packages*))
+
 (define find-newest-available-packages
   (memoize
    (lambda ()
-- 
1.7.9.5

-- 
Eric Bavier

reply via email to

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