about summary refs log tree commit diff
path: root/emacs/.emacs.d/wpc/colorscheme.el
blob: 97ad59e960d8f91e255ff2c10a41268f92f4b056 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
;;; colorscheme.el --- Syntax highlight and friends -*- lexical-binding: t -*-
;; Author: William Carroll <wpcarro@gmail.com>

;;; Commentary:
;;
;; TODO: Clarify this.
;; Since I have my own definition of "theme", which couples wallpaper, font,
;; with Emacs's traditional notion of the word "theme", I'm choosing to use
;; "colorscheme" to refer to *just* the notion of syntax highlight etc.

;;; Code:

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Dependencies
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

(require 'cycle)
(require 'general)

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Constants
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

(defcustom colorscheme/install-kbds? t
  "If non-nil, enable the keybindings.")

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Library
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

(defcustom colorscheme/whitelist
  (cycle/from-list
   (->> (custom-available-themes)
        (list/map #'symbol-name)
        (list/filter (>> (s-starts-with? "doom-")))
        (list/map #'intern)))
  "The whitelist of colorschemes through which to cycle.")

(defun colorscheme/current ()
  "Return the currently enabled colorscheme."
  (cycle/current colorscheme/whitelist))

(defun colorscheme/disable-all ()
  "Disable all currently enabled colorschemes."
  (interactive)
  (->> custom-enabled-themes
       (list/map #'disable-theme)))

(defun colorscheme/set (theme)
    "Call `load-theme' with `THEME', ensuring that the line numbers are bright.
There is no hook that I'm aware of to handle this more elegantly."
    (load-theme theme t)
    (prelude-set-line-number-color "#da5468"))

(defun colorscheme/whitelist-set (colorscheme)
  "Focus the COLORSCHEME in the `colorscheme/whitelist' cycle."
  (cycle/focus (lambda (x) (equal x colorscheme)) colorscheme/whitelist)
  (colorscheme/set (colorscheme/current)))

(defun colorscheme/ivy-select ()
  "Load a colorscheme using ivy."
  (interactive)
  (let ((theme (ivy-read "Theme: " (cycle/to-list colorscheme/whitelist))))
    (colorscheme/disable-all)
    (colorscheme/set (intern theme))))

(cl-defun colorscheme/cycle (&key forward?)
  "Cycle next if `FORWARD?' is non-nil.
Cycle prev otherwise."
  (disable-theme (cycle/current colorscheme/whitelist))
  (let ((theme (if forward?
                   (cycle/next colorscheme/whitelist)
                 (cycle/prev colorscheme/whitelist))))
    (colorscheme/set theme)
    (message (s-concat "Active theme: " (symbol-to-string theme)))))

(defun colorscheme/next ()
  "Disable the currently active theme and load the next theme."
  (interactive)
  (colorscheme/cycle :forward? t))

(defun colorscheme/prev ()
  "Disable the currently active theme and load the previous theme."
  (interactive)
  (colorscheme/cycle :forward? nil))

;; Keybindings
(when colorscheme/install-kbds?
  (general-define-key
   :prefix "<SPC>"
   :states '(normal)
   "Ft" #'colorscheme/next
   "Pt" #'colorscheme/prev))

(provide 'colorscheme)
;;; colorscheme.el ends here