From c9aef52121b458297e70bb50f49f7276b4a8d759 Mon Sep 17 00:00:00 2001 From: Alex Kost Date: Tue, 8 Jun 2021 19:53:06 +0300 Subject: [PATCH] elisp/ui-package: Add 'guix-package-use-name-at-point' variable * elisp/guix-ui-package.el (guix-package-use-name-at-point): New variable. (guix-packages-by-name): Use it. --- elisp/guix-ui-package.el | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/elisp/guix-ui-package.el b/elisp/guix-ui-package.el index 9ac587f..8dad304 100644 --- a/elisp/guix-ui-package.el +++ b/elisp/guix-ui-package.el @@ -52,6 +52,13 @@ a separate line)." (const :tag "List of outputs" output)) :group 'guix-package) +(defcustom guix-package-use-name-at-point t + "If non-nil, \\[guix-packages-by-name] uses symbol at point as default +if it is a package name. +If nil, then no default name is used." + :type 'boolean + :group 'guix-package) + (defun guix-package-list-type () "Return BUI list entry-type by `guix-package-list-type' variable." (guix-make-symbol guix-package-list-type)) @@ -1512,12 +1519,13 @@ a version number. Examples: \"guile\", \"guile@2.0.11\". If PROFILE is nil, use `guix-current-profile'. Interactively with prefix, prompt for PROFILE." (interactive - (let ((at-point (thing-at-point 'symbol t)) - default-pkg) - (when (stringp at-point) - (let ((at-point (car (split-string at-point "@")))) - (setq default-pkg (and (member at-point (guix-package-names)) - at-point)))) + (let (default-pkg) + (when guix-package-use-name-at-point + (let ((at-point (thing-at-point 'symbol t))) + (when (stringp at-point) + (let ((at-point (car (split-string at-point "@")))) + (setq default-pkg (and (member at-point (guix-package-names)) + at-point)))))) (list (guix-read-package-name "Package: " default-pkg) (guix-ui-read-package-profile)))) (guix-package-get-display profile 'name name))