mirror of
https://github.com/doomemacs/doomemacs
synced 2025-08-03 12:27:26 -05:00
Remove spaceline dependency; rewrite mode-line config
This commit is contained in:
2
Cask
2
Cask
@ -37,7 +37,7 @@
|
|||||||
(depends-on "nlinum")
|
(depends-on "nlinum")
|
||||||
(depends-on "rainbow-delimiters")
|
(depends-on "rainbow-delimiters")
|
||||||
(depends-on "rainbow-mode")
|
(depends-on "rainbow-mode")
|
||||||
(depends-on "spaceline")
|
(depends-on "powerline")
|
||||||
(depends-on "visual-fill-column")
|
(depends-on "visual-fill-column")
|
||||||
|
|
||||||
;; Evil --- core/core-evil.el
|
;; Evil --- core/core-evil.el
|
||||||
|
@ -296,7 +296,8 @@ Examples:
|
|||||||
(not inhibit-doom))
|
(not inhibit-doom))
|
||||||
(doom-mode-init t))
|
(doom-mode-init t))
|
||||||
(setq default-directory dir)
|
(setq default-directory dir)
|
||||||
(setq mode-line-format '(:eval (spaceline-ml-scratch))))))
|
(setq mode-line-format (doom-mode-line 'scratch))
|
||||||
|
)))
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
|
389
core/core-ui.el
389
core/core-ui.el
@ -178,32 +178,48 @@
|
|||||||
;; Mode-line
|
;; Mode-line
|
||||||
;;
|
;;
|
||||||
|
|
||||||
(use-package spaceline
|
(defvar mode-line-height 30)
|
||||||
:init
|
|
||||||
(defvar-local doom--env-version nil)
|
(defvar-local doom--env-version nil)
|
||||||
(defvar-local doom--env-command nil)
|
(defvar-local doom--env-command nil)
|
||||||
(defvar powerline-height 30)
|
|
||||||
(defvar powerline-default-separator nil)
|
|
||||||
|
|
||||||
:config
|
(eval-when-compile (require 'powerline))
|
||||||
|
(defvar mode-line-bar (! (pl/percent-xpm mode-line-height 100 0 100 0 3 "#00B3EF" nil)))
|
||||||
|
(defvar mode-line-eldoc-bar (! (pl/percent-xpm mode-line-height 100 0 100 0 3 "#B3EF00" nil)))
|
||||||
|
(defvar mode-line-inactive-bar (! (pl/percent-xpm mode-line-height 100 0 100 0 3 nil nil)))
|
||||||
|
|
||||||
(defface mode-line-is-modified nil "Face for mode-line modified symbol")
|
(defface mode-line-is-modified nil "Face for mode-line modified symbol")
|
||||||
(defface mode-line-buffer-file nil "Face for mode-line buffer file name")
|
|
||||||
(defface mode-line-buffer-path nil "Face for mode-line buffer file path")
|
(defface mode-line-buffer-path nil "Face for mode-line buffer file path")
|
||||||
|
(defface mode-line-highlight nil "")
|
||||||
|
(defface mode-line-2 nil "")
|
||||||
|
|
||||||
;; Make certain unicode glyphs bigger for UI purposes
|
;; Make certain unicode glyphs bigger for UI purposes
|
||||||
(doom-fix-unicode '("DejaVu Sans Mono" 15) ?✱)
|
(doom-fix-unicode '("DejaVu Sans Mono" 15) ?✱)
|
||||||
(let ((font "DejaVu Sans Mono for Powerline"))
|
(let ((font "DejaVu Sans Mono for Powerline"))
|
||||||
(doom-fix-unicode (list font 10) ?)
|
(doom-fix-unicode (list font 12) ?)
|
||||||
(doom-fix-unicode (list font 16) ?∄)
|
(doom-fix-unicode (list font 16) ?∄)
|
||||||
(doom-fix-unicode (list font 15) ?))
|
(doom-fix-unicode (list font 15) ?))
|
||||||
|
|
||||||
;; Custom modeline segments
|
(defvar mode-line-selected-window nil)
|
||||||
(spaceline-define-segment *buffer-path
|
(defun doom|set-selected-window (&rest _)
|
||||||
(concat
|
(let ((window (frame-selected-window)))
|
||||||
|
(unless (minibuffer-window-active-p window)
|
||||||
|
(setq mode-line-selected-window window))))
|
||||||
|
(add-hook 'window-configuration-change-hook #'doom|set-selected-window)
|
||||||
|
(add-hook 'focus-in-hook #'doom|set-selected-window)
|
||||||
|
|
||||||
|
(advice-add 'select-window :after 'doom|set-selected-window)
|
||||||
|
(advice-add 'select-frame :after 'doom|set-selected-window)
|
||||||
|
|
||||||
|
|
||||||
|
;;
|
||||||
|
;; Mode-line segments
|
||||||
|
;;
|
||||||
|
|
||||||
|
(defun *buffer-path ()
|
||||||
(when buffer-file-name
|
(when buffer-file-name
|
||||||
(powerline-raw
|
(propertize
|
||||||
(f-dirname
|
(f-dirname
|
||||||
(let ((buffer-path (f-relative buffer-file-name (doom/project-root)))
|
(let ((buffer-path (file-relative-name buffer-file-name (doom/project-root)))
|
||||||
(max-length (truncate (/ (window-body-width) 1.75))))
|
(max-length (truncate (/ (window-body-width) 1.75))))
|
||||||
(concat (projectile-project-name) "/"
|
(concat (projectile-project-name) "/"
|
||||||
(if (> (length buffer-path) max-length)
|
(if (> (length buffer-path) max-length)
|
||||||
@ -220,128 +236,90 @@
|
|||||||
(setq output (substring output 0 -1)))
|
(setq output (substring output 0 -1)))
|
||||||
output)
|
output)
|
||||||
buffer-path))))
|
buffer-path))))
|
||||||
(if active 'mode-line-buffer-path)))
|
'face (if active 'mode-line-buffer-path))))
|
||||||
(powerline-raw "%b" (if active 'mode-line-buffer-file))
|
|
||||||
" "
|
(defun *buffer-state ()
|
||||||
(when buffer-file-name
|
(when buffer-file-name
|
||||||
(powerline-raw
|
(propertize
|
||||||
(concat
|
(concat (if (not (file-exists-p buffer-file-name))
|
||||||
(if (not (file-exists-p buffer-file-name)) "∄"
|
"∄"
|
||||||
(if (buffer-modified-p) "✱"))
|
(if (buffer-modified-p) "✱"))
|
||||||
(if buffer-read-only ""))
|
(if buffer-read-only ""))
|
||||||
'mode-line-is-modified)))
|
'face 'mode-line-is-modified)))
|
||||||
:tight-right t
|
|
||||||
:skip-alternate t)
|
|
||||||
|
|
||||||
(spaceline-define-segment *buffer-position
|
(defun *buffer-name ()
|
||||||
"A more vim-like buffer position."
|
"The buffer's name."
|
||||||
(concat "(%l,%c) "
|
(s-trim-left (format-mode-line "%b")))
|
||||||
(let ((start (window-start))
|
|
||||||
(end (window-end))
|
|
||||||
(pend (point-max)))
|
|
||||||
(if (and (= start 1)
|
|
||||||
(= end pend))
|
|
||||||
":All"
|
|
||||||
(let ((perc (/ end 0.01 pend)))
|
|
||||||
(cond ((= start 1) ":Top")
|
|
||||||
((>= perc 100) ":Bot")
|
|
||||||
(t (format ":%d%%%%" perc))))))))
|
|
||||||
|
|
||||||
(defface mode-line-vcs-info nil '((t (:inherit warning))))
|
(defun *buffer-pwd ()
|
||||||
(defface mode-line-vcs-warning nil '((t (:inherit warning))))
|
"Displays `default-directory'."
|
||||||
(spaceline-define-segment *vc
|
|
||||||
"Version control info"
|
|
||||||
(when vc-mode
|
|
||||||
(propertize
|
(propertize
|
||||||
(concat " "
|
(concat "[" (abbreviate-file-name default-directory) "]")
|
||||||
(substring vc-mode (+ 2 (length (symbol-name (vc-backend buffer-file-name))))))
|
'face 'mode-line-2))
|
||||||
'face (when active
|
|
||||||
(let ((state (vc-state buffer-file-name)))
|
|
||||||
(cond ((memq state '(edited added))
|
|
||||||
'mode-line-vcs-info)
|
|
||||||
((memq state '(removed needs-merge needs-update conflict removed unregistered))
|
|
||||||
'mode-line-vcs-warning)))))))
|
|
||||||
|
|
||||||
;; search indicators
|
(defun *major-mode ()
|
||||||
(defface mode-line-count-face nil "")
|
|
||||||
(make-variable-buffer-local 'anzu--state)
|
|
||||||
(spaceline-define-segment *anzu
|
|
||||||
"Show the current match number and the total number of matches. Requires
|
|
||||||
anzu to be enabled."
|
|
||||||
(when (and (featurep 'evil-anzu)
|
|
||||||
(evil-ex-hl-active-p 'evil-ex-search))
|
|
||||||
(powerline-raw
|
|
||||||
(let ((here anzu--current-position)
|
|
||||||
(total anzu--total-matched))
|
|
||||||
(format " %s/%d%s "
|
|
||||||
here total
|
|
||||||
(if anzu--overflow-p "+" "")))
|
|
||||||
(if active 'mode-line-count-face 'mode-line-inactive)))
|
|
||||||
:tight t)
|
|
||||||
|
|
||||||
(spaceline-define-segment *iedit
|
|
||||||
"Show the number of iedit regions matches + what match you're on."
|
|
||||||
(when (bound-and-true-p iedit-mode)
|
|
||||||
(propertize
|
|
||||||
(let ((this-oc (let (message-log-max) (iedit-find-current-occurrence-overlay)))
|
|
||||||
(length (or (ignore-errors (length iedit-occurrences-overlays)) 0)))
|
|
||||||
(format
|
|
||||||
" %s/%s "
|
|
||||||
(save-excursion
|
|
||||||
(unless this-oc
|
|
||||||
(iedit-prev-occurrence)
|
|
||||||
(setq this-oc (iedit-find-current-occurrence-overlay)))
|
|
||||||
(if this-oc
|
|
||||||
;; NOTE: Not terribly reliable
|
|
||||||
(- length (-elem-index this-oc iedit-occurrences-overlays))
|
|
||||||
"-"))
|
|
||||||
length))
|
|
||||||
'face (if active 'mode-line-count-face 'mode-line-inactive)))
|
|
||||||
:tight t)
|
|
||||||
|
|
||||||
(spaceline-define-segment *evil-substitute
|
|
||||||
"Show number of :s matches in real time."
|
|
||||||
(when (and (evil-ex-p) (evil-ex-hl-active-p 'evil-ex-substitute))
|
|
||||||
(powerline-raw
|
|
||||||
(let ((range (if evil-ex-range
|
|
||||||
(cons (car evil-ex-range) (cadr evil-ex-range))
|
|
||||||
(cons (line-beginning-position) (line-end-position))))
|
|
||||||
(pattern (car-safe (evil-delimited-arguments evil-ex-argument 2))))
|
|
||||||
(if pattern
|
|
||||||
(format " %s matches "
|
|
||||||
(count-matches pattern (car range) (cdr range))
|
|
||||||
evil-ex-argument)
|
|
||||||
" ... "))
|
|
||||||
(if active 'mode-line-count-face 'mode-line-inactive)))
|
|
||||||
:tight t)
|
|
||||||
|
|
||||||
(spaceline-define-segment *macro-recording
|
|
||||||
"Show when recording macro."
|
|
||||||
(when (and active defining-kbd-macro)
|
|
||||||
(powerline-raw
|
|
||||||
(format " %s ▶ " (char-to-string evil-this-macro))
|
|
||||||
highlight-face))
|
|
||||||
:tight t)
|
|
||||||
|
|
||||||
(spaceline-define-segment *buffer-encoding-abbrev
|
|
||||||
"The line ending convention used in the buffer."
|
|
||||||
(unless (string-match-p "\\(utf-8\\|undecided\\)"
|
|
||||||
(symbol-name buffer-file-coding-system))
|
|
||||||
(format "%s" buffer-file-coding-system)))
|
|
||||||
|
|
||||||
(spaceline-define-segment *major-mode
|
|
||||||
"The major mode, including process, environment and text-scale info."
|
"The major mode, including process, environment and text-scale info."
|
||||||
(concat (format "%s" mode-name)
|
(concat (format-mode-line mode-name)
|
||||||
(if (stringp mode-line-process) mode-line-process)
|
(if (stringp mode-line-process) mode-line-process)
|
||||||
(if doom--env-version (concat " " doom--env-version))
|
(if doom--env-version (concat " " doom--env-version))
|
||||||
(and (featurep 'face-remap)
|
(and (featurep 'face-remap)
|
||||||
(/= text-scale-mode-amount 0)
|
(/= text-scale-mode-amount 0)
|
||||||
(format " (%+d)" text-scale-mode-amount))))
|
(format " (%+d)" text-scale-mode-amount))))
|
||||||
|
|
||||||
(spaceline-define-segment *selection-info
|
(defun *buffer-encoding-abbrev ()
|
||||||
|
"The line ending convention used in the buffer."
|
||||||
|
(if (memq buffer-file-coding-system '(utf-8 utf-8-unix))
|
||||||
|
""
|
||||||
|
(symbol-name buffer-file-coding-system)))
|
||||||
|
|
||||||
|
(defface mode-line-vcs-info nil '((t (:inherit warning))))
|
||||||
|
(defface mode-line-vcs-warning nil '((t (:inherit warning))))
|
||||||
|
(defun *vc ()
|
||||||
|
"Displays the current branch, colored based on its state."
|
||||||
|
(when vc-mode
|
||||||
|
(let ((backend (concat " " (substring vc-mode (+ 2 (length (symbol-name (vc-backend buffer-file-name)))))))
|
||||||
|
(face (let ((state (vc-state buffer-file-name)))
|
||||||
|
(cond ((memq state '(edited added))
|
||||||
|
'mode-line-vcs-info)
|
||||||
|
((memq state '(removed needs-merge needs-update conflict removed unregistered))
|
||||||
|
'mode-line-vcs-warning)))))
|
||||||
|
(if active
|
||||||
|
(propertize backend 'face face)
|
||||||
|
backend))))
|
||||||
|
|
||||||
|
(defface doom-flycheck-error '((t (:inherit error)))
|
||||||
|
"Face for flycheck error feedback in the modeline.")
|
||||||
|
(defface doom-flycheck-warning '((t (:inherit warning)))
|
||||||
|
"Face for flycheck warning feedback in the modeline.")
|
||||||
|
(defvar-local doom--flycheck-err-cache nil "")
|
||||||
|
(defvar-local doom--flycheck-cache nil "")
|
||||||
|
(defun *flycheck ()
|
||||||
|
"Persistent and cached flycheck indicators in the mode-line."
|
||||||
|
(when (and (featurep 'flycheck)
|
||||||
|
flycheck-mode
|
||||||
|
(or flycheck-current-errors
|
||||||
|
(eq 'running flycheck-last-status-change)))
|
||||||
|
(or (and (or (eq doom--flycheck-err-cache doom--flycheck-cache)
|
||||||
|
(memq flycheck-last-status-change '(running not-checked)))
|
||||||
|
doom--flycheck-cache)
|
||||||
|
(and (setq doom--flycheck-err-cache flycheck-current-errors)
|
||||||
|
(setq doom--flycheck-cache
|
||||||
|
(let ((fe (doom/-flycheck-count 'error))
|
||||||
|
(fw (doom/-flycheck-count 'warning)))
|
||||||
|
(concat
|
||||||
|
(if fe (propertize (format " •%d " fe)
|
||||||
|
'face (if active
|
||||||
|
'doom-flycheck-error
|
||||||
|
'mode-line)))
|
||||||
|
(if fw (propertize (format " •%d " fw)
|
||||||
|
'face (if active
|
||||||
|
'doom-flycheck-warning
|
||||||
|
'mode-line))))))))))
|
||||||
|
|
||||||
|
(defun *selection-info ()
|
||||||
"Information about the current selection."
|
"Information about the current selection."
|
||||||
(when (and active (evil-visual-state-p))
|
(when (and active (evil-visual-state-p))
|
||||||
(powerline-raw
|
(propertize
|
||||||
(let ((reg-beg (region-beginning))
|
(let ((reg-beg (region-beginning))
|
||||||
(reg-end (region-end))
|
(reg-end (region-end))
|
||||||
(evil (eq 'visual evil-state)))
|
(evil (eq 'visual evil-state)))
|
||||||
@ -360,100 +338,103 @@ anzu to be enabled."
|
|||||||
(format " %dL " lines)
|
(format " %dL " lines)
|
||||||
(format " %dC %dL " chars lines)))
|
(format " %dC %dL " chars lines)))
|
||||||
(t (format " %dC " (if evil chars (1- chars)))))))
|
(t (format " %dC " (if evil chars (1- chars)))))))
|
||||||
highlight-face))
|
'face 'mode-line-highlight)))
|
||||||
:tight t)
|
|
||||||
|
|
||||||
;; flycheck
|
(defun *macro-recording ()
|
||||||
(defface doom-flycheck-error '((t (:inherit error)))
|
"Show when recording macro."
|
||||||
"Face for flycheck error feedback in the modeline.")
|
(when (and active defining-kbd-macro)
|
||||||
(defface doom-flycheck-warning '((t (:inherit warning)))
|
(propertize
|
||||||
"Face for flycheck warning feedback in the modeline.")
|
(format " %s ▶ " (char-to-string evil-this-macro))
|
||||||
|
'face 'mode-line-highlight)))
|
||||||
|
|
||||||
(defvar-local doom--flycheck-err-cache nil "")
|
(defface mode-line-count-face nil "")
|
||||||
(defvar-local doom--flycheck-cache nil "")
|
(make-variable-buffer-local 'anzu--state)
|
||||||
(spaceline-define-segment *flycheck
|
(defun *anzu ()
|
||||||
"Persistent and cached flycheck indicators in the mode-line."
|
"Show the current match number and the total number of matches. Requires anzu
|
||||||
(when (and (bound-and-true-p flycheck-mode)
|
to be enabled."
|
||||||
(or flycheck-current-errors
|
(when (and (featurep 'evil-anzu) (evil-ex-hl-active-p 'evil-ex-search))
|
||||||
(eq 'running flycheck-last-status-change)))
|
(propertize
|
||||||
(or (and (or (eq doom--flycheck-err-cache doom--flycheck-cache)
|
(format " %s/%d%s "
|
||||||
(memq flycheck-last-status-change '(running not-checked)))
|
anzu--current-position anzu--total-matched
|
||||||
doom--flycheck-cache)
|
(if anzu--overflow-p "+" ""))
|
||||||
(and (setq doom--flycheck-err-cache flycheck-current-errors)
|
'face (if active 'mode-line-count-face))))
|
||||||
(setq doom--flycheck-cache
|
|
||||||
(let ((fe (doom/-flycheck-count 'error))
|
|
||||||
(fw (doom/-flycheck-count 'warning)))
|
|
||||||
(concat
|
|
||||||
(if fe (propertize (format " •%s " fe)
|
|
||||||
'face (if active
|
|
||||||
'doom-flycheck-error
|
|
||||||
'mode-line)))
|
|
||||||
(if fw (propertize (format " •%s " fw)
|
|
||||||
'face (if active
|
|
||||||
'doom-flycheck-warning
|
|
||||||
'mode-line))))))))))
|
|
||||||
|
|
||||||
(defvar *pad-active (pl/percent-xpm powerline-height 100 0 100 0 3 "#00B3EF" nil))
|
(defun *evil-substitute ()
|
||||||
(defvar *pad-inactive (pl/percent-xpm powerline-height 100 0 100 0 3 nil nil))
|
"Show number of :s matches in real time."
|
||||||
(spaceline-define-segment *pad
|
(when (and (evil-ex-p) (evil-ex-hl-active-p 'evil-ex-substitute))
|
||||||
"Padding, to ensure the mode-line is `powerline-height' pixels tall"
|
(propertize
|
||||||
(if active *pad-active *pad-inactive)
|
(let ((range (if evil-ex-range
|
||||||
:tight t)
|
(cons (car evil-ex-range) (cadr evil-ex-range))
|
||||||
|
(cons (line-beginning-position) (line-end-position))))
|
||||||
|
(pattern (car-safe (evil-delimited-arguments evil-ex-argument 2))))
|
||||||
|
(if pattern
|
||||||
|
(format " %s matches "
|
||||||
|
(count-matches pattern (car range) (cdr range))
|
||||||
|
evil-ex-argument)
|
||||||
|
" ... "))
|
||||||
|
'face (if active 'mode-line-count-face))))
|
||||||
|
|
||||||
(spaceline-compile
|
(defun *iedit ()
|
||||||
'main
|
"Show the number of iedit regions matches + what match you're on."
|
||||||
'(*pad
|
(when (and (boundp 'iedit-mode) iedit-mode)
|
||||||
((*macro-recording *anzu *iedit
|
(propertize
|
||||||
*evil-substitute *selection-info *flycheck)
|
(let ((this-oc (let (message-log-max) (iedit-find-current-occurrence-overlay)))
|
||||||
:skip-alternate t
|
(length (or (ignore-errors (length iedit-occurrences-overlays)) 0)))
|
||||||
:tight t)
|
(format
|
||||||
*buffer-path)
|
" %s/%s "
|
||||||
'(*vc
|
(save-excursion
|
||||||
*major-mode
|
(unless this-oc
|
||||||
*env-version
|
(iedit-prev-occurrence)
|
||||||
*buffer-encoding-abbrev
|
(setq this-oc (iedit-find-current-occurrence-overlay)))
|
||||||
(global :when active)
|
(if this-oc
|
||||||
*buffer-position
|
;; NOTE: Not terribly reliable
|
||||||
))
|
(- length (-elem-index this-oc iedit-occurrences-overlays))
|
||||||
|
"-"))
|
||||||
|
length))
|
||||||
|
'face (if active 'mode-line-count-face))))
|
||||||
|
|
||||||
;;
|
(defun *buffer-position ()
|
||||||
(spaceline-define-segment *default-dir
|
"A more vim-like buffer position."
|
||||||
"Shows default-directory"
|
(let ((start (window-start))
|
||||||
(concat "[" (abbreviate-file-name default-directory) "]")
|
(end (window-end))
|
||||||
:face other-face)
|
(pend (point-max)))
|
||||||
|
(if (and (= start 1)
|
||||||
|
(= end pend))
|
||||||
|
":All"
|
||||||
|
(cond ((= start 1) ":Top")
|
||||||
|
((= end pend) ":Bot")
|
||||||
|
(t (format ":%d%%%%" (/ end 0.01 pend)))))))
|
||||||
|
|
||||||
(spaceline-compile
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
'scratch
|
|
||||||
'(*pad
|
|
||||||
((*macro-recording *anzu *iedit *evil-substitute *flycheck *selection-info)
|
|
||||||
:skip-alternate t
|
|
||||||
:tight t)
|
|
||||||
*buffer-path
|
|
||||||
*default-dir)
|
|
||||||
'(*major-mode
|
|
||||||
*env-version
|
|
||||||
*buffer-encoding-abbrev
|
|
||||||
(global :when active)
|
|
||||||
*buffer-position))
|
|
||||||
|
|
||||||
;;
|
(defun doom-mode-line (&optional id)
|
||||||
(spaceline-define-segment *eldoc
|
`(:eval
|
||||||
(and (bound-and-true-p str) str)
|
(let* ((active (eq (selected-window) mode-line-selected-window))
|
||||||
:tight t
|
(lhs (list (propertize " " 'display (if active mode-line-bar mode-line-inactive-bar))
|
||||||
:face 'mode-line)
|
(*flycheck)
|
||||||
|
(*macro-recording)
|
||||||
|
(*selection-info)
|
||||||
|
(*anzu)
|
||||||
|
(*evil-substitute)
|
||||||
|
(*iedit)
|
||||||
|
" "
|
||||||
|
(*buffer-path)
|
||||||
|
(*buffer-name)
|
||||||
|
" "
|
||||||
|
(*buffer-state)
|
||||||
|
,(if (eq id 'scratch) '(*buffer-pwd))))
|
||||||
|
(rhs (list (*buffer-encoding-abbrev)
|
||||||
|
(*vc)
|
||||||
|
" " (*major-mode) " "
|
||||||
|
(propertize
|
||||||
|
(concat "(%l,%c) " (*buffer-position))
|
||||||
|
'face (if active 'mode-line-2))))
|
||||||
|
(middle (propertize
|
||||||
|
" " 'display `((space :align-to (- (+ right right-fringe right-margin)
|
||||||
|
,(1+ (string-width (format-mode-line rhs)))))))))
|
||||||
|
(list lhs middle rhs))))
|
||||||
|
|
||||||
(defvar *eldoc-pad-xpm (pl/percent-xpm powerline-height 100 0 100 0 3 "#B3EF00" nil))
|
(setq-default mode-line-format (doom-mode-line))
|
||||||
(spaceline-define-segment *eldoc-pad
|
|
||||||
"Padding, to ensure the mode-line is `powerline-height' pixels tall"
|
|
||||||
*eldoc-pad-xpm
|
|
||||||
:tight t
|
|
||||||
:face 'mode-line)
|
|
||||||
|
|
||||||
(spaceline-compile
|
|
||||||
'eldoc '(*eldoc-pad *eldoc) '())
|
|
||||||
|
|
||||||
;; Initialize modeline
|
|
||||||
(setq-default mode-line-format '("%e" (:eval (spaceline-ml-main)))))
|
|
||||||
|
|
||||||
(provide 'core-ui)
|
(provide 'core-ui)
|
||||||
;;; core-ui.el ends here
|
;;; core-ui.el ends here
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
;;; custom-demo.el --- -*- no-byte-compile: t; -*-
|
;;; custom-demo.el --- -*- no-byte-compile: t; -*-
|
||||||
|
|
||||||
(defvar powerline-height)
|
|
||||||
|
|
||||||
;; This library offers:
|
;; This library offers:
|
||||||
;; + impatient-mode: for broadcasting my emacs session
|
;; + impatient-mode: for broadcasting my emacs session
|
||||||
;; + big-mode: for enlarged text while screencasting
|
;; + big-mode: for enlarged text while screencasting
|
||||||
@ -19,7 +17,7 @@
|
|||||||
:config (httpd-start))
|
:config (httpd-start))
|
||||||
|
|
||||||
(defvar big-mode--old-line-spacing line-spacing)
|
(defvar big-mode--old-line-spacing line-spacing)
|
||||||
(defvar big-mode--old-modeline-height powerline-height)
|
(defvar big-mode--old-modeline-height mode-line-height)
|
||||||
(define-minor-mode big-mode
|
(define-minor-mode big-mode
|
||||||
:init-value nil
|
:init-value nil
|
||||||
:lighter " BIG"
|
:lighter " BIG"
|
||||||
@ -28,10 +26,10 @@
|
|||||||
(doom/load-font (if big-mode big-mode-font doom-default-font)))
|
(doom/load-font (if big-mode big-mode-font doom-default-font)))
|
||||||
(if big-mode
|
(if big-mode
|
||||||
(setq-default
|
(setq-default
|
||||||
powerline-height big-mode-modeline-height
|
mode-line-height big-mode-modeline-height
|
||||||
line-spacing big-mode-line-spacing)
|
line-spacing big-mode-line-spacing)
|
||||||
(setq-default
|
(setq-default
|
||||||
powerline-height big-mode--old-modeline-height
|
mode-line-height big-mode--old-modeline-height
|
||||||
line-spacing big-mode--old-line-spacing)))
|
line-spacing big-mode--old-line-spacing)))
|
||||||
|
|
||||||
(evil-define-command doom:big (&optional size)
|
(evil-define-command doom:big (&optional size)
|
||||||
|
Reference in New Issue
Block a user