Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Fetching contributors…

Cannot retrieve contributors at this time

262 lines (227 sloc) 10.1 KB
;;; helm-gentoo.el --- Helm UI for gentoo portage.
;; Copyright (C) 2012 Thierry Volpiatto <>
;; This program 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.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; 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 <>.
;;; Code:
(eval-when-compile (require 'cl))
(require 'helm)
(declare-function term-line-mode "term")
(declare-function term-char-mode "term")
(declare-function term-send-input "term")
(declare-function term-send-eof "term")
(defgroup helm-gentoo nil
"Predefined configurations for `helm.el'."
:group 'helm)
(defface helm-gentoo-match '((t (:foreground "red")))
"Face for helm-gentoo installed packages."
:group 'traverse-faces)
;;; Internals
(defvar helm-c-gentoo-use-flags nil)
(defvar helm-c-gentoo-buffer "*helm-gentoo-output*")
(defvar helm-c-cache-gentoo nil)
(defvar helm-c-cache-world nil)
(defvar helm-c-source-gentoo
'((name . "Portage sources")
(init . (lambda ()
(get-buffer-create helm-c-gentoo-buffer)
(unless helm-c-cache-gentoo
(unless helm-c-cache-world
(setq helm-c-cache-world (helm-c-gentoo-get-world)))
(match . identity)
(candidate-transformer helm-c-highlight-world)
(action . (("Show package" . (lambda (elm)
(helm-c-gentoo-eshell-action elm "eix")))
("Show history" . (lambda (elm)
(if (member elm helm-c-cache-world)
(helm-c-gentoo-eshell-action elm "genlop -qe")
(message "No infos on packages not yet installed"))))
("Copy in kill-ring" . kill-new)
("insert at point" . insert)
("Browse HomePage" . (lambda (elm)
(let ((urls (helm-c-gentoo-get-url elm)))
(browse-url (helm-comp-read "Url: " urls :must-match t)))))
("Show extra infos" . (lambda (elm)
(if (member elm helm-c-cache-world)
(helm-c-gentoo-eshell-action elm "genlop -qi")
(message "No infos on packages not yet installed"))))
("Show use flags" . (lambda (elm)
(helm-c-gentoo-default-action elm "equery" "-C" "u")
(font-lock-add-keywords nil '(("^\+.*" . font-lock-variable-name-face)))
(font-lock-mode 1)))
("Run emerge pretend" . (lambda (elm)
(helm-c-gentoo-eshell-action elm "emerge -p")))
("Emerge" . (lambda (elm)
(helm-gentoo-install elm :action 'install)))
("Unmerge" . (lambda (elm)
(helm-gentoo-install elm :action 'uninstall)))
("Show dependencies" . (lambda (elm)
(helm-c-gentoo-default-action elm "equery" "-C" "d")))
("Show related files" . (lambda (elm)
(helm-c-gentoo-default-action elm "equery" "files")))
("Refresh" . (lambda (elm)
(setq helm-c-cache-world (helm-c-gentoo-get-world))))))))
(defun* helm-gentoo-install (candidate &key action)
(setq helm-c-external-commands-list nil)
(ansi-term (getenv "SHELL") "Gentoo emerge")
(let ((command (case action
('install "sudo emerge -av ")
('uninstall "sudo emerge -avC ")
(t (error "Unknow action"))))
(elms (mapconcat 'identity (helm-marked-candidates) " "))
(beg (point)) end)
(goto-char (point-max))
(insert (concat command elms))
(setq end (point))
(term-char-mode) (term-send-input)))
(defun helm-c-gentoo-default-action (elm command &rest args)
"Gentoo default action that use `helm-c-gentoo-buffer'."
(if (member elm helm-c-cache-world)
(helm-c-switch-to-buffer helm-c-gentoo-buffer)
(let ((com-list (append args (list elm))))
(apply #'call-process command nil t nil
(message "No infos on packages not yet installed")))
(defvar helm-c-source-use-flags
'((name . "Use Flags")
(init . (lambda ()
(unless helm-c-gentoo-use-flags
(match . identity)
(candidate-transformer helm-c-highlight-local-use)
(action . (("Description"
. (lambda (elm)
(helm-c-switch-to-buffer helm-c-gentoo-buffer)
(apply #'call-process "euse" nil t nil
(font-lock-add-keywords nil `((,elm . font-lock-variable-name-face)))
(font-lock-mode 1)))
. (lambda (elm)
(helm-c-gentoo-eshell-action elm "*sudo -p Password: euse -E")))
. (lambda (elm)
(helm-c-gentoo-eshell-action elm "*sudo -p Password: euse -D")))
. (lambda (elm)
(helm-c-gentoo-eshell-action elm "*sudo -p Password: euse -P")))
("Show which dep use this flag"
. (lambda (elm)
(helm-c-switch-to-buffer helm-c-gentoo-buffer)
(apply #'call-process "equery" nil t nil
(defun helm-c-gentoo-init-list ()
"Initialize buffer with all packages in Portage."
(let* ((portage-buf (get-buffer-create "*helm-gentoo*"))
(buf (helm-candidate-buffer 'portage-buf)))
(with-current-buffer buf
(dolist (i helm-c-cache-gentoo)
(insert (concat i "\n"))))))
(defun helm-c-gentoo-setup-cache ()
"Set up `helm-c-cache-gentoo'"
(setq helm-c-cache-gentoo
(split-string (with-temp-buffer
(call-process "eix" nil t nil
(defun helm-c-gentoo-eshell-action (elm command)
(when (get-buffer "*EShell Command Output*")
(kill-buffer "*EShell Command Output*"))
(message "Wait searching...")
(let ((buf-fname (buffer-file-name helm-current-buffer)))
(if (and buf-fname (string-match tramp-file-name-regexp buf-fname))
(pop-to-buffer "*scratch*")
(eshell-command (format "%s %s" command elm)))
(pop-to-buffer "*EShell Command Output*"))
(eshell-command (format "%s %s" command elm)))))
(defun helm-c-gentoo-get-use ()
"Initialize buffer with all use flags."
(let* ((use-buf (get-buffer-create "*helm-gentoo-use*"))
(buf (helm-candidate-buffer 'use-buf)))
(with-current-buffer buf
(dolist (i helm-c-gentoo-use-flags)
(insert (concat i "\n"))))))
(defun helm-c-gentoo-setup-use-flags-cache ()
"Setup `helm-c-gentoo-use-flags'"
(setq helm-c-gentoo-use-flags
(split-string (with-temp-buffer
(call-process "eix" nil t nil
(defun helm-c-gentoo-get-url (elm)
"Return a list of urls from eix output."
(loop with url-list = (split-string
(call-process "eix" nil t nil
elm "--format" "<homepage>\n")
with all
for i in url-list
when (and (string-match "^http://.*" i)
(not (member i all)))
collect i into all
finally return all))
(defun helm-c-gentoo-get-world ()
"Return list of all installed package on your system."
(split-string (with-temp-buffer
(call-process "qlist" nil t nil
(defun helm-c-gentoo-get-local-use ()
(split-string (with-temp-buffer
(call-process "portageq" nil t nil
(defun helm-c-highlight-world (eix)
"Highlight all installed package."
(loop for i in eix
if (member i helm-c-cache-world)
collect (propertize i 'face 'helm-gentoo-match)
collect i))
(defun helm-c-highlight-local-use (use-flags)
(let ((local-uses (helm-c-gentoo-get-local-use)))
(loop for i in use-flags
if (member i local-uses)
collect (propertize i 'face 'helm-gentoo-match)
collect i)))
(defun helm-gentoo ()
"Preconfigured `helm' for gentoo linux."
(helm-other-buffer '(helm-c-source-gentoo
"*helm gentoo*"))
(provide 'helm-gentoo)
;; Local Variables:
;; byte-compile-warnings: (not cl-functions obsolete)
;; coding: utf-8
;; indent-tabs-mode: nil
;; byte-compile-dynamic: t
;; End:
;;; helm-gentoo.el ends here
Jump to Line
Something went wrong with that request. Please try again.