diff options
Diffstat (limited to '.config/emacs/init.el')
-rw-r--r-- | .config/emacs/init.el | 200 |
1 files changed, 151 insertions, 49 deletions
diff --git a/.config/emacs/init.el b/.config/emacs/init.el index 9c46633..5a92f14 100644 --- a/.config/emacs/init.el +++ b/.config/emacs/init.el @@ -1,6 +1,9 @@ -;; This config requires Emacs 24.4(+?) ;; Hey, Emacs: -*- Indent-tabs-mode: nil -*- + +;; This config requires Emacs 27. +;; With some differences in package.el initialization it should work with Emacs 24.4(+?). ;; Without (advice-add) it should work in older versions of Emacs 24. + ;;;; Use XDG-ish locations ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (let ((xdg-cache-home (file-name-as-directory (or (getenv "XDG_CACHE_HOME") "~/.cache"))) (xdg-data-home (file-name-as-directory (or (getenv "XDG_DATA_HOME") "~/.local/share")))) @@ -45,39 +48,81 @@ ;;;; Early settings ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; This isn't particularly important, but set it before doing a whole ;; lot (loading packages), so there isn't a weird change in text size. -(set-face-attribute 'default nil :height 80) +(set-face-attribute 'default nil + :family "DejaVu Sans Mono" + :height 80 + ;:weight 'semi-bold + ) ;;;; Package management ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; package.el -(require 'package) -(add-to-list 'package-archives '("melpa" . "http://melpa.org/packages/") t) -(setq package-enable-at-startup nil) -(package-initialize) +(when (require 'package) + (add-to-list 'package-archives + '("melpa-stable" . "https://stable.melpa.org/packages/") t) + (add-to-list 'package-archives + '("melpa" . "http://melpa.org/packages/") t) + ;; Always prefer versions from GNU > Melpa-Stable > Melpa, even if the + ;; later have higher version numbers. + (setq package-archive-priorities + '(("gnu" . 99) + ("melpa-stable" . 5) + ("melpa" . 0))) + (package-initialize)) + ;; use-package.el -(setq use-package-always-ensure t) -(add-to-list 'load-path (concat user-emacs-directory "use-package")) -(require 'use-package) +(eval-when-compile + (add-to-list 'load-path (concat user-emacs-directory "use-package")) + (require 'use-package) + (setq use-package-always-ensure t)) (require 'bind-key) -;; Themes -(use-package abyss-theme - :config (load-theme 'abyss t)) -;; Minor modes -;(use-package dtrt-indent ;; Detect indent style for existing files -; :config (dtrt-indent-mode 1)) -(use-package page-break-lines ;; Display form-feeds pretty - :init (advice-add 'page-break-lines-mode-maybe - :override #'page-break-lines-mode) - :config (global-page-break-lines-mode 1)) -;; (use-package smart-tabs-mode ;; Indent with tabs, align with spaces -;; :config (progn -;; (smart-tabs-mode 1) -;; (apply 'smart-tabs-insinuate -;; (mapcar 'car smart-tabs-insinuate-alist)))) +;; Themes ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(use-package modus-themes + :config (progn + ;; Modus makes MMM regions almost impossible to see + (add-hook 'modus-themes-after-load-theme-hook + '(lambda () + (modus-themes-with-colors + (custom-set-faces + `(mmm-cleanup-submode-face ((,class :background ,yellow-refine-bg))) + `(mmm-code-submode-face ((,class :background ,bg-active))) + `(mmm-comment-submode-face ((,class :background ,blue-refine-bg))) + `(mmm-declaration-submode-face ((,class :background ,cyan-refine-bg))) + `(mmm-default-submode-face ((,class :background ,bg-alt))) + `(mmm-init-submode-face ((,class :background ,magenta-refine-bg))) + `(mmm-output-submode-face ((,class :background ,red-refine-bg))) + `(mmm-special-submode-face ((,class :background ,green-refine-bg))))) + )) + ;; Load the theme. Use this function instead of + ;; load-theme in order to get the above hook. + (modus-themes-load-vivendi) + )) + +;; Minor modes ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(use-package adaptive-wrap +; :config (progn +; (adaptive-wrap-prefix-mode 1)) + ) (use-package editorconfig - :config (editorconfig-mode 1)) + :config (progn + (editorconfig-mode 1) + (add-to-list 'editorconfig-indentation-alist '(protobuf-mode c-basic-offset)) + (add-to-list 'editorconfig-indentation-alist '(terraform-mode terra-indent-level + terraform-indent-level + hcl-indent-level)) + )) +(use-package jq-format + :commands (jq-format-json-buffer + jq-format-json-region + jq-format-json-on-save-mode + jq-format-jsonlines-buffer + jq-format-jsonlines-region + jq-format-jsonlines-on-save-mode)) +(use-package multiple-cursors + :bind (("C-c m l" . mc/edit-lines) + ("C-c m n" . mc/insert-numbers))) (use-package outline-magic :commands (outline-cycle outline-next-line @@ -85,8 +130,24 @@ outline-move-subtree-down outline-promote outline-demote)) -;; Major modes (non-HTML-related) +(use-package page-break-lines ;; Display form-feeds pretty + :init (advice-add 'page-break-lines-mode-maybe + :override #'page-break-lines-mode) + :config (global-page-break-lines-mode 1)) +(use-package smart-tabs-mode ;; Indent with tabs, align with spaces + :config (progn + (smart-tabs-mode 1) + (apply 'smart-tabs-insinuate + (mapcar 'car smart-tabs-insinuate-alist)))) + +;; Major modes (non-HTML-related) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (use-package bats-mode :mode "\\.bats\\'") +(use-package bazel + :mode (((rx "/" (or "BUILD" "BUILD.bazel") eos) . bazel-build-mode) + ((rx "/" (or "WORKSPACE" "WORKSPACE.bazel") eos) . bazel-workspace-mode) + ((rx "/" (+ nonl) ".bzl" eos) . bazel-starlark-mode) + ((rx "/" (or "bazel.bazelrc" ".bazelrc") eos) . bazelrc-mode) + ((rx "/.bazelignore" eos) . bazelignore-mode))) (use-package bison-mode :mode (("\\.l\\'" . bison-mode) ("\\.y\\'" . bison-mode) @@ -98,12 +159,19 @@ dockerfile-build-no-cache-buffer)) (use-package glsl-mode :mode ("\\.vert\\'" "\\.frag\\'" "\\.geom\\'" "\\.glsl\\'")) (use-package go-mode :mode ("\\.go\\'" "go\\.mod")) +(use-package graphql-mode :mode ("\\.graphql\\'" "\\.gql\\'")) (use-package graphviz-dot-mode :mode ("\\.dot\\'" "\\.gv\\'") :config (add-hook 'graphviz-dot-mode-hook '(lambda () (set (make-local-variable 'graphviz-dot-auto-indent-on-semi) nil) ))) +(use-package jq-mode + :mode "\\.jq\\'" + :interpreter "jq") +(use-package lua-mode + :mode "\\.lua\\'" + :interpreter "lua") (use-package markdown-mode :mode ("\\.markdown\\'" "\\.md\\'" "\\.ronn\\'")) (use-package meson-mode :mode "/meson\\(\\.build\\|_options\\.txt\\)\\'") (use-package nginx-mode :mode ("nginx\\.conf\\'" "/nginx/.+\\.conf\\'")) @@ -116,7 +184,8 @@ (outline-minor-mode t) (set (make-local-variable 'outline-regexp) "[ \t]*[A-Za-z-]") ))) -;; Major modes (HTML-related) + +;; Major modes (HTML-related) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (use-package coffee-mode :mode ("\\.coffee\\'" "\\.iced\\'" @@ -134,25 +203,35 @@ :mode ("\\.php[s345t]?\\'" "/\\.php_cs\\(\\.dist\\)?\\'" "\\.phtml\\'" "/Amkfile\\'" "\\.amk\\'") :interpreter "php\\(?:-?[3457]\\(?:\\.[0-9]+\\)*\\)?") (use-package scss-mode :mode "\\.scss\\'") -(use-package typescript-mode :mode "\\.ts\\'") -(use-package web-mode :mode "\\.html\\'") - -;;(use-package nxhtml) ; nxhtml is invasive, only enable if actively using - -;; IDK? I guess I decided that plain php-mode had improved? -;; -;;(use-package php-mode-improved -;; :mode (("\\.php[s34]?\\'" . php-mode) -;; ("\\.phtml\\'" . php-mode) -;; ("\\.inc\\'" . php-mode)) -;; :config (add-hook 'php-mode-hook -;; '(lambda () -;; (c-set-offset 'cpp-macro 0) -;; ))) +(use-package typescript-mode :mode "\\.tsx?\\'") +(use-package web-mode + :mode ("\\.html\\'" + "\\.vue\\'")) +(use-package mmm-mode + :load mmm-auto + :config (progn + ;; Define the class + (mmm-add-classes + '((js-graphql + :submode graphql-mode + :face mmm-code-submode-face + :front "[^a-zA-Z]graphql`" + :back "`"))) + ;; Add too mmm-mode-ext-classes-alist + (mmm-add-mode-ext-class 'js-mode nil 'js-graphql) + (setq + ;; Enable MMM for modes/files named in + ;; mmm-mode-ext-classes-alist, and only modes/files named + ;; in mmm-mode-ext-classes-alist. + mmm-global-mode 'maybe + ;; 0 = none, 1 = low, 2 = high + mmm-submode-decoration-level 2) + )) +;; Email ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (if (file-exists-p "~/Maildir") - ;;'(apel flim semi wanderlust) (use-package wanderlust + :commands (wl) :config (progn (define-mail-user-agent 'wl-user-agent @@ -264,12 +343,14 @@ sh-script.el is broken." ;; Backup settings (setq - backup-by-copying t ;; don't clobber symlinks - backup-directory-alist '(("." . "~/.cache/emacs/saves")) ;; don't litter my fs tree - delete-old-versions t - kept-new-versions 6 - kept-old-versions 2 - version-control t ;; use versioned backups + backup-by-copying t ;; don't clobber symlinks + backup-directory-alist '(("." . "~/.cache/emacs/saves")) ;; don't litter my fs tree + delete-old-versions t + kept-new-versions 6 + kept-old-versions 2 + version-control t ;; use versioned backups + + create-lockfiles nil ;; don't litter my fs tree ) ;; Web browser settings @@ -356,14 +437,35 @@ sh-script.el is broken." (local-set-key [C-tab] 'hs-toggle-hiding) )) +(add-hook 'python-mode-hook + (lambda () + (hs-minor-mode t) + (local-set-key [C-tab] 'hs-toggle-hiding) + )) + (add-hook 'outline-minor-mode-hook (lambda () (define-key outline-minor-mode-map [C-tab] 'outline-cycle))) +(add-hook 'web-mode-hook + (lambda () + (setq web-mode-enable-auto-closing nil) + (setq web-mode-enable-auto-pairing nil) + (setq web-mode-enable-auto-opening nil) + (setq web-mode-enable-auto-quoting nil) + (setq web-mode-enable-auto-expanding nil) + (setq web-mode-enable-auto-indentation nil) + )) + (add-to-list 'auto-mode-alist '("PKGBUILD" . sh-mode)) (add-to-list 'auto-mode-alist '("SRCBUILD" . sh-mode)) (add-to-list 'auto-mode-alist '("\\.mak\\'" . makefile-gmake-mode)) (add-to-list 'auto-mode-alist '("\\.jad\\'" . java-mode)) +(add-to-list 'auto-mode-alist '("\\.schema\\'" . js-mode)) + +(eval-when-compile + (add-to-list 'load-path (concat user-emacs-directory "go-template-mode")) + (require 'go-template-mode)) ;; Anything that gets magically appended ;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |