;;; Emacs Bedrock ;;; ;;; Minimal init.el ;;; Contents: ;;; ;;; - Discovery aids ;;; - Minibuffer/completion settings ;;; - Interface enhancements/defaults ;;; - Tab-bar configuration ;;; - Theme ;;; - Optional mixins ;;; - Built-in customization framework ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; ;;; Discovery aids ;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; Show the help buffer after startup (add-hook 'after-init-hook 'help-quick) ;; which-key: shows a popup of available keybindings (use-package which-key :ensure t :config (which-key-mode)) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; ;;; Minibuffer/completion settings ;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; For help, see: https://www.masteringemacs.org/article/understanding-minibuffer-completion (setq enable-recursive-minibuffers t) ; Use the minibuffer whilst in the minibuffer (setq completion-cycle-threshold 1) ; TAB cycles candidates (setq completions-detailed t) ; Show annotations (setq tab-always-indent 'complete) ; When I hit TAB, try to complete, otherwise, indent (fido-vertical-mode) ; Show completion candidates in a vertical, interactive list (setq completion-styles '(basic initials substring)) ; Different styles to match input to candidates (define-key minibuffer-mode-map (kbd "TAB") 'minibuffer-complete) ; TAB acts more like how it does in the shell ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; ;;; Interface enhancements/defaults ;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; Mode line information (setq line-number-mode t) (setq column-number-mode t) (setq x-underline-at-descent-line nil) ; Prettier underlines (setq frame-resize-pixelwise t) (setq switch-to-buffer-obey-display-actions t) (setq-default show-trailing-whitespace nil) (setq-default indicate-buffer-boundaries 'left) ;; Enable horizontal scrolling (setq mouse-wheel-tilt-scroll t) (setq mouse-wheel-flip-direction t) ;; We won't set these, but they're good to know about ;; ;; (setq-default indent-tabs-mode nil) ;; (setq-default tab-width 4) ;; Misc. UI tweaks (blink-cursor-mode -1) (tool-bar-mode -1) (pixel-scroll-precision-mode) (global-hl-line-mode) ;; Display line numbers in programming mode (add-hook 'prog-mode-hook 'display-line-numbers-mode) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; ;;; Tab-bar configuration ;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; Show the tab-bar as soon as tab-bar functions are invoked (setq tab-bar-show 0) ;; Add the time to the tab-bar, if visible (add-to-list 'tab-bar-format 'tab-bar-format-align-right 'append) (add-to-list 'tab-bar-format 'tab-bar-format-global 'append) (setq display-time-format "%a %F %T") (setq display-time-interval 1) (display-time-mode) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; ;;; Theme ;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; We just use the built-in high contrast theme modus-vivendi (load-theme 'modus-vivendi) ;; If you like light-mode themes instead, use this: ;(load-theme 'modus-operandi) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; ;;; Optional mixins ;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; Uncomment these lines or copy from the mixin/ files as you see fit ;; UI/UX enhancements mostly focused on minibuffer and autocompletion interfaces ;(load-file "mixins/ui.el") ;; Packages for software development ;(load-file "mixins/dev.el") ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; ;;; Built-in customization framework ;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;