emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
;;; guix-info.el --- Info buffers for displaying entries -*- lexical-binding: t -*-
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-07-13 22:08:11 +02:00
|
|
|
|
;; Copyright © 2014, 2015 Alex Kost <alezost@gmail.com>
|
|
|
|
|
;; Copyright © 2015 Ludovic Courtès <ludo@gnu.org>
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
;; This file is part of GNU Guix.
|
|
|
|
|
|
|
|
|
|
;; GNU Guix is free software; you can redistribute it and/or modify
|
|
|
|
|
;; it under the terms of the GNU General Public License as published by
|
|
|
|
|
;; the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
;; (at your option) any later version.
|
|
|
|
|
|
|
|
|
|
;; GNU Guix is distributed in the hope that it will be useful,
|
|
|
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
;; GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
|
|
|
|
;; along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
|
|
;;; Commentary:
|
|
|
|
|
|
|
|
|
|
;; This file provides a help-like buffer for displaying information
|
|
|
|
|
;; about Guix packages and generations.
|
|
|
|
|
|
|
|
|
|
;;; Code:
|
|
|
|
|
|
|
|
|
|
(require 'guix-base)
|
2015-10-22 09:08:42 +02:00
|
|
|
|
(require 'guix-entry)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(require 'guix-utils)
|
2015-11-20 10:38:31 +01:00
|
|
|
|
(require 'guix-ui)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defgroup guix-info nil
|
|
|
|
|
"General settings for info buffers."
|
|
|
|
|
:prefix "guix-info-"
|
|
|
|
|
:group 'guix)
|
|
|
|
|
|
2015-09-14 22:32:53 +02:00
|
|
|
|
(defgroup guix-info-faces nil
|
|
|
|
|
"Faces for info buffers."
|
|
|
|
|
:group 'guix-info
|
|
|
|
|
:group 'guix-faces)
|
|
|
|
|
|
2015-12-08 09:22:14 +01:00
|
|
|
|
(defface guix-info-heading
|
|
|
|
|
'((((type tty pc) (class color)) :weight bold)
|
|
|
|
|
(t :height 1.6 :weight bold :inherit variable-pitch))
|
|
|
|
|
"Face for headings."
|
|
|
|
|
:group 'guix-info-faces)
|
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(defface guix-info-param-title
|
|
|
|
|
'((t :inherit font-lock-type-face))
|
|
|
|
|
"Face used for titles of parameters."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-info-file-path
|
|
|
|
|
'((t :inherit link))
|
|
|
|
|
"Face used for file paths."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-info-url
|
|
|
|
|
'((t :inherit link))
|
|
|
|
|
"Face used for URLs."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-info-time
|
|
|
|
|
'((t :inherit font-lock-constant-face))
|
|
|
|
|
"Face used for timestamps."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-info-action-button
|
|
|
|
|
'((((type x w32 ns) (class color))
|
|
|
|
|
:box (:line-width 2 :style released-button)
|
|
|
|
|
:background "lightgrey" :foreground "black")
|
|
|
|
|
(t :inherit button))
|
|
|
|
|
"Face used for action buttons."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-info-action-button-mouse
|
|
|
|
|
'((((type x w32 ns) (class color))
|
|
|
|
|
:box (:line-width 2 :style released-button)
|
|
|
|
|
:background "grey90" :foreground "black")
|
|
|
|
|
(t :inherit highlight))
|
|
|
|
|
"Mouse face used for action buttons."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(defcustom guix-info-ignore-empty-values nil
|
2014-08-27 14:44:17 +02:00
|
|
|
|
"If non-nil, do not display parameters with nil values."
|
|
|
|
|
:type 'boolean
|
|
|
|
|
:group 'guix-info)
|
|
|
|
|
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(defcustom guix-info-fill t
|
|
|
|
|
"If non-nil, fill string parameters to fit the window.
|
|
|
|
|
If nil, insert text parameters (like synopsis or description) in
|
|
|
|
|
a raw form."
|
|
|
|
|
:type 'boolean
|
|
|
|
|
:group 'guix-info)
|
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(defvar guix-info-param-title-format "%-18s: "
|
|
|
|
|
"String used to format a title of a parameter.
|
|
|
|
|
It should be a '%s'-sequence. After inserting a title formatted
|
|
|
|
|
with this string, a value of the parameter is inserted.
|
2015-11-19 22:13:19 +01:00
|
|
|
|
This string is used by `guix-info-insert-title-format'.")
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(defvar guix-info-multiline-prefix
|
|
|
|
|
(make-string (length (format guix-info-param-title-format " "))
|
|
|
|
|
?\s)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
"String used to format multi-line parameter values.
|
|
|
|
|
If a value occupies more than one line, this string is inserted
|
|
|
|
|
in the beginning of each line after the first one.
|
2015-11-19 22:13:19 +01:00
|
|
|
|
This string is used by `guix-info-insert-value-format'.")
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defvar guix-info-indent 2
|
|
|
|
|
"Number of spaces used to indent various parts of inserted text.")
|
|
|
|
|
|
|
|
|
|
(defvar guix-info-delimiter "\n\f\n"
|
|
|
|
|
"String used to separate entries.")
|
|
|
|
|
|
2015-11-20 19:25:10 +01:00
|
|
|
|
|
|
|
|
|
;;; Wrappers for 'info' variables
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-20 19:25:10 +01:00
|
|
|
|
(defvar guix-info-data nil
|
|
|
|
|
"Alist with 'info' data.
|
|
|
|
|
This alist is filled by `guix-info-define-interface' macro.")
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-20 19:25:10 +01:00
|
|
|
|
(defun guix-info-value (entry-type symbol)
|
|
|
|
|
"Return SYMBOL's value for ENTRY-TYPE from `guix-info-data'."
|
|
|
|
|
(symbol-value (guix-assq-value guix-info-data entry-type symbol)))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(defun guix-info-param-title (entry-type param)
|
|
|
|
|
"Return a title of an ENTRY-TYPE parameter PARAM."
|
2015-11-21 09:35:43 +01:00
|
|
|
|
(guix-buffer-param-title 'info entry-type param))
|
2015-11-19 22:13:19 +01:00
|
|
|
|
|
|
|
|
|
(defun guix-info-format (entry-type)
|
|
|
|
|
"Return 'info' format for ENTRY-TYPE."
|
2015-11-20 19:25:10 +01:00
|
|
|
|
(guix-info-value entry-type 'format))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-18 09:36:27 +01:00
|
|
|
|
(defun guix-info-displayed-params (entry-type)
|
2015-11-19 22:13:19 +01:00
|
|
|
|
"Return a list of ENTRY-TYPE parameters that should be displayed."
|
|
|
|
|
(delq nil
|
|
|
|
|
(mapcar (lambda (spec)
|
|
|
|
|
(pcase spec
|
|
|
|
|
(`(,param . ,_) param)))
|
|
|
|
|
(guix-info-format entry-type))))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;;; Inserting entries
|
|
|
|
|
|
|
|
|
|
(defvar guix-info-title-aliases
|
|
|
|
|
'((format . guix-info-insert-title-format)
|
|
|
|
|
(simple . guix-info-insert-title-simple))
|
|
|
|
|
"Alist of aliases and functions to insert titles.")
|
|
|
|
|
|
|
|
|
|
(defvar guix-info-value-aliases
|
|
|
|
|
'((format . guix-info-insert-value-format)
|
|
|
|
|
(indent . guix-info-insert-value-indent)
|
|
|
|
|
(simple . guix-info-insert-value-simple)
|
|
|
|
|
(time . guix-info-insert-time))
|
|
|
|
|
"Alist of aliases and functions to insert values.")
|
|
|
|
|
|
|
|
|
|
(defun guix-info-title-function (fun-or-alias)
|
|
|
|
|
"Convert FUN-OR-ALIAS into a function to insert a title."
|
|
|
|
|
(or (guix-assq-value guix-info-title-aliases fun-or-alias)
|
|
|
|
|
fun-or-alias))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-value-function (fun-or-alias)
|
|
|
|
|
"Convert FUN-OR-ALIAS into a function to insert a value."
|
|
|
|
|
(or (guix-assq-value guix-info-value-aliases fun-or-alias)
|
|
|
|
|
fun-or-alias))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-title-method->function (method)
|
|
|
|
|
"Convert title METHOD into a function to insert a title."
|
|
|
|
|
(pcase method
|
|
|
|
|
((pred null) #'ignore)
|
|
|
|
|
((pred symbolp) (guix-info-title-function method))
|
|
|
|
|
(`(,fun-or-alias . ,rest-args)
|
|
|
|
|
(lambda (title)
|
|
|
|
|
(apply (guix-info-title-function fun-or-alias)
|
|
|
|
|
title rest-args)))
|
|
|
|
|
(_ (error "Unknown title method '%S'" method))))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-value-method->function (method)
|
|
|
|
|
"Convert value METHOD into a function to insert a value."
|
|
|
|
|
(pcase method
|
|
|
|
|
((pred null) #'ignore)
|
|
|
|
|
((pred functionp) method)
|
|
|
|
|
(`(,fun-or-alias . ,rest-args)
|
|
|
|
|
(lambda (value _)
|
|
|
|
|
(apply (guix-info-value-function fun-or-alias)
|
|
|
|
|
value rest-args)))
|
|
|
|
|
(_ (error "Unknown value method '%S'" method))))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-fill-column ()
|
|
|
|
|
"Return fill column for the current window."
|
|
|
|
|
(min (window-width) fill-column))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defun guix-info-get-indent (&optional level)
|
|
|
|
|
"Return `guix-info-indent' \"multiplied\" by LEVEL spaces.
|
|
|
|
|
LEVEL is 1 by default."
|
|
|
|
|
(make-string (* guix-info-indent (or level 1)) ?\s))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-insert-indent (&optional level)
|
|
|
|
|
"Insert `guix-info-indent' spaces LEVEL times (1 by default)."
|
|
|
|
|
(insert (guix-info-get-indent level)))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-insert-entries (entries entry-type)
|
|
|
|
|
"Display ENTRIES of ENTRY-TYPE in the current info buffer.
|
|
|
|
|
ENTRIES should have a form of `guix-entries'."
|
|
|
|
|
(guix-mapinsert (lambda (entry)
|
|
|
|
|
(guix-info-insert-entry entry entry-type))
|
|
|
|
|
entries
|
|
|
|
|
guix-info-delimiter))
|
|
|
|
|
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(defun guix-info-insert-entry (entry entry-type &optional indent-level)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
"Insert ENTRY of ENTRY-TYPE into the current info buffer.
|
2015-11-19 22:13:19 +01:00
|
|
|
|
If INDENT-LEVEL is non-nil, indent displayed data by this number
|
|
|
|
|
of `guix-info-indent' spaces."
|
2015-11-17 20:10:46 +01:00
|
|
|
|
(guix-with-indent (* (or indent-level 0)
|
|
|
|
|
guix-info-indent)
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(dolist (spec (guix-info-format entry-type))
|
|
|
|
|
(guix-info-insert-entry-unit spec entry entry-type))))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(defun guix-info-insert-entry-unit (format-spec entry entry-type)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
"Insert title and value of a PARAM at point.
|
|
|
|
|
ENTRY is alist with parameters and their values.
|
|
|
|
|
ENTRY-TYPE is a type of ENTRY."
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(pcase format-spec
|
|
|
|
|
((pred functionp)
|
|
|
|
|
(funcall format-spec entry)
|
|
|
|
|
(insert "\n"))
|
|
|
|
|
(`(,param ,title-method ,value-method)
|
|
|
|
|
(let ((value (guix-entry-value entry param)))
|
|
|
|
|
(unless (and guix-info-ignore-empty-values (null value))
|
|
|
|
|
(let ((title (guix-info-param-title entry-type param))
|
|
|
|
|
(insert-title (guix-info-title-method->function title-method))
|
|
|
|
|
(insert-value (guix-info-value-method->function value-method)))
|
|
|
|
|
(funcall insert-title title)
|
|
|
|
|
(funcall insert-value value entry)
|
|
|
|
|
(insert "\n")))))
|
|
|
|
|
(_ (error "Unknown format specification '%S'" format-spec))))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-insert-title-simple (title &optional face)
|
|
|
|
|
"Insert \"TITLE: \" string at point.
|
|
|
|
|
If FACE is nil, use `guix-info-param-title'."
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(guix-format-insert title
|
|
|
|
|
(or face 'guix-info-param-title)
|
2015-11-19 22:13:19 +01:00
|
|
|
|
"%s: "))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(defun guix-info-insert-title-format (title &optional face)
|
|
|
|
|
"Insert TITLE using `guix-info-param-title-format' at point.
|
|
|
|
|
If FACE is nil, use `guix-info-param-title'."
|
|
|
|
|
(guix-format-insert title
|
|
|
|
|
(or face 'guix-info-param-title)
|
|
|
|
|
guix-info-param-title-format))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-insert-value-simple (value &optional button-or-face indent)
|
|
|
|
|
"Format and insert parameter VALUE at point.
|
|
|
|
|
|
|
|
|
|
VALUE may be split into several short lines to fit the current
|
|
|
|
|
window, depending on `guix-info-fill', and each line is indented
|
|
|
|
|
with INDENT number of spaces.
|
|
|
|
|
|
|
|
|
|
If BUTTON-OR-FACE is a button type symbol, transform VALUE into
|
|
|
|
|
this (these) button(s) and insert each one on a new line. If it
|
|
|
|
|
is a face symbol, propertize inserted line(s) with this face."
|
|
|
|
|
(or indent (setq indent 0))
|
|
|
|
|
(guix-with-indent indent
|
|
|
|
|
(let* ((button? (guix-button-type? button-or-face))
|
|
|
|
|
(face (unless button? button-or-face))
|
|
|
|
|
(fill-col (unless (or button?
|
|
|
|
|
(and (stringp value)
|
|
|
|
|
(not guix-info-fill)))
|
|
|
|
|
(- (guix-info-fill-column) indent)))
|
|
|
|
|
(value (if (and value button?)
|
|
|
|
|
(guix-buttonize value button-or-face "\n")
|
|
|
|
|
value)))
|
|
|
|
|
(guix-split-insert value face fill-col "\n"))))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-insert-value-indent (value &optional button-or-face)
|
|
|
|
|
"Format and insert parameter VALUE at point.
|
|
|
|
|
|
|
|
|
|
This function is intended to be called after inserting a title
|
|
|
|
|
with `guix-info-insert-title-simple'.
|
|
|
|
|
|
|
|
|
|
VALUE may be split into several short lines to fit the current
|
|
|
|
|
window, depending on `guix-info-fill', and each line is indented
|
|
|
|
|
with `guix-info-indent'.
|
|
|
|
|
|
|
|
|
|
For the meaning of BUTTON-OR-FACE, see `guix-info-insert-value-simple'."
|
|
|
|
|
(when value (insert "\n"))
|
|
|
|
|
(guix-info-insert-value-simple value button-or-face guix-info-indent))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-insert-value-format (value &optional button-or-face
|
|
|
|
|
&rest button-properties)
|
|
|
|
|
"Format and insert parameter VALUE at point.
|
|
|
|
|
|
|
|
|
|
This function is intended to be called after inserting a title
|
|
|
|
|
with `guix-info-insert-title-format'.
|
|
|
|
|
|
|
|
|
|
VALUE may be split into several short lines to fit the current
|
|
|
|
|
window, depending on `guix-info-fill' and
|
|
|
|
|
`guix-info-multiline-prefix'. If VALUE is a list, its elements
|
|
|
|
|
will be separated with `guix-list-separator'.
|
|
|
|
|
|
|
|
|
|
If BUTTON-OR-FACE is a button type symbol, transform VALUE into
|
|
|
|
|
this (these) button(s). If it is a face symbol, propertize
|
|
|
|
|
inserted line(s) with this face.
|
|
|
|
|
|
|
|
|
|
BUTTON-PROPERTIES are passed to `guix-buttonize' (only if
|
|
|
|
|
BUTTON-OR-FACE is a button type)."
|
|
|
|
|
(let* ((button? (guix-button-type? button-or-face))
|
|
|
|
|
(face (unless button? button-or-face))
|
|
|
|
|
(fill-col (when (or button?
|
|
|
|
|
guix-info-fill
|
|
|
|
|
(not (stringp value)))
|
|
|
|
|
(- (guix-info-fill-column)
|
|
|
|
|
(length guix-info-multiline-prefix))))
|
|
|
|
|
(value (if (and value button?)
|
|
|
|
|
(apply #'guix-buttonize
|
|
|
|
|
value button-or-face guix-list-separator
|
|
|
|
|
button-properties)
|
|
|
|
|
value)))
|
|
|
|
|
(guix-split-insert value face fill-col
|
|
|
|
|
(concat "\n" guix-info-multiline-prefix))))
|
|
|
|
|
|
|
|
|
|
(defun guix-info-insert-time (seconds &optional face)
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
"Insert formatted time string using SECONDS at point."
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(guix-format-insert (guix-get-time-string seconds)
|
|
|
|
|
(or face 'guix-info-time)))
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;;; Buttons
|
|
|
|
|
|
2014-11-08 18:13:32 +01:00
|
|
|
|
(defvar guix-info-button-map
|
|
|
|
|
(let ((map (make-sparse-keymap)))
|
|
|
|
|
(set-keymap-parent map button-map)
|
|
|
|
|
(define-key map (kbd "c") 'guix-info-button-copy-label)
|
|
|
|
|
map)
|
|
|
|
|
"Keymap for buttons in info buffers.")
|
|
|
|
|
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
(define-button-type 'guix
|
2014-11-08 18:13:32 +01:00
|
|
|
|
'keymap guix-info-button-map
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
'follow-link t)
|
|
|
|
|
|
|
|
|
|
(define-button-type 'guix-action
|
|
|
|
|
:supertype 'guix
|
|
|
|
|
'face 'guix-info-action-button
|
|
|
|
|
'mouse-face 'guix-info-action-button-mouse)
|
|
|
|
|
|
|
|
|
|
(define-button-type 'guix-file
|
|
|
|
|
:supertype 'guix
|
|
|
|
|
'face 'guix-info-file-path
|
|
|
|
|
'help-echo "Find file"
|
|
|
|
|
'action (lambda (btn)
|
2014-11-10 13:29:04 +01:00
|
|
|
|
(guix-find-file (button-label btn))))
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
|
|
|
|
|
(define-button-type 'guix-url
|
|
|
|
|
:supertype 'guix
|
|
|
|
|
'face 'guix-info-url
|
|
|
|
|
'help-echo "Browse URL"
|
|
|
|
|
'action (lambda (btn)
|
|
|
|
|
(browse-url (button-label btn))))
|
|
|
|
|
|
|
|
|
|
(define-button-type 'guix-package-location
|
|
|
|
|
:supertype 'guix
|
|
|
|
|
'face 'guix-package-info-location
|
|
|
|
|
'help-echo "Find location of this package"
|
|
|
|
|
'action (lambda (btn)
|
|
|
|
|
(guix-find-location (button-label btn))))
|
|
|
|
|
|
|
|
|
|
(define-button-type 'guix-package-name
|
|
|
|
|
:supertype 'guix
|
|
|
|
|
'face 'guix-package-info-name-button
|
|
|
|
|
'help-echo "Describe this package"
|
|
|
|
|
'action (lambda (btn)
|
emacs: Improve interface for working with multiple profiles.
Suggested by David Thompson, Ludovic Courtès and Mathieu Lirzin.
* emacs/guix-base.el (guix-profile-prompt): New procedure.
(guix-set-current-profile): Use it.
(guix-buffer-name-simple, guix-buffer-name-default, guix-buffer-name): New
procedures.
(guix-buffer-name-function, guix-profile): New variables.
(guix-set-vars, guix-get-entries, guix-get-show-entries, guix-set-buffer,
guix-history-call, guix-process-package-actions,
guix-continue-package-operation-p, guix-delete-generations,
guix-switch-to-generation): Add 'profile' argument.
* emacs/guix.el (guix-get-show-packages, guix-get-show-generations,
guix-search-by-name, guix-search-by-regexp, guix-installed-packages,
guix-obsolete-packages, guix-all-available-packages,
guix-newest-available-packages, guix-generations, guix-generations-by-time):
Likewise.
(guix-last-generations): New command.
* emacs/guix-info.el: Adjust for using 'profile' argument where needed.
* emacs/guix-list.el: Likewise.
* doc/emacs.texi (Emacs Commands): Document 'guix-last-generations' and using
"C-u" for commands.
(Emacs Buffer Names): Document 'guix-buffer-name-function'.
2014-10-17 20:21:32 +02:00
|
|
|
|
(guix-get-show-entries guix-profile 'info guix-package-info-type
|
|
|
|
|
'name (button-label btn))))
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
|
2014-11-08 18:13:32 +01:00
|
|
|
|
(defun guix-info-button-copy-label (&optional pos)
|
|
|
|
|
"Copy a label of the button at POS into kill ring.
|
|
|
|
|
If POS is nil, use the current point position."
|
|
|
|
|
(interactive)
|
|
|
|
|
(let ((button (button-at (or pos (point)))))
|
|
|
|
|
(when button
|
2015-12-05 21:51:43 +01:00
|
|
|
|
(guix-copy-as-kill (button-label button)))))
|
2014-11-08 18:13:32 +01:00
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(defun guix-info-insert-action-button (label action &optional message
|
|
|
|
|
&rest properties)
|
|
|
|
|
"Make action button with LABEL and insert it at point.
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
ACTION is a function called when the button is pressed. It
|
|
|
|
|
should accept button as the argument.
|
|
|
|
|
MESSAGE is a button message.
|
|
|
|
|
See `insert-text-button' for the meaning of PROPERTIES."
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(apply #'guix-insert-button
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
label 'guix-action
|
|
|
|
|
'action action
|
|
|
|
|
'help-echo message
|
2014-08-27 14:44:17 +02:00
|
|
|
|
properties))
|
|
|
|
|
|
|
|
|
|
|
2015-11-20 10:38:31 +01:00
|
|
|
|
;;; Major mode and interface definer
|
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(defvar guix-info-mode-map
|
|
|
|
|
(let ((map (make-sparse-keymap)))
|
|
|
|
|
(set-keymap-parent
|
2015-11-21 10:25:19 +01:00
|
|
|
|
map (make-composed-keymap (list guix-buffer-map button-buffer-map)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
special-mode-map))
|
|
|
|
|
map)
|
2015-11-21 10:25:19 +01:00
|
|
|
|
"Keymap for `guix-info-mode' buffers.")
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(define-derived-mode guix-info-mode special-mode "Guix-Info"
|
|
|
|
|
"Parent mode for displaying information in info buffers.")
|
|
|
|
|
|
2015-11-20 10:38:31 +01:00
|
|
|
|
(defmacro guix-info-define-interface (entry-type &rest args)
|
|
|
|
|
"Define 'info' interface for displaying ENTRY-TYPE entries.
|
|
|
|
|
Remaining arguments (ARGS) should have a form [KEYWORD VALUE] ...
|
|
|
|
|
|
2015-11-20 19:25:10 +01:00
|
|
|
|
Required keywords:
|
|
|
|
|
|
|
|
|
|
- `:format' - default value of the generated
|
|
|
|
|
`guix-ENTRY-TYPE-info-format' variable.
|
|
|
|
|
|
2015-11-20 10:38:31 +01:00
|
|
|
|
The rest keyword arguments are passed to
|
|
|
|
|
`guix-buffer-define-interface' macro."
|
|
|
|
|
(declare (indent 1))
|
2015-11-20 19:25:10 +01:00
|
|
|
|
(let* ((entry-type-str (symbol-name entry-type))
|
|
|
|
|
(prefix (concat "guix-" entry-type-str "-info"))
|
|
|
|
|
(group (intern prefix))
|
|
|
|
|
(format-var (intern (concat prefix "-format"))))
|
|
|
|
|
(guix-keyword-args-let args
|
|
|
|
|
((format-val :format))
|
|
|
|
|
`(progn
|
|
|
|
|
(defcustom ,format-var ,format-val
|
|
|
|
|
,(format "\
|
|
|
|
|
List of methods for inserting '%s' entry.
|
|
|
|
|
Each METHOD should be either a function or should have the
|
|
|
|
|
following form:
|
|
|
|
|
|
|
|
|
|
(PARAM INSERT-TITLE INSERT-VALUE)
|
|
|
|
|
|
|
|
|
|
If METHOD is a function, it is called with an entry as argument.
|
|
|
|
|
|
|
|
|
|
PARAM is a name of '%s' entry parameter.
|
|
|
|
|
|
|
|
|
|
INSERT-TITLE may be either a symbol or a list. If it is a
|
|
|
|
|
symbol, it should be a function or an alias from
|
|
|
|
|
`guix-info-title-aliases', in which case it is called with title
|
|
|
|
|
as argument. If it is a list, it should have a
|
|
|
|
|
form (FUN-OR-ALIAS [ARGS ...]), in which case FUN-OR-ALIAS is
|
|
|
|
|
called with title and ARGS as arguments.
|
|
|
|
|
|
|
|
|
|
INSERT-VALUE may be either a symbol or a list. If it is a
|
|
|
|
|
symbol, it should be a function or an alias from
|
|
|
|
|
`guix-info-value-aliases', in which case it is called with value
|
|
|
|
|
and entry as arguments. If it is a list, it should have a
|
|
|
|
|
form (FUN-OR-ALIAS [ARGS ...]), in which case FUN-OR-ALIAS is
|
|
|
|
|
called with value and ARGS as arguments.
|
|
|
|
|
|
|
|
|
|
Parameters are inserted in the same order as defined by this list.
|
|
|
|
|
After calling each METHOD, a new line is inserted."
|
|
|
|
|
entry-type-str entry-type-str)
|
|
|
|
|
:type 'sexp
|
|
|
|
|
:group ',group)
|
|
|
|
|
|
|
|
|
|
(guix-alist-put!
|
|
|
|
|
'((format . ,format-var))
|
|
|
|
|
'guix-info-data ',entry-type)
|
|
|
|
|
|
|
|
|
|
(guix-buffer-define-interface info ,entry-type
|
|
|
|
|
,@%foreign-args)))))
|
2015-11-20 10:38:31 +01:00
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
;;; Displaying packages
|
|
|
|
|
|
2015-11-20 10:38:31 +01:00
|
|
|
|
(guix-ui-info-define-interface package
|
emacs: Generalize buffer naming.
* emacs/guix-base.el (guix-buffer-name): New procedure.
(guix-buffer-define-interface): Make ':buffer-name' a required keyword.
(guix-update-after-operation, guix-buffer-name-function)
(guix-buffer-name-simple, guix-buffer-name-default, guix-buffer-name)
(guix-buffer-p, guix-buffers, guix-update-buffer)
(guix-update-buffers-maybe-after-operation): Adjust, move and rename to...
* emacs/guix-ui.el (guix-ui-update-after-operation)
(guix-ui-buffer-name-function, guix-ui-buffer-name-simple)
(guix-ui-buffer-name-default, guix-ui-buffer-name)
(guix-ui-buffer?, guix-ui-buffers, guix-ui-update-buffer)
(guix-ui-update-buffers-after-operation): ... this.
(guix-ui-define-interface): Generate
'guix-ENTRY-TYPE-BUFFER-TYPE-buffer-name' procedure and pass it as
':buffer-name' argument.
(guix-ui): New custom group.
* emacs/guix-info.el: Specify ':buffer-name' for the defined interfaces.
* emacs/guix-list.el: Likewise.
* doc/emacs.texi (Emacs Appearance): Adjust accordingly.
2015-11-23 14:41:58 +01:00
|
|
|
|
:buffer-name "*Guix Package Info*"
|
2015-11-20 19:25:10 +01:00
|
|
|
|
:format '(guix-package-info-insert-heading
|
|
|
|
|
ignore
|
|
|
|
|
(synopsis ignore (simple guix-package-info-synopsis))
|
|
|
|
|
ignore
|
|
|
|
|
(description ignore (simple guix-package-info-description))
|
|
|
|
|
ignore
|
|
|
|
|
(outputs simple guix-package-info-insert-outputs)
|
|
|
|
|
(source simple guix-package-info-insert-source)
|
|
|
|
|
(location format (format guix-package-location))
|
|
|
|
|
(home-url format (format guix-url))
|
|
|
|
|
(license format (format guix-package-info-license))
|
|
|
|
|
(inputs format (format guix-package-input))
|
|
|
|
|
(native-inputs format (format guix-package-native-input))
|
|
|
|
|
(propagated-inputs format
|
|
|
|
|
(format guix-package-propagated-input)))
|
2015-11-21 09:35:43 +01:00
|
|
|
|
:titles '((home-url . "Home page"))
|
2015-11-20 10:38:31 +01:00
|
|
|
|
:required '(id name version installed non-unique))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2015-11-20 19:25:10 +01:00
|
|
|
|
(guix-info-define-interface installed-output
|
|
|
|
|
:format '((path simple (indent guix-file))
|
|
|
|
|
(dependencies simple (indent guix-file)))
|
2015-11-21 09:35:43 +01:00
|
|
|
|
:titles '((path . "Store directory"))
|
2015-11-20 19:25:10 +01:00
|
|
|
|
:reduced? t)
|
|
|
|
|
|
2014-10-30 22:11:55 +01:00
|
|
|
|
(defface guix-package-info-heading
|
2015-12-08 09:22:14 +01:00
|
|
|
|
'((t :inherit guix-info-heading))
|
2014-10-30 22:11:55 +01:00
|
|
|
|
"Face for package name and version headings."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-10-30 22:11:55 +01:00
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(defface guix-package-info-name
|
|
|
|
|
'((t :inherit font-lock-keyword-face))
|
|
|
|
|
"Face used for a name of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
(defface guix-package-info-name-button
|
|
|
|
|
'((t :inherit button))
|
|
|
|
|
"Face used for a full name that can be used to describe a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(defface guix-package-info-version
|
|
|
|
|
'((t :inherit font-lock-builtin-face))
|
|
|
|
|
"Face used for a version of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-package-info-synopsis
|
2014-10-30 22:11:55 +01:00
|
|
|
|
'((((type tty pc) (class color)) :weight bold)
|
|
|
|
|
(t :height 1.1 :weight bold :inherit variable-pitch))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
"Face used for a synopsis of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-package-info-description
|
|
|
|
|
'((t))
|
|
|
|
|
"Face used for a description of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-package-info-license
|
|
|
|
|
'((t :inherit font-lock-string-face))
|
|
|
|
|
"Face used for a license of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-package-info-location
|
|
|
|
|
'((t :inherit link))
|
|
|
|
|
"Face used for a location of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-package-info-installed-outputs
|
|
|
|
|
'((default :weight bold)
|
|
|
|
|
(((class color) (min-colors 88) (background light))
|
|
|
|
|
:foreground "ForestGreen")
|
|
|
|
|
(((class color) (min-colors 88) (background dark))
|
|
|
|
|
:foreground "PaleGreen")
|
|
|
|
|
(((class color) (min-colors 8))
|
|
|
|
|
:foreground "green")
|
|
|
|
|
(t :underline t))
|
|
|
|
|
"Face used for installed outputs of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-package-info-uninstalled-outputs
|
|
|
|
|
'((t :weight bold))
|
|
|
|
|
"Face used for uninstalled outputs of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-package-info-obsolete
|
|
|
|
|
'((t :inherit error))
|
|
|
|
|
"Face used if a package is obsolete."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2014-10-30 22:11:55 +01:00
|
|
|
|
(defun guix-package-info-insert-heading (entry)
|
2015-11-19 22:13:19 +01:00
|
|
|
|
"Insert package ENTRY heading (name specification) at point."
|
2015-11-22 22:18:38 +01:00
|
|
|
|
(guix-insert-button
|
|
|
|
|
(guix-package-entry->name-specification entry)
|
|
|
|
|
'guix-package-name
|
|
|
|
|
'face 'guix-package-info-heading))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defmacro guix-package-info-define-insert-inputs (&optional type)
|
|
|
|
|
"Define a face and a function for inserting package inputs.
|
|
|
|
|
TYPE is a type of inputs.
|
|
|
|
|
Function name is `guix-package-info-insert-TYPE-inputs'.
|
|
|
|
|
Face name is `guix-package-info-TYPE-inputs'."
|
|
|
|
|
(let* ((type-str (symbol-name type))
|
|
|
|
|
(type-name (and type (concat type-str "-")))
|
|
|
|
|
(type-desc (and type (concat type-str " ")))
|
|
|
|
|
(face (intern (concat "guix-package-info-" type-name "inputs")))
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(btn (intern (concat "guix-package-" type-name "input"))))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
`(progn
|
|
|
|
|
(defface ,face
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
'((t :inherit guix-package-info-name-button))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
,(concat "Face used for " type-desc "inputs of a package.")
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
(define-button-type ',btn
|
|
|
|
|
:supertype 'guix-package-name
|
2015-11-19 22:13:19 +01:00
|
|
|
|
'face ',face))))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(guix-package-info-define-insert-inputs)
|
|
|
|
|
(guix-package-info-define-insert-inputs native)
|
|
|
|
|
(guix-package-info-define-insert-inputs propagated)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;;; Inserting outputs and installed parameters
|
|
|
|
|
|
|
|
|
|
(defvar guix-package-info-output-format "%-10s"
|
|
|
|
|
"String used to format output names of the packages.
|
|
|
|
|
It should be a '%s'-sequence. After inserting an output name
|
|
|
|
|
formatted with this string, an action button is inserted.")
|
|
|
|
|
|
|
|
|
|
(defvar guix-package-info-obsolete-string "(This package is obsolete)"
|
|
|
|
|
"String used if a package is obsolete.")
|
|
|
|
|
|
|
|
|
|
(defun guix-package-info-insert-outputs (outputs entry)
|
|
|
|
|
"Insert OUTPUTS from package ENTRY at point."
|
2015-10-22 09:08:42 +02:00
|
|
|
|
(and (guix-entry-value entry 'obsolete)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(guix-package-info-insert-obsolete-text))
|
2015-10-22 09:08:42 +02:00
|
|
|
|
(and (guix-entry-value entry 'non-unique)
|
|
|
|
|
(guix-entry-value entry 'installed)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(guix-package-info-insert-non-unique-text
|
2015-11-18 09:36:27 +01:00
|
|
|
|
(guix-package-entry->name-specification entry)))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(insert "\n")
|
|
|
|
|
(mapc (lambda (output)
|
|
|
|
|
(guix-package-info-insert-output output entry))
|
|
|
|
|
outputs))
|
|
|
|
|
|
|
|
|
|
(defun guix-package-info-insert-obsolete-text ()
|
|
|
|
|
"Insert a message about obsolete package at point."
|
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(guix-format-insert guix-package-info-obsolete-string
|
|
|
|
|
'guix-package-info-obsolete))
|
|
|
|
|
|
|
|
|
|
(defun guix-package-info-insert-non-unique-text (full-name)
|
|
|
|
|
"Insert a message about non-unique package with FULL-NAME at point."
|
|
|
|
|
(insert "\n")
|
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(insert "Installed outputs are displayed for a non-unique ")
|
emacs: Support font-locking.
Avoid breaking highlighting after adding new font-lock keywords.
* emacs/guix-base.el (guix-insert-package-strings): Use 'propertize' instead
of 'guix-get-string'.
* emacs/guix-info.el (guix, guix-action, guix-file, guix-url,
guix-package-location, guix-package-name): New button types.
(guix-info-insert-action-button, guix-info-insert-file-path,
guix-info-insert-url, guix-package-info-insert-location,
guix-package-info-insert-full-names,
guix-package-info-insert-non-unique-text): Adjust for 'guix-insert-button'
and button types.
(guix-package-info-name-button): New face.
(guix-package-info-define-insert-inputs): Use it. Add new button types.
(guix-package-info-insert-full-name): Remove.
* emacs/guix-utils.el (guix-get-string): Replace 'face' with 'font-lock-face'.
(guix-insert-button): Adjust for using button types.
2014-09-27 22:59:08 +02:00
|
|
|
|
(guix-insert-button full-name 'guix-package-name)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(insert " package."))
|
|
|
|
|
|
|
|
|
|
(defun guix-package-info-insert-output (output entry)
|
|
|
|
|
"Insert OUTPUT at point.
|
|
|
|
|
Make some fancy text with buttons and additional stuff if the
|
|
|
|
|
current OUTPUT is installed (if there is such output in
|
|
|
|
|
`installed' parameter of a package ENTRY)."
|
2015-10-22 09:08:42 +02:00
|
|
|
|
(let* ((installed (guix-entry-value entry 'installed))
|
|
|
|
|
(obsolete (guix-entry-value entry 'obsolete))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(installed-entry (cl-find-if
|
|
|
|
|
(lambda (entry)
|
2015-10-22 09:08:42 +02:00
|
|
|
|
(string= (guix-entry-value entry 'output)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
output))
|
|
|
|
|
installed))
|
|
|
|
|
(action-type (if installed-entry 'delete 'install)))
|
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(guix-format-insert output
|
|
|
|
|
(if installed-entry
|
|
|
|
|
'guix-package-info-installed-outputs
|
|
|
|
|
'guix-package-info-uninstalled-outputs)
|
|
|
|
|
guix-package-info-output-format)
|
|
|
|
|
(guix-package-info-insert-action-button action-type entry output)
|
|
|
|
|
(when obsolete
|
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(guix-package-info-insert-action-button 'upgrade entry output))
|
|
|
|
|
(insert "\n")
|
|
|
|
|
(when installed-entry
|
2015-11-20 19:25:10 +01:00
|
|
|
|
(guix-info-insert-entry installed-entry 'installed-output 2))))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defun guix-package-info-insert-action-button (type entry output)
|
|
|
|
|
"Insert button to process an action on a package OUTPUT at point.
|
|
|
|
|
TYPE is one of the following symbols: `install', `delete', `upgrade'.
|
|
|
|
|
ENTRY is an alist with package info."
|
|
|
|
|
(let ((type-str (capitalize (symbol-name type)))
|
2015-11-18 09:36:27 +01:00
|
|
|
|
(full-name (guix-package-entry->name-specification entry output)))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(guix-info-insert-action-button
|
|
|
|
|
type-str
|
|
|
|
|
(lambda (btn)
|
|
|
|
|
(guix-process-package-actions
|
emacs: Improve interface for working with multiple profiles.
Suggested by David Thompson, Ludovic Courtès and Mathieu Lirzin.
* emacs/guix-base.el (guix-profile-prompt): New procedure.
(guix-set-current-profile): Use it.
(guix-buffer-name-simple, guix-buffer-name-default, guix-buffer-name): New
procedures.
(guix-buffer-name-function, guix-profile): New variables.
(guix-set-vars, guix-get-entries, guix-get-show-entries, guix-set-buffer,
guix-history-call, guix-process-package-actions,
guix-continue-package-operation-p, guix-delete-generations,
guix-switch-to-generation): Add 'profile' argument.
* emacs/guix.el (guix-get-show-packages, guix-get-show-generations,
guix-search-by-name, guix-search-by-regexp, guix-installed-packages,
guix-obsolete-packages, guix-all-available-packages,
guix-newest-available-packages, guix-generations, guix-generations-by-time):
Likewise.
(guix-last-generations): New command.
* emacs/guix-info.el: Adjust for using 'profile' argument where needed.
* emacs/guix-list.el: Likewise.
* doc/emacs.texi (Emacs Commands): Document 'guix-last-generations' and using
"C-u" for commands.
(Emacs Buffer Names): Document 'guix-buffer-name-function'.
2014-10-17 20:21:32 +02:00
|
|
|
|
guix-profile
|
2014-10-14 18:43:10 +02:00
|
|
|
|
`((,(button-get btn 'action-type) (,(button-get btn 'id)
|
|
|
|
|
,(button-get btn 'output))))
|
|
|
|
|
(current-buffer)))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(concat type-str " '" full-name "'")
|
|
|
|
|
'action-type type
|
2015-10-22 09:08:42 +02:00
|
|
|
|
'id (or (guix-entry-value entry 'package-id)
|
|
|
|
|
(guix-entry-id entry))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
'output output)))
|
|
|
|
|
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
|
|
|
|
|
;;; Inserting a source
|
|
|
|
|
|
|
|
|
|
(defface guix-package-info-source
|
|
|
|
|
'((t :inherit link :underline nil))
|
|
|
|
|
"Face used for a source URL of a package."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-package-info-faces)
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
|
|
|
|
|
(defcustom guix-package-info-auto-find-source nil
|
|
|
|
|
"If non-nil, find a source file after pressing a \"Show\" button.
|
|
|
|
|
If nil, just display the source file path without finding."
|
|
|
|
|
:type 'boolean
|
|
|
|
|
:group 'guix-package-info)
|
|
|
|
|
|
|
|
|
|
(defcustom guix-package-info-auto-download-source t
|
|
|
|
|
"If nil, do not automatically download a source file if it doesn't exist.
|
|
|
|
|
After pressing a \"Show\" button, a derivation of the package
|
|
|
|
|
source is calculated and a store file path is displayed. If this
|
|
|
|
|
variable is non-nil and the source file does not exist in the
|
|
|
|
|
store, it will be automatically downloaded (with a possible
|
|
|
|
|
prompt depending on `guix-operation-confirm' variable)."
|
|
|
|
|
:type 'boolean
|
|
|
|
|
:group 'guix-package-info)
|
|
|
|
|
|
|
|
|
|
(defvar guix-package-info-download-buffer nil
|
|
|
|
|
"Buffer from which a current download operation was performed.")
|
|
|
|
|
|
|
|
|
|
(define-button-type 'guix-package-source
|
|
|
|
|
:supertype 'guix
|
|
|
|
|
'face 'guix-package-info-source
|
|
|
|
|
'help-echo ""
|
|
|
|
|
'action (lambda (_)
|
|
|
|
|
;; As a source may not be a real URL (e.g., "mirror://..."),
|
|
|
|
|
;; no action is bound to a source button.
|
|
|
|
|
(message "Yes, this is the source URL. What did you expect?")))
|
|
|
|
|
|
|
|
|
|
(defun guix-package-info-show-source (entry-id package-id)
|
|
|
|
|
"Show file name of a package source in the current info buffer.
|
|
|
|
|
Find the file if needed (see `guix-package-info-auto-find-source').
|
|
|
|
|
ENTRY-ID is an ID of the current entry (package or output).
|
|
|
|
|
PACKAGE-ID is an ID of the package which source to show."
|
2015-11-22 11:21:18 +01:00
|
|
|
|
(let* ((entries guix-entries)
|
|
|
|
|
(entry (guix-entry-by-id entry-id guix-entries))
|
|
|
|
|
(file (guix-package-source-path package-id)))
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
(or file
|
2015-11-22 11:21:18 +01:00
|
|
|
|
(error "Couldn't define file name of the package source"))
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
(let* ((new-entry (cons (cons 'source-file file)
|
|
|
|
|
entry))
|
2015-11-22 11:21:18 +01:00
|
|
|
|
(new-entries (guix-replace-entry entry-id new-entry entries)))
|
|
|
|
|
(setq guix-entries new-entries)
|
|
|
|
|
(guix-buffer-redisplay-goto-button)
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
(if (file-exists-p file)
|
|
|
|
|
(if guix-package-info-auto-find-source
|
|
|
|
|
(guix-find-file file)
|
|
|
|
|
(message "The source store path is displayed."))
|
|
|
|
|
(if guix-package-info-auto-download-source
|
|
|
|
|
(guix-package-info-download-source package-id)
|
|
|
|
|
(message "The source does not exist in the store."))))))
|
|
|
|
|
|
|
|
|
|
(defun guix-package-info-download-source (package-id)
|
|
|
|
|
"Download a source of the package PACKAGE-ID."
|
|
|
|
|
(setq guix-package-info-download-buffer (current-buffer))
|
|
|
|
|
(guix-package-source-build-derivation
|
|
|
|
|
package-id
|
|
|
|
|
"The source does not exist in the store. Download it?"))
|
|
|
|
|
|
|
|
|
|
(defun guix-package-info-insert-source (source entry)
|
|
|
|
|
"Insert SOURCE from package ENTRY at point.
|
|
|
|
|
SOURCE is a list of URLs."
|
|
|
|
|
(if (null source)
|
|
|
|
|
(guix-format-insert nil)
|
2015-10-22 09:08:42 +02:00
|
|
|
|
(let* ((source-file (guix-entry-value entry 'source-file))
|
|
|
|
|
(entry-id (guix-entry-id entry))
|
|
|
|
|
(package-id (or (guix-entry-value entry 'package-id)
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
entry-id)))
|
|
|
|
|
(if (null source-file)
|
|
|
|
|
(guix-info-insert-action-button
|
|
|
|
|
"Show"
|
|
|
|
|
(lambda (btn)
|
|
|
|
|
(guix-package-info-show-source (button-get btn 'entry-id)
|
|
|
|
|
(button-get btn 'package-id)))
|
2015-11-19 22:13:19 +01:00
|
|
|
|
"Show the source store directory of the current package"
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
'entry-id entry-id
|
|
|
|
|
'package-id package-id)
|
|
|
|
|
(unless (file-exists-p source-file)
|
|
|
|
|
(guix-info-insert-action-button
|
|
|
|
|
"Download"
|
|
|
|
|
(lambda (btn)
|
|
|
|
|
(guix-package-info-download-source
|
|
|
|
|
(button-get btn 'package-id)))
|
|
|
|
|
"Download the source into the store"
|
|
|
|
|
'package-id package-id))
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(guix-info-insert-value-indent source-file 'guix-file))
|
|
|
|
|
(guix-info-insert-value-indent source 'guix-package-source))))
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
|
|
|
|
|
(defun guix-package-info-redisplay-after-download ()
|
|
|
|
|
"Redisplay an 'info' buffer after downloading the package source.
|
|
|
|
|
This function is used to hide a \"Download\" button if needed."
|
|
|
|
|
(when (buffer-live-p guix-package-info-download-buffer)
|
2015-11-22 11:21:18 +01:00
|
|
|
|
(with-current-buffer guix-package-info-download-buffer
|
|
|
|
|
(guix-buffer-redisplay-goto-button))
|
emacs: Add "Source" field to 'guix-info' buffers.
Suggested by Ludovic Courtès.
* emacs/guix-info.el (guix-info-insert-methods, guix-info-displayed-params):
Add 'source' parameter.
(guix-package-info-source): New face.
(guix-package-source): New button type.
(guix-package-info-auto-find-source, guix-package-info-auto-download-source,
guix-package-info-download-buffer): New variables.
(guix-package-info-show-source, guix-package-info-insert-source-url,
guix-package-info-insert-source, guix-package-info-download-source,
guix-package-info-redisplay-after-download): New procedures.
* emacs/guix-base.el (guix-param-titles): Add 'source' parameter.
(guix-operation-prompt): Add 'prompt' argument.
(guix-after-source-download-hook): New variable.
(guix-package-source-path, guix-package-source-build-derivation): New
procedures.
* emacs/guix-main.scm (%package-param-alist): Add 'source' parameter.
(package-source-names, package-source-derivation->store-path,
package-source-path, package-source-build-derivation): New procedures.
2014-11-09 09:03:39 +01:00
|
|
|
|
(setq guix-package-info-download-buffer nil)))
|
|
|
|
|
|
|
|
|
|
(add-hook 'guix-after-source-download-hook
|
|
|
|
|
'guix-package-info-redisplay-after-download)
|
|
|
|
|
|
2014-09-19 07:57:36 +02:00
|
|
|
|
|
|
|
|
|
;;; Displaying outputs
|
|
|
|
|
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(guix-ui-info-define-interface output
|
2014-09-19 07:57:36 +02:00
|
|
|
|
:buffer-name "*Guix Package Info*"
|
2015-11-20 19:25:10 +01:00
|
|
|
|
:format '((name format (format guix-package-info-name))
|
|
|
|
|
(version format guix-output-info-insert-version)
|
|
|
|
|
(output format guix-output-info-insert-output)
|
|
|
|
|
(synopsis simple (indent guix-package-info-synopsis))
|
|
|
|
|
(source simple guix-package-info-insert-source)
|
|
|
|
|
(path simple (indent guix-file))
|
|
|
|
|
(dependencies simple (indent guix-file))
|
|
|
|
|
(location format (format guix-package-location))
|
|
|
|
|
(home-url format (format guix-url))
|
|
|
|
|
(license format (format guix-package-info-license))
|
|
|
|
|
(inputs format (format guix-package-input))
|
|
|
|
|
(native-inputs format (format guix-package-native-input))
|
|
|
|
|
(propagated-inputs format
|
|
|
|
|
(format guix-package-propagated-input))
|
|
|
|
|
(description simple (indent guix-package-info-description)))
|
2015-11-21 09:35:43 +01:00
|
|
|
|
:titles guix-package-info-titles
|
2015-11-20 10:38:31 +01:00
|
|
|
|
:required '(id package-id installed non-unique))
|
2014-09-19 07:57:36 +02:00
|
|
|
|
|
|
|
|
|
(defun guix-output-info-insert-version (version entry)
|
|
|
|
|
"Insert output VERSION and obsolete text if needed at point."
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(guix-info-insert-value-format version
|
|
|
|
|
'guix-package-info-version)
|
2015-10-22 09:08:42 +02:00
|
|
|
|
(and (guix-entry-value entry 'obsolete)
|
2014-09-19 07:57:36 +02:00
|
|
|
|
(guix-package-info-insert-obsolete-text)))
|
|
|
|
|
|
|
|
|
|
(defun guix-output-info-insert-output (output entry)
|
|
|
|
|
"Insert OUTPUT and action buttons at point."
|
2015-10-22 09:08:42 +02:00
|
|
|
|
(let* ((installed (guix-entry-value entry 'installed))
|
|
|
|
|
(obsolete (guix-entry-value entry 'obsolete))
|
2014-09-19 07:57:36 +02:00
|
|
|
|
(action-type (if installed 'delete 'install)))
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(guix-info-insert-value-format
|
2014-09-19 07:57:36 +02:00
|
|
|
|
output
|
|
|
|
|
(if installed
|
|
|
|
|
'guix-package-info-installed-outputs
|
|
|
|
|
'guix-package-info-uninstalled-outputs))
|
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(guix-package-info-insert-action-button action-type entry output)
|
|
|
|
|
(when obsolete
|
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(guix-package-info-insert-action-button 'upgrade entry output))))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;;; Displaying generations
|
|
|
|
|
|
2015-11-20 19:25:10 +01:00
|
|
|
|
(guix-ui-info-define-interface generation
|
emacs: Generalize buffer naming.
* emacs/guix-base.el (guix-buffer-name): New procedure.
(guix-buffer-define-interface): Make ':buffer-name' a required keyword.
(guix-update-after-operation, guix-buffer-name-function)
(guix-buffer-name-simple, guix-buffer-name-default, guix-buffer-name)
(guix-buffer-p, guix-buffers, guix-update-buffer)
(guix-update-buffers-maybe-after-operation): Adjust, move and rename to...
* emacs/guix-ui.el (guix-ui-update-after-operation)
(guix-ui-buffer-name-function, guix-ui-buffer-name-simple)
(guix-ui-buffer-name-default, guix-ui-buffer-name)
(guix-ui-buffer?, guix-ui-buffers, guix-ui-update-buffer)
(guix-ui-update-buffers-after-operation): ... this.
(guix-ui-define-interface): Generate
'guix-ENTRY-TYPE-BUFFER-TYPE-buffer-name' procedure and pass it as
':buffer-name' argument.
(guix-ui): New custom group.
* emacs/guix-info.el: Specify ':buffer-name' for the defined interfaces.
* emacs/guix-list.el: Likewise.
* doc/emacs.texi (Emacs Appearance): Adjust accordingly.
2015-11-23 14:41:58 +01:00
|
|
|
|
:buffer-name "*Guix Generation Info*"
|
2015-11-20 19:25:10 +01:00
|
|
|
|
:format '((number format guix-generation-info-insert-number)
|
|
|
|
|
(prev-number format (format))
|
|
|
|
|
(current format guix-generation-info-insert-current)
|
|
|
|
|
(path simple (indent guix-file))
|
2015-11-21 09:35:43 +01:00
|
|
|
|
(time format (time)))
|
|
|
|
|
:titles '((path . "File name")
|
|
|
|
|
(prev-number . "Previous number")))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-generation-info-number
|
|
|
|
|
'((t :inherit font-lock-keyword-face))
|
|
|
|
|
"Face used for a number of a generation."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-generation-info-faces)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2014-10-10 21:50:15 +02:00
|
|
|
|
(defface guix-generation-info-current
|
|
|
|
|
'((t :inherit guix-package-info-installed-outputs))
|
|
|
|
|
"Face used if a generation is the current one."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-generation-info-faces)
|
2014-10-10 21:50:15 +02:00
|
|
|
|
|
|
|
|
|
(defface guix-generation-info-not-current
|
|
|
|
|
'((t nil))
|
|
|
|
|
"Face used if a generation is not the current one."
|
2015-09-14 22:32:53 +02:00
|
|
|
|
:group 'guix-generation-info-faces)
|
2014-10-10 21:50:15 +02:00
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(defun guix-generation-info-insert-number (number &optional _)
|
|
|
|
|
"Insert generation NUMBER and action buttons."
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(guix-info-insert-value-format number 'guix-generation-info-number)
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(guix-info-insert-action-button
|
|
|
|
|
"Packages"
|
|
|
|
|
(lambda (btn)
|
emacs: Improve interface for working with multiple profiles.
Suggested by David Thompson, Ludovic Courtès and Mathieu Lirzin.
* emacs/guix-base.el (guix-profile-prompt): New procedure.
(guix-set-current-profile): Use it.
(guix-buffer-name-simple, guix-buffer-name-default, guix-buffer-name): New
procedures.
(guix-buffer-name-function, guix-profile): New variables.
(guix-set-vars, guix-get-entries, guix-get-show-entries, guix-set-buffer,
guix-history-call, guix-process-package-actions,
guix-continue-package-operation-p, guix-delete-generations,
guix-switch-to-generation): Add 'profile' argument.
* emacs/guix.el (guix-get-show-packages, guix-get-show-generations,
guix-search-by-name, guix-search-by-regexp, guix-installed-packages,
guix-obsolete-packages, guix-all-available-packages,
guix-newest-available-packages, guix-generations, guix-generations-by-time):
Likewise.
(guix-last-generations): New command.
* emacs/guix-info.el: Adjust for using 'profile' argument where needed.
* emacs/guix-list.el: Likewise.
* doc/emacs.texi (Emacs Commands): Document 'guix-last-generations' and using
"C-u" for commands.
(Emacs Buffer Names): Document 'guix-buffer-name-function'.
2014-10-17 20:21:32 +02:00
|
|
|
|
(guix-get-show-entries guix-profile 'list guix-package-list-type
|
|
|
|
|
'generation (button-get btn 'number)))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
"Show installed packages for this generation"
|
|
|
|
|
'number number)
|
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(guix-info-insert-action-button
|
|
|
|
|
"Delete"
|
2014-10-05 10:31:23 +02:00
|
|
|
|
(lambda (btn)
|
emacs: Improve interface for working with multiple profiles.
Suggested by David Thompson, Ludovic Courtès and Mathieu Lirzin.
* emacs/guix-base.el (guix-profile-prompt): New procedure.
(guix-set-current-profile): Use it.
(guix-buffer-name-simple, guix-buffer-name-default, guix-buffer-name): New
procedures.
(guix-buffer-name-function, guix-profile): New variables.
(guix-set-vars, guix-get-entries, guix-get-show-entries, guix-set-buffer,
guix-history-call, guix-process-package-actions,
guix-continue-package-operation-p, guix-delete-generations,
guix-switch-to-generation): Add 'profile' argument.
* emacs/guix.el (guix-get-show-packages, guix-get-show-generations,
guix-search-by-name, guix-search-by-regexp, guix-installed-packages,
guix-obsolete-packages, guix-all-available-packages,
guix-newest-available-packages, guix-generations, guix-generations-by-time):
Likewise.
(guix-last-generations): New command.
* emacs/guix-info.el: Adjust for using 'profile' argument where needed.
* emacs/guix-list.el: Likewise.
* doc/emacs.texi (Emacs Commands): Document 'guix-last-generations' and using
"C-u" for commands.
(Emacs Buffer Names): Document 'guix-buffer-name-function'.
2014-10-17 20:21:32 +02:00
|
|
|
|
(guix-delete-generations guix-profile (list (button-get btn 'number))
|
2014-10-14 18:43:10 +02:00
|
|
|
|
(current-buffer)))
|
2014-10-05 10:31:23 +02:00
|
|
|
|
"Delete this generation"
|
|
|
|
|
'number number))
|
2014-08-27 14:44:17 +02:00
|
|
|
|
|
2014-10-10 21:50:15 +02:00
|
|
|
|
(defun guix-generation-info-insert-current (val entry)
|
|
|
|
|
"Insert boolean value VAL showing whether this generation is current."
|
|
|
|
|
(if val
|
2015-11-19 22:13:19 +01:00
|
|
|
|
(guix-info-insert-value-format "Yes" 'guix-generation-info-current)
|
|
|
|
|
(guix-info-insert-value-format "No" 'guix-generation-info-not-current)
|
2014-10-10 21:58:30 +02:00
|
|
|
|
(guix-info-insert-indent)
|
|
|
|
|
(guix-info-insert-action-button
|
|
|
|
|
"Switch"
|
|
|
|
|
(lambda (btn)
|
emacs: Improve interface for working with multiple profiles.
Suggested by David Thompson, Ludovic Courtès and Mathieu Lirzin.
* emacs/guix-base.el (guix-profile-prompt): New procedure.
(guix-set-current-profile): Use it.
(guix-buffer-name-simple, guix-buffer-name-default, guix-buffer-name): New
procedures.
(guix-buffer-name-function, guix-profile): New variables.
(guix-set-vars, guix-get-entries, guix-get-show-entries, guix-set-buffer,
guix-history-call, guix-process-package-actions,
guix-continue-package-operation-p, guix-delete-generations,
guix-switch-to-generation): Add 'profile' argument.
* emacs/guix.el (guix-get-show-packages, guix-get-show-generations,
guix-search-by-name, guix-search-by-regexp, guix-installed-packages,
guix-obsolete-packages, guix-all-available-packages,
guix-newest-available-packages, guix-generations, guix-generations-by-time):
Likewise.
(guix-last-generations): New command.
* emacs/guix-info.el: Adjust for using 'profile' argument where needed.
* emacs/guix-list.el: Likewise.
* doc/emacs.texi (Emacs Commands): Document 'guix-last-generations' and using
"C-u" for commands.
(Emacs Buffer Names): Document 'guix-buffer-name-function'.
2014-10-17 20:21:32 +02:00
|
|
|
|
(guix-switch-to-generation guix-profile (button-get btn 'number)
|
2014-10-14 18:43:10 +02:00
|
|
|
|
(current-buffer)))
|
2014-10-10 21:58:30 +02:00
|
|
|
|
"Switch to this generation (make it the current one)"
|
2015-10-22 09:08:42 +02:00
|
|
|
|
'number (guix-entry-value entry 'number))))
|
2014-10-10 21:50:15 +02:00
|
|
|
|
|
2015-11-20 10:38:31 +01:00
|
|
|
|
|
|
|
|
|
(defvar guix-info-font-lock-keywords
|
|
|
|
|
(eval-when-compile
|
|
|
|
|
`((,(rx "(" (group "guix-info-define-interface")
|
|
|
|
|
symbol-end)
|
|
|
|
|
. 1))))
|
|
|
|
|
|
|
|
|
|
(font-lock-add-keywords 'emacs-lisp-mode guix-info-font-lock-keywords)
|
|
|
|
|
|
2014-08-27 14:44:17 +02:00
|
|
|
|
(provide 'guix-info)
|
|
|
|
|
|
|
|
|
|
;;; guix-info.el ends here
|