;;; doom-modeline.el --- A minimal and modern mode-line -*- lexical-binding: t; -*- ;; Copyright (C) 2018-2020 Vincent Zhang ;; Author: Vincent Zhang ;; Homepage: https://github.com/seagle0128/doom-modeline ;; Version: 3.3.3 ;; Package-Requires: ((emacs "25.1") (compat "28.1.1.1") (shrink-path "0.2.0")) ;; Keywords: faces mode-line ;; This file is not part of GNU Emacs. ;; ;; 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 ;; 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 . ;; ;;; Commentary: ;; ;; This package offers a fancy and fast mode-line inspired by minimalism design. ;; ;; It's integrated into Doom Emacs (https://github.com/hlissner/doom-emacs) and ;; Centaur Emacs (https://github.com/seagle0128/.emacs.d). ;; ;; The doom-modeline offers: ;; - A match count panel (for anzu, iedit, multiple-cursors, symbol-overlay, ;; evil-search and evil-substitute) ;; - An indicator for recording a macro ;; - Current environment version (e.g. python, ruby, go, etc.) in the major-mode ;; - A customizable mode-line height (see doom-modeline-height) ;; - A minor modes segment which is compatible with minions ;; - An error/warning count segment for flymake/flycheck ;; - A workspace number segment for eyebrowse ;; - A perspective name segment for persp-mode ;; - A window number segment for winum and window-numbering ;; - An indicator for modal editing state, including evil, overwrite, god, ryo ;; and xah-fly-keys, etc. ;; - An indicator for battery status ;; - An indicator for current input method ;; - An indicator for debug state ;; - An indicator for remote host ;; - An indicator for LSP state with lsp-mode or eglot ;; - An indicator for github notifications ;; - An indicator for unread emails with mu4e-alert ;; - An indicator for unread emails with gnus (basically builtin) ;; - An indicator for irc notifications with circe, rcirc or erc. ;; - An indicator for buffer position which is compatible with nyan-mode or poke-line ;; - An indicator for party parrot ;; - An indicator for PDF page number with pdf-tools ;; - An indicator for markdown/org previews with grip ;; - Truncated file name, file icon, buffer state and project name in buffer ;; information segment, which is compatible with project, find-file-in-project ;; and projectile ;; - New mode-line for Info-mode buffers ;; - New package mode-line for paradox ;; - New mode-line for helm buffers ;; - New mode-line for git-timemachine buffers ;; ;; Installation: ;; From melpa, `M-x package-install RET doom-modeline RET`. ;; In `init.el`, ;; (require 'doom-modeline) ;; (doom-modeline-mode 1) ;; or ;; (use-package doom-modeline ;; :ensure t ;; :hook (after-init . doom-modeline-mode)) ;; ;;; Code: (require 'doom-modeline-core) (require 'doom-modeline-segments) ;; ;; Mode lines ;; (doom-modeline-def-modeline 'main '(bar workspace-name window-number modals matches follow buffer-info remote-host buffer-position word-count parrot selection-info) '(compilation objed-state misc-info persp-name battery grip irc mu4e gnus github debug repl lsp minor-modes input-method indent-info buffer-encoding major-mode process vcs checker time)) (doom-modeline-def-modeline 'minimal '(bar matches buffer-info-simple) '(media-info major-mode time)) (doom-modeline-def-modeline 'special '(bar window-number modals matches buffer-info remote-host buffer-position word-count parrot selection-info) '(compilation objed-state misc-info battery irc-buffers debug minor-modes input-method indent-info buffer-encoding major-mode process time)) (doom-modeline-def-modeline 'project '(bar window-number modals buffer-default-directory remote-host buffer-position) '(compilation misc-info battery irc mu4e gnus github debug minor-modes input-method major-mode process time)) (doom-modeline-def-modeline 'dashboard '(bar window-number buffer-default-directory-simple remote-host) '(compilation misc-info battery irc mu4e gnus github debug minor-modes input-method major-mode process time)) (doom-modeline-def-modeline 'vcs '(bar window-number modals matches buffer-info remote-host buffer-position parrot selection-info) '(compilation misc-info battery irc mu4e gnus github debug minor-modes buffer-encoding major-mode process time)) (doom-modeline-def-modeline 'package '(bar window-number package) '(compilation misc-info major-mode process time)) (doom-modeline-def-modeline 'info '(bar window-number buffer-info info-nodes buffer-position parrot selection-info) '(compilation misc-info buffer-encoding major-mode time)) (doom-modeline-def-modeline 'media '(bar window-number buffer-size buffer-info) '(compilation misc-info media-info major-mode process vcs time)) (doom-modeline-def-modeline 'message '(bar window-number modals matches buffer-info-simple buffer-position word-count parrot selection-info) '(compilation objed-state misc-info battery debug minor-modes input-method indent-info buffer-encoding major-mode time)) (doom-modeline-def-modeline 'pdf '(bar window-number matches buffer-info pdf-pages) '(compilation misc-info major-mode process vcs time)) (doom-modeline-def-modeline 'org-src '(bar window-number modals matches buffer-info buffer-position word-count parrot selection-info) '(compilation objed-state misc-info debug lsp minor-modes input-method indent-info buffer-encoding major-mode process checker time)) (doom-modeline-def-modeline 'helm '(bar helm-buffer-id helm-number helm-follow helm-prefix-argument) '(helm-help time)) (doom-modeline-def-modeline 'timemachine '(bar window-number modals matches git-timemachine buffer-position word-count parrot selection-info) '(misc-info minor-modes indent-info buffer-encoding major-mode time)) (doom-modeline-def-modeline 'calculator '(window-number modals matches calc buffer-position) '(misc-info minor-modes major-mode process)) ;; ;; Interfaces ;; ;;;###autoload (defun doom-modeline-set-main-modeline (&optional default) "Set main mode-line. If DEFAULT is non-nil, set the default mode-line for all buffers." (doom-modeline-set-modeline 'main default)) ;; ;; Minor mode ;; ;; Suppress warnings (defvar 2C-mode-line-format) (defvar helm-ag-show-status-function) (declare-function helm-display-mode-line "ext:helm-core") (defvar doom-modeline-mode-map (make-sparse-keymap)) (defvar doom-modeline-mode-alist '((message-mode . message) (git-commit-mode . message) (magit-mode . vcs) (dashboard-mode . dashboard) (Info-mode . info) (image-mode . media) (pdf-view-mode . pdf) (org-src-mode . org-src) (paradox-menu-mode . package) (xwidget-webkit-mode . minimal) (git-timemachine-mode . timemachine) (calc-mode . calculator) (calc-trail-mode . calculator) (circe-mode . special) (erc-mode . special) (rcirc-mode . special)) "Alist of major modes and mode-lines.") (defun doom-modeline-auto-set-modeline () "Set mode-line base on major-mode." (catch 'found (dolist (x doom-modeline-mode-alist) (when (derived-mode-p (car x)) (doom-modeline-set-modeline (cdr x)) (throw 'found x))))) (defun doom-modeline-set-helm-modeline (&rest _) ; To advice helm "Set helm mode-line." (doom-modeline-set-modeline 'helm)) ;;;###autoload (define-minor-mode doom-modeline-mode "Toggle `doom-modeline' on or off." :group 'doom-modeline :global t :lighter nil :keymap doom-modeline-mode-map (if doom-modeline-mode (progn (doom-modeline-refresh-bars) ; Create bars (doom-modeline-set-main-modeline t) ; Set default mode-line ;; Apply to all existing buffers. (dolist (buf (buffer-list)) (with-current-buffer buf (unless (doom-modeline-auto-set-modeline) (doom-modeline-set-main-modeline)))) ;; For two-column editing (setq 2C-mode-line-format (doom-modeline 'special)) ;; Automatically set mode-lines (add-hook 'after-change-major-mode-hook #'doom-modeline-auto-set-modeline) ;; Special handles (advice-add #'helm-display-mode-line :after #'doom-modeline-set-helm-modeline) (setq helm-ag-show-status-function #'doom-modeline-set-helm-modeline)) (progn ;; Restore mode-line (let ((original-format (doom-modeline--original-value 'mode-line-format))) (setq-default mode-line-format original-format) (dolist (buf (buffer-list)) (with-current-buffer buf (setq mode-line-format original-format)))) ;; For two-column editing (setq 2C-mode-line-format (doom-modeline--original-value '2C-mode-line-format)) ;; Cleanup (remove-hook 'after-change-major-mode-hook #'doom-modeline-auto-set-modeline) (advice-remove #'helm-display-mode-line #'doom-modeline-set-helm-modeline) (setq helm-ag-show-status-function (default-value 'helm-ag-show-status-function))))) (provide 'doom-modeline) ;;; doom-modeline.el ends here