From e99183427515af67ac97c64e22f286693ecbe060 Mon Sep 17 00:00:00 2001 From: Vincent Ambo Date: Mon, 16 Dec 2019 03:49:07 +0000 Subject: feat(emacs.d): Install and configure emacs-libvterm This incredible package provides a fully functional, libvterm based terminal emulator inside of Emacs. Killer feature: It's possible to switch the buffer into a full Emacs text mode (read-only) for selections and such. --- tools/emacs/config/init.el | 13 +++++++++++++ tools/emacs/default.nix | 1 + 2 files changed, 14 insertions(+) diff --git a/tools/emacs/config/init.el b/tools/emacs/config/init.el index 7d40813d83..06fe707921 100644 --- a/tools/emacs/config/init.el +++ b/tools/emacs/config/init.el @@ -73,6 +73,19 @@ (use-package pg) (use-package restclient) +(use-package vterm + :config (progn + (setq vterm-shell "/usr/bin/fish") + (setq vterm-exit-functions + (lambda (&rest _) (kill-buffer (current-buffer)))) + (setq vterm-set-title-functions + (lambda (title) + (rename-buffer + (generate-new-buffer-name + (format "vterm<%s>" + (s-trim-left + (s-chop-prefix "fish" title))))))))) + ;; ;; Packages providing language-specific functionality ;; diff --git a/tools/emacs/default.nix b/tools/emacs/default.nix index 02ffb36605..742556dd61 100644 --- a/tools/emacs/default.nix +++ b/tools/emacs/default.nix @@ -73,6 +73,7 @@ let transient use-package uuidgen + vterm web-mode websocket which-key -- cgit 1.4.1 From d63996c3cb9640b34fa4112d460a060742ade99c Mon Sep 17 00:00:00 2001 From: Vincent Ambo Date: Mon, 16 Dec 2019 03:50:34 +0000 Subject: feat(term-switcher): Use emacs-libvterm instead of launching X-terms --- tools/emacs-pkgs/term-switcher/term-switcher.el | 61 +++++++++---------------- 1 file changed, 22 insertions(+), 39 deletions(-) diff --git a/tools/emacs-pkgs/term-switcher/term-switcher.el b/tools/emacs-pkgs/term-switcher/term-switcher.el index 66247d6824..0b99bbf816 100644 --- a/tools/emacs-pkgs/term-switcher/term-switcher.el +++ b/tools/emacs-pkgs/term-switcher/term-switcher.el @@ -1,72 +1,55 @@ -;;; term-switcher.el --- Easily switch between open X11 terminals +;;; term-switcher.el --- Easily switch between open vterms ;; ;; Copyright (C) 2019 Google Inc. ;; ;; Author: Vincent Ambo -;; Version: 1.0 +;; Version: 1.1 ;; Package-Requires: (dash ivy s) ;; ;;; Commentary: ;; ;; This package adds a function that lets users quickly switch between -;; different open X11 terminals using ivy. -;; -;; It is primarily intended to be used by EXWM users who use graphical -;; terminals inside of Emacs. -;; -;; Users MUST configure the group `term-switcher' and can then bind -;; `ts/switch-to-terminal' to an appropriate key. +;; different open vterms via ivy. (require 'dash) (require 'ivy) (require 's) (defgroup term-switcher nil - "Customization options for configuring `term-switcher' with the - user's terminal emulator of choice.") + "Customization options `term-switcher'.") -(defcustom term-switcher-program "gnome-terminal" - "X11 terminal application to use." +(defcustom term-switcher-buffer-prefix "vterm<" + "String prefix for vterm terminal buffers. For example, if you + set your titles to match `vterm<...>' a useful prefix might be + `vterm<'." :type '(string) :group 'term-switcher) -(defcustom term-switcher-buffer-prefix "Term" - "String prefix for X11 terminal buffers. For example, if your - EXWM configuration renames X11 terminal buffers to - `Term' you might want to use `Term' as the matching - prefix." - :type '(string) - :group 'term-switcher) - -(defun ts/run-terminal-program () - (message "Starting %s..." term-switcher-program) - (start-process-shell-command term-switcher-program nil term-switcher-program)) - -(defun ts/open-or-create-terminal-buffer (buffer-name) - "Switch to the buffer with BUFFER-NAME or create a new buffer - running the configured X11 terminal." +(defun ts/open-or-create-vterm (buffer-name) + "Switch to the buffer with BUFFER-NAME or create a new vterm + buffer." (let ((buffer (get-buffer buffer-name))) (if (not buffer) - (ts/run-terminal-program) + (vterm) (switch-to-buffer buffer)))) -(defun ts/is-terminal-buffer (buffer) - "Determine whether BUFFER runs an X11 terminal." - (and (equal 'exwm-mode (buffer-local-value 'major-mode buffer)) - (s-starts-with? term-switcher-buffer-prefix (buffer-name buffer)))) +(defun ts/is-vterm-buffer (buffer) + "Determine whether BUFFER runs a vterm." + (equal 'vterm-mode (buffer-local-value 'major-mode buffer))) (defun ts/switch-to-terminal () - "Switch to an X11 terminal buffer, or create a new one." + "Switch to an existing vterm buffer or create a new one." + (interactive) (let ((terms (-map #'buffer-name - (-filter #'ts/is-terminal-buffer (buffer-list))))) + (-filter #'ts/is-vterm-buffer (buffer-list))))) (if terms - (ivy-read "Switch to terminal buffer: " - (cons "New terminal" terms) + (ivy-read "Switch to vterm: " + (cons "New vterm" terms) :caller 'ts/switch-to-terminal :preselect (s-concat "^" term-switcher-buffer-prefix) :require-match t - :action #'ts/open-or-create-terminal-buffer) - (ts/run-terminal-program)))) + :action #'ts/open-or-create-vterm) + (vterm)))) (provide 'term-switcher) -- cgit 1.4.1