emacs: Display supported systems in "Package Info".

* emacs/guix-main.scm (%package-param-alist): Add 'systems'.
* emacs/guix-ui-package.el (guix-package-info-insert-systems): New
  procedure.
  (guix-package-info-format): Add it.
  (guix-output-info-format): Likewise.
  (guix-package-info-titles): Add "Supported systems" title.
This commit is contained in:
Alex Kost 2015-12-28 21:40:06 +03:00
parent cb933df6da
commit 0a5ec7092d
2 changed files with 19 additions and 1 deletions

View file

@ -307,6 +307,7 @@ (define %package-param-alist
(description . ,package-description-string) (description . ,package-description-string)
(home-url . ,package-home-page) (home-url . ,package-home-page)
(outputs . ,package-outputs) (outputs . ,package-outputs)
(systems . ,package-supported-systems)
(non-unique . ,(negate package-unique?)) (non-unique . ,(negate package-unique?))
(inputs . ,(lambda (pkg) (inputs . ,(lambda (pkg)
(package-inputs-names (package-inputs-names

View file

@ -221,11 +221,13 @@ ENTRIES is a list of package entries to get info about packages."
(location format (format guix-package-location)) (location format (format guix-package-location))
(home-url format (format guix-url)) (home-url format (format guix-url))
(license format (format guix-package-info-license)) (license format (format guix-package-info-license))
(systems format guix-package-info-insert-systems)
(inputs format (format guix-package-input)) (inputs format (format guix-package-input))
(native-inputs format (format guix-package-native-input)) (native-inputs format (format guix-package-native-input))
(propagated-inputs format (propagated-inputs format
(format guix-package-propagated-input))) (format guix-package-propagated-input)))
:titles '((home-url . "Home page")) :titles '((home-url . "Home page")
(systems . "Supported systems"))
:required '(id name version installed non-unique)) :required '(id name version installed non-unique))
(guix-info-define-interface installed-output (guix-info-define-interface installed-output
@ -363,6 +365,20 @@ formatted with this string, an action button is inserted.")
'guix-package-name 'guix-package-name
'face 'guix-package-info-heading)) 'face 'guix-package-info-heading))
(defun guix-package-info-insert-systems (systems entry)
"Insert supported package SYSTEMS at point."
(guix-info-insert-value-format
systems 'guix-hydra-build-system
'action (lambda (btn)
(let ((args (guix-hydra-build-latest-prompt-args
:job (button-get btn 'job-name)
:system (button-label btn))))
(apply #'guix-hydra-build-get-display
'latest args)))
'job-name (guix-package-name-specification
(guix-entry-value entry 'name)
(guix-entry-value entry 'version))))
(defmacro guix-package-info-define-insert-inputs (&optional type) (defmacro guix-package-info-define-insert-inputs (&optional type)
"Define a face and a function for inserting package inputs. "Define a face and a function for inserting package inputs.
TYPE is a type of inputs. TYPE is a type of inputs.
@ -749,6 +765,7 @@ for all ARGS."
(location format (format guix-package-location)) (location format (format guix-package-location))
(home-url format (format guix-url)) (home-url format (format guix-url))
(license format (format guix-package-info-license)) (license format (format guix-package-info-license))
(systems format guix-package-info-insert-systems)
(inputs format (format guix-package-input)) (inputs format (format guix-package-input))
(native-inputs format (format guix-package-native-input)) (native-inputs format (format guix-package-native-input))
(propagated-inputs format (propagated-inputs format