refactor: Reutilise multi-term commands for Alacritty buffers

In practice I never use multi-term, but it's nice to have the same
buffer selection functionality for Alacritty buffers.
This commit is contained in:
Vincent Ambo 2018-10-31 10:29:49 +01:00 committed by Vincent Ambo
parent 2c5946163c
commit 5b5f051b13
4 changed files with 35 additions and 36 deletions

13
init.el
View file

@ -78,19 +78,6 @@
:bind ("C-c g" . magit-status)
:init (setq magit-repository-directories '(("/home/vincent/projects" . 2))))
;; (use-package multi-term
;; :bind ("C-x t" . counsel-switch-to-term)
;; :init (progn
;; ;; term-mode's attempt to use isearch is not my favourite thing in the
;; ;; world.
;; (delete '("C-r" . isearch-backward) term-bind-key-alist)
;; (delete '("C-s" . isearch-forward) term-bind-key-alist)
;; (add-to-list 'term-bind-key-alist '("C-r" . term-send-reverse-search-history))
;; (add-to-list 'term-bind-key-alist '("C-c C-l" . term-line-mode))
;; (add-to-list 'term-bind-key-alist '("C-s" . swiper))
;; (add-to-list 'term-bind-key-alist '("C-c C-r" . term-rename))))
(use-package password-store)
(use-package pg)
(use-package restclient)

View file

@ -158,6 +158,16 @@ Including indent-buffer, which should not be called automatically on save."
append lsdir into completions
finally return (sort completions 'string-lessp)))
(defun run-external-command (cmd)
"Execute the specified command and notify the user when it
finishes."
(message "Starting %s..." cmd)
(set-process-sentinel
(start-process-shell-command cmd nil cmd)
(lambda (process event)
(when (string= event "finished\n")
(message "%s process finished." process)))))
(defun ivy-run-external-command ()
"Prompts the user with a list of all installed applications and
lets them select one to launch."
@ -167,13 +177,7 @@ Including indent-buffer, which should not be called automatically on save."
(ivy-read "Command:" external-commands-list
:require-match t
:history 'external-commands-history
:action (lambda (cmd)
(message "Starting %s..." cmd)
(set-process-sentinel
(start-process-shell-command cmd nil cmd)
(lambda (process event)
(when (string= event "finished\n")
(message "%s process finished." process))))))))
:action #'run-external-command)))
(defun ivy-password-store (&optional password-store-dir)
"Custom version of password-store integration with ivy that

View file

@ -63,6 +63,9 @@
(interactive)
(ivy-password-store "~/.aprila-secrets")))
;; Add Alacritty selector to a key
(exwm-input-set-key (kbd "C-x t") #'counsel-switch-to-alacritty)
;; Toggle between line-mode / char-mode
(exwm-input-set-key (kbd "C-c C-t C-t") #'exwm-input-toggle-keyboard)

View file

@ -1,32 +1,37 @@
;; Utilities for term-mode
;; Utilities for Alacritty buffers.
(defun open-or-create-term-buffer (buffer-name)
(defun open-or-create-alacritty-buffer (buffer-name)
"Switch to the buffer with BUFFER-NAME or create a
new (multi-)term-mode buffer."
new buffer running Alacritty."
(let ((buffer (get-buffer buffer-name)))
(if (not buffer)
(multi-term)
(run-external-command "alacritty")
(switch-to-buffer buffer))))
(defun counsel-switch-to-term ()
(defun is-alacritty-buffer (buffer)
"Determine whether BUFFER runs Alacritty."
(and (equal 'exwm-mode (buffer-local-value 'major-mode buffer))
(s-starts-with? "Alacritty" (buffer-name buffer))))
(defun counsel-switch-to-alacritty ()
"Switch to a (multi-)term buffer or create one."
(interactive)
(let ((terms (counsel-list-buffers-with-mode 'term-mode)))
(let ((terms (-map #'buffer-name
(-filter #'is-alacritty-buffer (buffer-list)))))
(if terms
(ivy-read "Switch to term buffer: "
(ivy-read "Switch to Alacritty buffer: "
(cons "New terminal" terms)
:caller 'counsel-switch-to-term
:caller 'counsel-switch-to-alacritty
:require-match t
:action #'open-or-create-term-buffer)
(multi-term))))
:action #'open-or-create-alacritty-buffer)
(run-external-command "alacritty"))))
(defun term-rename ()
(defun alacritty-rename ()
"Rename the current terminal buffer."
(interactive)
(let* ((buffer (get-buffer (buffer-name)))
(mode (buffer-local-value 'major-mode buffer)))
(if (equal 'term-mode mode)
(rename-buffer (format "*terminal<%s>*" (read-string "New terminal name: ")))
(error "This function is only intended to rename terminal buffers."))))
(let* ((buffer (get-buffer (buffer-name))))
(if (is-alacritty-buffer buffer)
(rename-buffer (format "Alacritty<%s>" (read-string "New terminal name: ")))
(error "This function is only intended to rename Alacritty buffers."))))
(provide 'term-setup)