summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Lemon <matt@matthewlemon.com>2022-11-19 08:50:51 +0000
committerMatthew Lemon <matt@matthewlemon.com>2022-11-19 08:50:51 +0000
commit08053502a9b68accc972e237b9db5ca85356d269 (patch)
tree339a6146424710a431e827c3006583433b34e515
parente5692228f27c834e608e3dda780dea900dcd41b9 (diff)
removed org init and went back to native init.el file
Diffstat (limited to '')
-rw-r--r--init.el802
-rw-r--r--myinit.org921
2 files changed, 797 insertions, 926 deletions
diff --git a/init.el b/init.el
index 6729f7e..edb38bb 100644
--- a/init.el
+++ b/init.el
@@ -13,14 +13,806 @@
(eval-when-compile
(require 'use-package))
(setq use-package-always-ensure t)
-
-;; start of use-package
(require 'use-package)
-
(require 'org)
(add-to-list 'org-modules 'org-habit)
-(org-babel-load-file (expand-file-name "~/.emacs.d/myinit.org"))
+;; (org-babel-load-file (expand-file-name "~/.emacs.d/myinit.org"))
+
+;; Garbage collection
+(setq gc-cons-percentage 0.6)
+
+;; MISC optimizations
+(setq idle-update-delay 1.0)
+(setq-default bidi-display-reordering 'left-to-right
+ bidi-paragraph-direction 'left-to-right)
+(setq-default cursor-in-non-selected-windows nil)
+(setq hightlight-nonselected-windows nil)
+(setq fast-but-imprecise-scrolling t)
+(setq inhibit-compacting-font-caches t)
+(menu-bar-mode 1)
+
+(add-hook 'org-mode-hook 'visual-line-mode)
+
+;; turn off flycheck-mode
+(add-hook 'org-mode-hook (lambda () flycheck-mode -1))
+
+(setq user-full-name "Matthew Lemon"
+ user-mail-address "matt@matthewlemon.com")
+
+(defun establish-machine ()
+ (let ((sys (system-name)))
+ (if (string= sys "archdesk")
+ (setq mrl/computer 'desktop)
+ (setq mrl/computer 'laptop))))
+
+(establish-machine)
+
+;; handier undo
+(global-unset-key "\C-z")
+(global-set-key "\C-z" 'advertised-undo)
+
+(setq inhibit-startup-message 1)
+(scroll-bar-mode -1)
+(tool-bar-mode -1)
+(tooltip-mode -1)
+(set-fringe-mode 10)
+
+(put 'narrow-to-defun 'disabled nil)
+(put 'narrow-to-page 'disabled nil)
+(put 'narrow-to-region 'disabled nil)
+
+;; we don't want the old buffer list!
+(global-unset-key (kbd "C-x C-b"))
+
+;; Put backups in /tmp where they belong
+(setq backup-directory-alist
+ `((".*" . ,temporary-file-directory)))
+(setq auto-save-file-name-transforms
+ `((".*" ,temporary-file-directory t)))
+
+;; recursively copy by default
+(setq dired-recursive-copies 'always)
+
+;; y or n instead of yes or no
+(fset 'yes-or-no-p 'y-or-n-p)
+
+;; auto revert files
+(global-auto-revert-mode t)
+
+;; BACKUPS/LOCKFILES --------
+;; Don't generate backups or lockfiles.
+(setq create-lockfiles nil
+ make-backup-files nil
+ ;; But in case the user does enable it, some sensible defaults:
+ version-control t ; number each backup file
+ backup-by-copying t ; instead of renaming current file (clobbers links)
+ delete-old-versions t ; clean up after itself
+ kept-old-versions 5
+ kept-new-versions 5
+ backup-directory-alist (list (cons "." (concat user-emacs-directory "backup/"))))
+
+;; Display the current time
+(display-time-mode t)
+
+(setq visible-bell t)
+
+;; font
+(cond
+ ((string-equal (system-name) "archdesk")
+ (when (member "Hack" (font-family-list))
+ (add-to-list 'default-frame-alist '(font . "Hack-14"))))
+ ((string-equal (system-name) "pop_os")
+ (when (member "Hack" (font-family-list))
+ (add-to-list 'default-frame-alist '(font . "Hack-10")))))
+
+ (use-package gruber-darker-theme
+ :ensure t
+ :config
+ (load-theme 'gruber-darker t))
+
+ (setq display-line-numbers-type `relative)
+ (setq undo-limit 8000000) ; raise limit to 80Mb
+ (setq truncate-string-ellipsis "…") ; better than using dots
+ (setq scroll-preserve-screen-position 'always) ; experimental
+ (setq scroll-margin 3) ; bit of space
+
+
+ ;; calendar proper Monday start
+ (setq calendar-week-start-day 1)
+ (setq calendar-date-style (quote european))
+
+ ;; Handling tabs (for programming)
+ (setq-default tab-width 2)
+ (setq-default tab-width 2 indent-tabs-mode nil)
+ (setq-default indent-tabs-mode nil)
+ (setq js-indent-level 2)
+ (setq python-indent 2)
+ (setq css-indent-offset 2)
+ (add-hook 'sh-mode-hook
+ (lambda ()
+ (setq sh-basic-offset 2
+ sh-indentation 2)))
+ (setq web-mode-markup-indent-offset 2)
+
+ ;; Highlight matching parens
+ (show-paren-mode t)
+
+ ;; Stop C-z suspending emacs
+ (global-set-key (kbd "C-z") 'nil)
+
+ ;; encoding
+ (prefer-coding-system 'utf-8)
+ (setq coding-system-for-read 'utf-8)
+ (setq coding-system-for-write 'utf-8)
+
+;; Yasnippet
+(use-package yasnippet
+:diminish yas-minor-mode
+ :hook ((prog-mode LaTeX-mode org-mode) . yas-minor-mode)
+ :bind
+ (:map yas-minor-mode-map ("C-c C-n" . yas-expand-from-trigger-key))
+ (:map yas-keymap
+ (("TAB" . smarter-yas-expand-next-field)
+ ([(tab)] . smarter-yas-expand-next-field)))
+ :config
+ (use-package yasnippet-snippets)
+ (yas-reload-all)
+ (defun smarter-yas-expand-next-field ()
+ "Try to `yas-expand' then `yas-next-field' at current cursor position."
+ (interactive)
+ (let ((old-point (point))
+ (old-tick (buffer-chars-modified-tick)))
+ (yas-expand)
+ (when (and (eq old-point (point))
+ (eq old-tick (buffer-chars-modified-tick)))
+ (ignore-errors (yas-next-field))))))
+
+;; this config works better with yasnippet
+(use-package company
+ :diminish company-mode
+ :hook ((prog-mode LaTeX-mode latex-mode ess-r-mode ledger-mode) . company-mode)
+ :bind
+ (:map company-active-map
+ ([tab] . smarter-yas-expand-next-field-complete)
+ ("TAB" . smarter-yas-expand-next-field-complete))
+ :custom
+ (company-tooltip-align-annotations t)
+ (company-begin-commands '(self-insert-command))
+ (company-require-match 'never)
+ ;; Don't use company in the following modes
+ (company-global-modes '(not shell-mode eaf-mode))
+ ;; Trigger completion immediately.
+ (company-idle-delay 0.1)
+ ;; Number the candidates (use M-1, M-2 etc to select completions).
+ (company-show-numbers t)
+ :config
+ ;; clangd variable not present which was a problem
+;; (unless *clangd* (delete 'company-clang company-backends))
+;; (global-company-mode 1)
+ (setq company-idle-delay 0)
+ (setq company-minimum-prefix-length 3)
+ (defun smarter-yas-expand-next-field-complete ()
+ "Try to `yas-expand' and `yas-next-field' at current cursor position.
+
+If failed try to complete the common part with `company-complete-common'"
+ (interactive)
+ (if yas-minor-mode
+ (let ((old-point (point))
+ (old-tick (buffer-chars-modified-tick)))
+ (yas-expand)
+ (when (and (eq old-point (point))
+ (eq old-tick (buffer-chars-modified-tick)))
+ (ignore-errors (yas-next-field))
+ (when (and (eq old-point (point))
+ (eq old-tick (buffer-chars-modified-tick)))
+ (company-complete-common))))
+ (company-complete-common))))
+
+(use-package deft
+ :ensure t
+ :config
+ (defun mrl/kill-deft ()
+ (kill-buffer "*Deft*"))
+ (setq deft-directory "~/org-roam"
+ deft-extensions '("org" "md" "txt")
+ deft-recursive t
+ deft-file-limit 40
+ deft-use-filename-as-title t)
+ (add-hook 'deft-open-file-hook 'mrl/kill-deft))
+
+;; Ace Jump
+(use-package ace-jump-mode
+ :bind ("C-M-SPC" . ace-jump-mode))
+
+;; Lisp programming
+(use-package paredit
+ :init
+ (add-hook 'clojure-mode-hook #'enable-paredit-mode)
+ (add-hook 'cider-repl-mode-hook #'enable-paredit-mode)
+ (add-hook 'emacs-lisp-mode-hook #'enable-paredit-mode)
+ (add-hook 'eval-expression-minibuffer-setup-hook #'enable-paredit-mode)
+ (add-hook 'ielm-mode-hook #'enable-paredit-mode)
+ (add-hook 'lisp-mode-hook #'enable-paredit-mode)
+ (add-hook 'lisp-interaction-mode-hook #'enable-paredit-mode)
+ (add-hook 'scheme-mode-hook #'enable-paredit-mode)
+ :config
+ (show-paren-mode t)
+ :bind (("M-[" . paredit-wrap-square)
+ ("M-{" . paredit-wrap-curly))
+ :diminish nil)
+
+(use-package rainbow-delimiters
+ :config
+ (add-hook 'prog-mode-hook 'rainbow-delimiters-mode))
+
+;; EVIL
+ (use-package evil
+ :init
+ :config
+ (setq evil-respect-visual-line-mode t)
+ (setq evil-default-state 'emacs)
+ (evil-mode 0))
+
+;; which-key
+(use-package which-key
+ :config
+ (which-key-mode))
+
+(use-package elfeed
+ :config
+ (setq elfeed-feeds
+ '(("http://feeds.bbci.co.uk/news/rss.xml?edition=uk" news)
+ ("http://feeds.bbci.co.uk/news/technology/rss.xml" tech news)
+ ("https://planet.emacslife.com/atom.xml" emacs)
+ ("https://irreal.org/blog/?feed=rss2" emacs)
+ ("https://karl-voit.at/feeds/lazyblorg-all.atom_1.0.links-only.xml" emacs)
+ ("https://dominiccummings.com/rss.xml" blog tech)
+ ("https://usesthis.com/feed.atom" tech blog)
+ ("https://plaintextproject.online/feed.xml" plaintext productivity)
+ ("https://feeds.feedburner.com/StudyHacks" productivity)
+ ("http://newsrss.bbc.co.uk/rss/sportonline_uk_edition/rugby_union/rss.xml" rugby)
+ ("http://feeds.bbci.co.uk/news/video_and_audio/politics/rss.xml" news)
+ ("https://feeds.feedburner.com/arstechnica/open-source" opensource)
+ ("https://www.computerweekly.com/rss/IT-security.xml" cyber)
+ ("http://tonsky.me/blog/atom.xml" blog)
+ ("https://akkshaya.blog/feed" blob)
+ ("https://miguelmota.com/index.xml" blog)
+ ("https://www.computerweekly.com/rss/IT-security.xml" security)
+ ("https://www.fsf.org/static/fsforg/rss/news.xml" opensource)
+ ("https://www.reddit.com/r/emacs.rss" emacs)
+ ("https://www.reddit.com/r/rugbyunion/.rss" rugby)
+ ("http://pragmaticemacs.com/feed/" emacs)
+ ("https://200ok.ch/atom.xml" emacs)
+ ("http://www.linuxinsider.com/perl/syndication/rssfull.pl" linux)
+ ("http://planet.debian.org/rss20.xml" debian linux)
+ ("http://feeds2.feedburner.com/Command-line-fu" linux)
+ ("https://opensource.org/news.xml" opensource)
+ ("https://www.wired.com/feed/rss" news tech)
+ ("https://sivers.org/en.atom" blog))))
+
+;; get scoring in elfeed
+(use-package elfeed-score
+ :ensure t
+ :config
+ (progn
+ (elfeed-score-enable)
+ (define-key elfeed-search-mode-map "=" elfeed-score-map)))
+
+;; Basic magit
+(use-package magit
+ :bind ("C-x g" . magit-status))
+
+(use-package cider
+ :ensure t)
+
+;; Interactively Do Things (ido)
+(use-package ido
+ :config
+ (ido-mode t)
+ (ido-everywhere t)
+ (setq ido-enable-flex-matching t)
+ (setq ido-create-new-buffer 'always)
+ (setq ido-everywhere t)
+ (setq ido-file-extensions-order '(".org" ".txt" ".py" ".emacs" ".md" ".xml" ".el" ".ini"))
+ (setq ido-enable-flex-matching t))
+
+;; ;; helm
+;; (require 'helm-config)
+;; (global-set-key (kbd "M-x") #'helm-M-x)
+;; (global-set-key (kbd "C-x r b") #'helm-filtered-bookmarks)
+;; (global-set-key (kbd "C-x C-f") #'helm-find-files)
+;; ;; The default "C-x c" is quite close to "C-x C-c", which quits Emacs.
+;; ;; Changed to "C-c h". Note: We must set "C-c h" globally, because we
+;; ;; cannot change `helm-command-prefix-key' once `helm-config' is loaded.
+;; (global-set-key (kbd "C-c h") 'helm-command-prefix)
+;; (global-unset-key (kbd "C-x c"))
+;; (helm-mode 1)
+
+;; ledger mode
+(use-package ledger-mode
+ :ensure t
+ :mode ("\\.ledger\\'")
+ :config
+ ;; (setq ledger-default-date-format "%d/%m/%Y")
+ (setq ledger-reports
+ '(("hsbc_current_account" "ledger [[ledger-mode-flags]] --date-format \"%d/%m/%Y\" -f /home/lemon/Documents/Budget/ledger/2021/budget2021.ledger reg Assets\\:HSBC\\:Current")
+ ("bal" "%(binary) -f %(ledger-file) bal")
+ ("reg" "%(binary) -f %(ledger-file) reg")
+ ("payee" "%(binary) -f %(ledger-file) reg @%(payee)")
+ ("account" "%(binary) -f %(ledger-file) reg %(account)")))
+ (add-hook 'ledger-mode-hook
+ (lambda ()
+ (setq-local tab-always-indent 'complete)
+ (setq-local completion-cycle-threshold t)
+ (setq-local ledger-complete-in-steps t)))
+ :custom (ledger-clear-whole-transactions t))
+
+(use-package ivy
+ :diminish
+ :init
+ (use-package amx :defer t)
+ (use-package counsel :diminish :config (counsel-mode 1))
+ (use-package swiper :defer t)
+ (ivy-mode 1)
+ :bind
+ (("C-s" . swiper-isearch)
+ ("C-x C-f" . counsel-find-file)
+ ("C-x C-m" . counsel-M-x)
+ ("C-h f" . counsel-describe-function)
+ ("C-h v" . counsel-describe-variable)
+ ("C-z s" . counsel-rg)
+ ("C-x C-r" . counsel-recentf)
+ ("C-z b" . counsel-buffer-or-recentf)
+ ("C-z C-b" . counsel-ibuffer)
+ (:map ivy-minibuffer-map
+ ("C-r" . ivy-previous-line-or-history)
+ ("M-RET" . ivy-immediate-done))
+ (:map counsel-find-file-map
+ ("C-~" . counsel-goto-local-home)))
+ :custom
+ (ivy-use-virtual-buffers t)
+ (ivy-height 13)
+ (ivy-on-del-error-function nil)
+ (ivy-magic-slash-non-match-action 'ivy-magic-slash-non-match-create)
+ (ivy-count-format "【%d/%d】")
+ (ivy-wrap t)
+ :config
+ (setq projectile-completion-system 'ivy)
+ (defun counsel-goto-local-home ()
+ "Go to the $HOME of the local machine."
+ (interactive)
+ (ivy--cd "~/")))
+
+;; beacon mode
+(use-package beacon
+ :config
+ (setq beacon-color "OrangeRed")
+ (beacon-mode 1))
+
+;; flycheck syntax highlighting
+(use-package flycheck
+ :ensure t
+ :init (global-flycheck-mode))
+
+;; turn off flycheck-mode for org
+(setq flycheck-global-modes '(not org-mode))
+
+;; install pdf-tools
+(use-package pdf-tools)
+(pdf-tools-install)
+
+;; dired
+(use-package dired
+ :ensure nil
+ :bind
+ (("C-x C-j" . dired-jump)
+ ("C-x j" . dired-jump-other-window))
+ :custom
+ ;; Always delete and copy recursively
+ (dired-recursive-deletes 'always)
+ (dired-recursive-copies 'always)
+ ;; Auto refresh Dired, but be quiet about it
+ (global-auto-revert-non-file-buffers t)
+ (auto-revert-verbose nil)
+ ;; Quickly copy/move file in Dired
+ (dired-dwim-target t)
+ ;; Move files to trash when deleting
+ (delete-by-moving-to-trash t)
+ :config
+ ;; Reuse same dired buffer, to prevent numerous buffers while navigating in dired
+ (put 'dired-find-alternate-file 'disabled nil)
+ :hook
+ (dired-mode . (lambda ()
+ (local-set-key (kbd "<mouse-2>") #'dired-find-alternate-file)
+ (local-set-key (kbd "RET") #'dired-find-alternate-file)
+ (local-set-key (kbd "^")
+ (lambda () (interactive) (find-alternate-file ".."))))))
+
+;; dired config
+;; human readable
+(setq-default dired-listing-switches "-alh")
+;; Ability to use a to visit a new directory or file in dired instead of using RET. RET works just fine,
+;; but it will create a new buffer for every interaction whereas a reuses the current buffer.
+(put 'dired-find-alternate-file 'disabled nil)
+(setq dired-recursive-copies 'always)
+
+;; auto-package-update
+(use-package auto-package-update
+ :if (not (daemonp))
+ :custom
+ (auto-package-update-interval 7) ;; in days
+ (auto-package-update-prompt-before-update t)
+ (auto-package-update-delete-old-versions t)
+ (auto-package-update-hide-results t)
+ :config
+ (auto-package-update-maybe))
+
+;; remove certain minor modes from the mode line
+(use-package diminish)
+
+;; Windmove - use Shift and arrow keys to move in windows
+;; this fucks around with org mode - we want to shift timestamps and stuff
+;;(when (fboundp 'windmove-default-keybindings)
+;; (windmove-default-keybindings))
+
+;; Winner mode - undo and redo changes in window config
+;; with C-c left and C-c right
+(use-package winner
+ :ensure nil
+ :custom
+ (winner-boring-buffers
+ '("*Completions*"
+ "*Compile-Log*"
+ "*inferior-lisp*"
+ "*Fuzzy Completions*"
+ "*Apropos*"
+ "*Help*"
+ "*cvs*"
+ "*Buffer List*"
+ "*Ibuffer*"
+ "*esh command on file*"))
+ :config
+ (winner-mode 1))
+
+;; elpy for python
+(use-package elpy
+ :ensure t
+ :config
+ (setq elpy-modules (delq 'elpy-module-flymake elpy-modules))
+ (add-hook 'elpy-mode-hook 'flycheck-mode)
+ :init
+ (elpy-enable))
+
+(when (load "flycheck" t t)
+(setq elpy-modules (delq 'elpy-module-flymake elpy-modules))
+(add-hook 'elpy-mode-hook 'flycheck-mode))
+
+;; Ace Window
+(use-package ace-window
+ :bind (("C-x o" . ace-window)
+ ("M-2" . ace-window))
+ :init
+ (setq aw-background t
+ aw-keys '(?a ?o ?e ?u ?i ?d ?h ?t ?n ?s)))
+
+;; expand-region
+(use-package expand-region
+ :bind (("C-@" . er/expand-region)
+ ("C-=" . er/expand-region)
+ ("M-3" . er/expand-region)))
+
+;; browse-kill-ring
+(use-package browse-kill-ring
+ :bind ("C-x C-y" . browse-kill-ring)
+ :config
+ (setq browse-kill-ring-quit-action 'kill-and-delete-window))
+
+(setq save-interprogram-paste-before-kill t)
+
+;; recentf
+(use-package recentf
+:hook (after-init . recentf-mode)
+:custom
+(recentf-auto-cleanup "05:00am")
+(recentf-exclude '((expand-file-name package-user-dir)
+ ".cache"
+ ".cask"
+ ".elfeed"
+ "bookmarks"
+ "cache"
+ "ido.*"
+ "persp-confs"
+ "recentf"
+ "undo-tree-hist"
+ "url"
+ "COMMIT_EDITMSG\\'"))
+(setq recentf-auto-cleanup 'never
+ recentf-max-saved-items 50
+ recentf-save-file (concat user-emacs-directory ".recentf"))
+(setq recentf-max-menu-items 25)
+(setq recentf-max-saved-items 25)
+(recentf-mode t))
+
+(use-package org-roam
+ :ensure t
+ :custom
+ (org-roam-dailies-directory "daily/")
+ (org-roam-directory "~/org-roam")
+ (org-roam-capture-ref-templates
+ '(("d" "default" plain
+ "%?"
+ :target (file+head "%<%Y%m%d%H%M%S>-${slug}.org" "#+title: ${title}\n")
+ :unnarrowed t)))
+ (org-roam-capture-templates
+ '(("d" "default" plain
+ "%?"
+ :target (file+head "%<%Y%m%d%H%M%S>-${slug}.org" "#+title: ${title}\n")
+ :unnarrowed t)
+ ("e" "encrypted" plain
+ "%?"
+ :target (file+head "%<%Y%m%d%H%M%S>-${slug}.org.gpg" "#+title: ${title}\n")
+ :unnarrowed t)))
+ (org-roam-dailies-capture-templates
+ '(("d" "default" entry "* %<%T>: %?"
+ :target (file+head "%<%Y-%m-%d>.org" "#+title: %<%Y-%m-%d>\n")
+ :unnarrowed t)))
+ :bind (("C-c n l" . org-roam-buffer-toggle)
+ ("C-c n f" . org-roam-node-find)
+ ("C-c n i" . org-roam-node-insert)
+ ("C-c n n" . org-roam-dailies-capture-today)
+ ("C-c n t" . org-roam-dailies-goto-today)
+ :map org-roam-mode-map
+ ("y" . org-roam-dailies-goto-previous-note)
+ ("t" . org-roam-dailies-goto-next-note)
+ ("d" . org-roam-dailies-goto-date)
+ ("D" . org-roam-dailies-capture-date))
+ :bind-keymap ("C-c n D" . org-roam-mode-map)
+ :config
+ (require 'org-roam-protocol)
+ (org-roam-db-autosync-mode)
+ ;; Bind this to C-c n I
+ (defun org-roam-node-insert-immediate (arg &rest args)
+ (interactive "P")
+ (let ((args (cons arg args))
+ (org-roam-capture-templates (list (append (car org-roam-capture-templates)
+ '(:immediate-finish t)))))
+ (apply #'org-roam-node-insert args)))
+ :bind (("C-c n I" . org-roam-node-insert-immediate)))
+
+(use-package unicode-fonts
+ :ensure t
+ :config
+ (unicode-fonts-setup))
+
+;; some core bindings
+;; Use iBuffer instead of Buffer List
+;;(global-set-key (kbd "C-x C-b") #'ibuffer)
+;; Truncate lines
+(global-set-key (kbd "C-x C-l") #'toggle-truncate-lines)
+;; Adjust font size like web browsers
+(global-set-key (kbd "C-+") #'text-scale-increase)
+(global-set-key (kbd "C--") #'text-scale-decrease)
+;; Move up/down paragraph
+(global-set-key (kbd "M-n") #'forward-paragraph)
+(global-set-key (kbd "M-p") #'backward-paragraph)
+
+;; kill other buffers
+(defun kill-other-buffers ()
+ "Kill all other buffers."
+ (interactive)
+ (mapc 'kill-buffer (delq (current-buffer) (buffer-list))))
+
+(setq calendar-latitude 55.77)
+(setq calendar-longitude -2.01)
+(setq calendar-location-name "Berwick-upon-Tweed")
+
+(use-package org
+ :init
+ (add-to-list 'org-modules 'org-habit)
+ :bind (("C-c l" . 'org-store-link)
+ ("C-c a" . 'org-agenda)
+ ("C-c b" . 'org-iswitchb)
+ ("C-c c" . 'org-capture))
+ :config
+ (setq org-src-tab-acts-natively t)
+ (setq org-directory "~/org/")
+ (setq org-highest-priority ?A)
+ (setq org-default-priority ?C)
+ (setq org-lowest-priority ?E)
+ (setq org-priority-faces
+ '((?A . (:foreground "#CC0000" :background "#FFE3E3"))
+ (?B . (:foreground "#64992C" :background "#EBF4DD"))
+ (?C . (:foreground "#64992C" :background "#FFFFFF"))))
+ (setq org-ellipsis "...")
+ (setq org-startup-indented nil)
+ (setq org-hide-leading-stars nil)
+ (setq org-log-into-drawer t)
+ (setq org-deadline-warning-days 4)
+ (setq org-clock-persist 'history)
+ (org-clock-persistence-insinuate)
+ (setq org-default-notes-file (concat org-directory "/notes.org"))
+ (setq org-M-RET-may-split-line '(default . nil))
+ (setq org-enforce-todo-dependencies t)
+ (setq org-log-done 'time)
+ (setq org-log-done-with-time 'note)
+ (setq diary-file "~/org/diary")
+ (setq org-reverse-note-order t)
+ (setq +org-habit-min-width 45)
+ (setq org-habit-show-habits t)
+ (setq org-habit-show-habits-only-for-today nil)
+ (setq org-columns-default-format "%50ITEM(Task) %10CLOCKSUM %25TIMESTAMP_IA")
+ (setq org-archive-location "~/org/archive.org::* From %s")
+ (setq org-refile-targets (quote ((nil :maxlevel . 9)
+ (org-agenda-files :maxlevel . 9))))
+
+(setq org-agenda-span 'day)
+(setq org-agenda-start-day "today")
+(setq org-agenda-files (quote ("~/org/home.org"
+ "~/org/projects.org"
+ "~/org/refile.org"
+ "~/org/mod.org"
+ "~/org/notes.org"
+ "~/org/habits.org")))
+(setq org-agenda-window-setup 'current-window)
+(setq org-agenda-start-with-log-mode t)
+(setq org-agenda-include-diary nil)
+(setq org-agenda-diary-file "~/org/calendar/cal.org")
+(setq org-agenda-show-future-repeats t)
+(setq org-agenda-skip-deadline-if-done t)
+(setq org-agenda-skip-scheduled-if-done t)
+(setq org-agenda-sort-notime-is-late nil)
+
+(setq org-agenda-custom-commands
+ '(
+ ("w" "Work"
+ (
+ (agenda)
+ (tags "TODO=\"DOING\"|REFILE+LEVEL=2|current|PRIORITY=\"A\"" ((org-agenda-overriding-header "DEAL")))
+ (tags-todo "TODO=\"WAITING\"" ((org-agenda-overriding-header "MOD WAITING")
+ (org-agenda-sorting-strategy '(deadline-down scheduled-down priority-down))))
+ (tags-todo "-SCHEDULED>=\"<today>\"&TODO=\"NEXT\""
+ ((org-agenda-overriding-header "MOD NEXT UNSCHEDULED")
+ (org-agenda-sorting-strategy '(deadline-up priority-down))))
+ (tags-todo "TODO=\"PROJ\"" ((org-agenda-overriding-header "Projects")))
+ (tags-todo "TODO=\"NEXT\"" ((org-agenda-overriding-header "All Next Actions")
+ (org-agenda-sorting-strategy '(deadline-up scheduled-down priority-down))))
+ (tags-todo "TODO=\"TODO\"" ((org-agenda-overriding-header "TODO")
+ (org-agenda-sorting-strategy '(deadline-up)))))
+ ((org-agenda-category-filter-preset '("+MOD" "+Proj/Task" "+Meeting" "+WorkTrip" "+refile"))))
+
+ ("h" "Home"
+ (
+ (agenda)
+ (tags "TODO=\"DOING\"|REFILE+LEVEL=2|current|PRIORITY=\"A\"" ((org-agenda-overriding-header "DEAL")))
+ (tags-todo "TODO=\"WAITING\"" ((org-agenda-overriding-header "Home WAITING")
+ (org-agenda-sorting-strategy '(deadline-down scheduled-down priority-down))))
+ (tags-todo "-SCHEDULED>=\"<today>\"&TODO=\"NEXT\""
+ ((org-agenda-overriding-header "Home NEXT UNSCHEDULED")
+ (org-agenda-sorting-strategy '(deadline-down scheduled-down priority-down))))
+ (tags-todo "TODO=\"PROJ\"" ((org-agenda-overriding-header "Projects")))
+ (tags-todo "TODO=\"NEXT\"" ((org-agenda-overriding-header "All Next Actions")
+ (org-agenda-sorting-strategy '(deadline-down scheduled-down priority-down))))
+ (tags-todo "TODO=\"TODO\"" ((org-agenda-overriding-header "TODO"))))
+ ((org-agenda-category-filter-preset '("+home" "+habits" "+refile"))))
+ ("i" tags "idea")
+ ("r" tags "LEVEL=2+REFILE" ((org-agenda-overriding-header "Stuff to refile")))))
+
+(setq org-capture-templates
+ (quote (("i" "Inbox" entry (file+headline "~/org/refile.org" "Inbox")
+ "* %?\nCaptured: %U\n")
+ ("h" "Home Tasks & Notes")
+ ;; ("w" "Protocol Capture" entry (file+headline "~/org/refile.org" "Web Capture")
+ ;; "* %^{Title or Comment}\nDescription: %:description\nSource: %:link\n%:initial\nCaptured: %U\n")
+ ("x" "Protocol Capture" entry (file+headline "~/org/refile.org" "Web Capture")
+ "* TODO Review %:description\nSource: %:link\n%:initial\nCaptured: %U\n" :immediate-finish t)
+ ("w" "Protocol Capture" entry (file+headline "~/org/refile.org" "Web Capture")
+ "* %:description\nSource: %:link\n%:initial\nCaptured: %U\n")
+ ("ht" "Home TODO" entry (file+headline "~/org/home.org" "Tasks")
+ "** TODO %?\nEntered on %U\n"
+ :prepend t)
+ ("hn" "Home NEXT" entry (file+headline "~/org/home.org" "Tasks")
+ "** NEXT %?\nEntered on %U\n"
+ :prepend t)
+ ("hS" "Home Someday" entry (file+headline "~/org/home.org" "Someday")
+ "** SOMEDAY %?\nEntered on %U\n")
+ ;; ("hN" "Home Note" entry (file+headline "~/org/home.org" "Notes")
+ ;; "** %?\nEntered on %U\n")
+ ;; ("hj" "Journal" entry (file+olp+datetree "~/org/home.org" "Journal")
+ ;; "* %?\nEntered on %U\n")
+ ("hi" "Home Idea" entry (file+headline "~/org/home.org" "Notes")
+ "** %? :idea:\nEntered on %U\n")
+ ("hs" "Home Calendar - Single" entry (file+headline "~/org/home.org" "Calendar")
+ "* %?\n%^T")
+ ("hb" "Home Calendar - Block" entry (file+headline "~/org/home.org" "Calendar")
+ "* %?\n%^t--%^t")
+ ("w" "Work Tasks & Notes")
+ ("wt" "Work TODO" entry (file+headline "~/org/mod.org" "Tasks")
+ "** TODO %?\nEntered on %U\n"
+ :prepend t)
+ ("wn" "Work NEXT" entry (file+headline "~/org/mod.org" "Tasks")
+ "** NEXT %?\nEntered on %U\n"
+ :prepend t)
+ ("wS" "Work Someday" entry (file+headline "~/org/mod.org" "Someday")
+ "** SOMEDAY %?\nEntered on %U\n")
+ ("wN" "Note" entry (file+headline "~/org/mod.org" "Notes")
+ "* %?\nEntered on %U\n")
+ ("wc" "Note from Clipboard" entry (file+headline "~/org/mod.org" "Notes")
+ "* %?\n\t\n%c")
+ ("wr" "Note from Region" entry (file+headline "~/org/mod.org" "Notes")
+ "* %?\n\t\n%i")
+ ("wj" "Journal" entry (file+olp+datetree "~/org/mod.org" "Journal")
+ "* %?\nEntered on %U\n")
+ ("wd" "Retrospective Tasks" entry (file+headline "~/org/mod.org" "Tasks")
+ "* DONE %?\nCLOSED: %U")
+ ("ws" "Work Calendar - Single" entry (file+headline "~/org/mod.org" "Calendar")
+ "* %?\n%^T")
+ ("wb" "Work Calendar - Block" entry (file+headline "~/org/mod.org" "Calendar")
+ "* %?\n%^t--%^t")
+ ("wp" "Work Calendar - Trip" entry (file+headline "~/org/mod.org" "Work Trips")
+ "* %?\n%^t--%^t")
+ ("wm" "Work Calendar - Meeting" entry (file+headline "~/org/mod.org" "Meetings")
+ "* %?\n:PROPERTIES:\n:CATEGORY: Meeting\n:END:\n%^T")
+ ("e" "Emacs Tip")
+ ("et" "Emacs Tip" entry (file+headline "~/org/emacs-tips.org" "Emacs Tips")
+ "* %?\n\t%a")
+ ("er" "Emacs Tip from Region" entry (file+headline "~/org/emacs-tips.org" "Emacs Tips")
+ "* %?\n\t%i"))))
+
+(setq org-tag-alist '(
+ ;; Type
+ ("brainstorm" . ?b)
+ ("idea" . ?d)
+ ;; Context
+ ("work" . ?w)
+ ("home" . ?h)
+ ("errand" . ?e)
+ ("emacs" . ?E)
+ ("orgmode" . ?o)
+ ("joanna" . ?j)
+ ("harvey" . ?h)
+ ("sophie" . ?s)))
+
+(defun open-agenda ()
+ "Open the org-agenda."
+ (interactive)
+ (let ((agenda "*Org Agenda*"))
+ (if (equal (get-buffer agenda) nil)
+ (org-agenda-list)
+ (unless (equal (buffer-name (current-buffer)) agenda)
+ (switch-to-buffer agenda))
+ (org-agenda-redo t)
+ (beginning-of-buffer))))
+
+(setq org-stuck-projects
+ '("+LEVEL=2/+PROJ" ("NEXT" "DOING") nil ""))
+
+(setq org-todo-keywords
+ (quote ((sequence "TODO(t)" "NEXT(n)" "DOING(D)" "PROJ(p)" "|" "DONE(d!)")
+ (sequence "WAITING(w@/!)" "SOMEDAY(s@/!)" "HOLD(h@/!)" "|" "CANCELLED(c@/!)"))))
+
+
+(setq org-todo-keyword-faces
+ (quote (("TODO" :foreground "tomato4" :weight bold)
+ ("NEXT" :foreground "turquoise4" :weight bold)
+ ("PROJ" :foreground "DarkViolet" :weight bold)
+ ("DOING" :foreground "brown" :weight bold)
+ ("DONE" :foreground "forest green" :weight bold)
+ ("WAITING" :foreground "orange" :weight bold)
+ ("SOMEDAY" :foreground "blue" :weight bold)
+ ("HOLD" :foreground "magenta" :weight bold)
+ ("CANCELLED" :foreground "snow4" :weight bold))))
+
+(setq org-todo-state-tags-triggers
+ (quote (("CANCELLED" ("CANCELLED" . t))
+ ("WAITING" ("WAITING" . t))
+ ("HOLD" ("WAITING") ("HOLD" . t))
+ (done ("WAITING") ("HOLD"))
+ ("TODO" ("WAITING") ("CANCELLED") ("HOLD"))
+ ("NEXT" ("WAITING") ("CANCELLED") ("HOLD"))
+ ("DONE" ("WAITING") ("CANCELLED") ("HOLD"))))))
+
+
(custom-set-variables
;; custom-set-variables was added by Custom.
;; If you edit it by hand, you could mess it up, so be careful.
@@ -29,7 +821,7 @@
'(company-show-quick-access t nil nil "Customized with use-package company")
'(custom-safe-themes
'("3d2e532b010eeb2f5e09c79f0b3a277bfc268ca91a59cdda7ffd056b868a03bc" default))
- '(display-line-numbers-type 'relative)
+ '(display-line-numbers-type 'relative t)
'(display-time-mode t)
'(package-selected-packages
'(unicode-fonts deft cider org-roam org yasnippet-snippets which-key vterm use-package rainbow-delimiters pdf-tools paredit notmuch magit ledger-mode gruvbox-theme flycheck expand-region evil elpy elfeed-score diminish counsel cmake-mode browse-kill-ring beacon auto-package-update amx ace-window ace-jump-mode))
diff --git a/myinit.org b/myinit.org
deleted file mode 100644
index 888f4ce..0000000
--- a/myinit.org
+++ /dev/null
@@ -1,921 +0,0 @@
-#+BEGIN_SRC emacs-lisp
- ;; -*- lexical-binding: t; -*-
-
- ;; yulqen's Emacs Configuration
-
- ;; Copyright (C) yulqen
-#+END_SRC
-* Startup
-** Early Init
-#+BEGIN_SRC emacs-lisp
- ;; -*- lexical-binding: t; -*-
-
- ;; Garbage collection
- (setq gc-cons-percentage 0.6)
-
- ;; MISC optimizations
- (setq idle-update-delay 1.0)
- (setq-default bidi-display-reordering 'left-to-right
- bidi-paragraph-direction 'left-to-right)
- (setq-default cursor-in-non-selected-windows nil)
- (setq hightlight-nonselected-windows nil)
- (setq fast-but-imprecise-scrolling t)
- (setq inhibit-compacting-font-caches t)
- (menu-bar-mode 1)
-#+END_SRC
-#+begin_src emacs-lisp
- (add-hook 'org-mode-hook 'visual-line-mode)
-#+end_src
-#+begin_src emacs-lisp
- ;; turn off flycheck-mode
- (add-hook 'org-mode-hook (lambda () flycheck-mode -1))
-#+end_src
-
-* Fundamentals
-#+BEGIN_SRC emacs-lisp
-
- (setq user-full-name "Matthew Lemon"
- user-mail-address "matt@matthewlemon.com")
-
- (defun establish-machine ()
- (let ((sys (system-name)))
- (if (string= sys "archdesk")
- (setq mrl/computer 'desktop)
- (setq mrl/computer 'laptop))))
-
- (establish-machine)
-
- ;; handier undo
- (global-unset-key "\C-z")
- (global-set-key "\C-z" 'advertised-undo)
-
- (setq inhibit-startup-message 1)
- (scroll-bar-mode -1)
- (tool-bar-mode -1)
- (tooltip-mode -1)
- (set-fringe-mode 10)
-
- (put 'narrow-to-defun 'disabled nil)
- (put 'narrow-to-page 'disabled nil)
- (put 'narrow-to-region 'disabled nil)
-
- ;; we don't want the old buffer list!
- (global-unset-key (kbd "C-x C-b"))
-
- ;; Put backups in /tmp where they belong
- (setq backup-directory-alist
- `((".*" . ,temporary-file-directory)))
- (setq auto-save-file-name-transforms
- `((".*" ,temporary-file-directory t)))
-
- ;; recursively copy by default
- (setq dired-recursive-copies 'always)
-
- ;; y or n instead of yes or no
- (fset 'yes-or-no-p 'y-or-n-p)
-
- ;; auto revert files
- (global-auto-revert-mode t)
-
- ;; BACKUPS/LOCKFILES --------
- ;; Don't generate backups or lockfiles.
- (setq create-lockfiles nil
- make-backup-files nil
- ;; But in case the user does enable it, some sensible defaults:
- version-control t ; number each backup file
- backup-by-copying t ; instead of renaming current file (clobbers links)
- delete-old-versions t ; clean up after itself
- kept-old-versions 5
- kept-new-versions 5
- backup-directory-alist (list (cons "." (concat user-emacs-directory "backup/"))))
-
- ;; Display the current time
- (display-time-mode t)
-
- (setq visible-bell t)
-
- ;; font
- (cond
- ((string-equal (system-name) "archdesk")
- (when (member "Hack" (font-family-list))
- (add-to-list 'default-frame-alist '(font . "Hack-14"))))
- ((string-equal (system-name) "pop_os")
- (when (member "Hack" (font-family-list))
- (add-to-list 'default-frame-alist '(font . "Hack-10")))))
-
- (use-package gruber-darker-theme
- :ensure t
- :config
- (load-theme 'gruber-darker t))
-
- (setq display-line-numbers-type `relative)
- (setq undo-limit 8000000) ; raise limit to 80Mb
- (setq truncate-string-ellipsis "…") ; better than using dots
- (setq scroll-preserve-screen-position 'always) ; experimental
- (setq scroll-margin 3) ; bit of space
-
-
- ;; calendar proper Monday start
- (setq calendar-week-start-day 1)
- (setq calendar-date-style (quote european))
-
- ;; Handling tabs (for programming)
- (setq-default tab-width 2)
- (setq-default tab-width 2 indent-tabs-mode nil)
- (setq-default indent-tabs-mode nil)
- (setq js-indent-level 2)
- (setq python-indent 2)
- (setq css-indent-offset 2)
- (add-hook 'sh-mode-hook
- (lambda ()
- (setq sh-basic-offset 2
- sh-indentation 2)))
- (setq web-mode-markup-indent-offset 2)
-
- ;; Highlight matching parens
- (show-paren-mode t)
-
- ;; Stop C-z suspending emacs
- (global-set-key (kbd "C-z") 'nil)
-
- ;; encoding
- (prefer-coding-system 'utf-8)
- (setq coding-system-for-read 'utf-8)
- (setq coding-system-for-write 'utf-8)
-#+END_SRC
-* Packages
-** yasnippet
-#+BEGIN_SRC emacs-lisp
-;; Yasnippet
-(use-package yasnippet
-:diminish yas-minor-mode
- :hook ((prog-mode LaTeX-mode org-mode) . yas-minor-mode)
- :bind
- (:map yas-minor-mode-map ("C-c C-n" . yas-expand-from-trigger-key))
- (:map yas-keymap
- (("TAB" . smarter-yas-expand-next-field)
- ([(tab)] . smarter-yas-expand-next-field)))
- :config
- (use-package yasnippet-snippets)
- (yas-reload-all)
- (defun smarter-yas-expand-next-field ()
- "Try to `yas-expand' then `yas-next-field' at current cursor position."
- (interactive)
- (let ((old-point (point))
- (old-tick (buffer-chars-modified-tick)))
- (yas-expand)
- (when (and (eq old-point (point))
- (eq old-tick (buffer-chars-modified-tick)))
- (ignore-errors (yas-next-field))))))
-#+END_SRC
-** company
-
-#+BEGIN_SRC emacs-lisp
-;; this config works better with yasnippet
-(use-package company
- :diminish company-mode
- :hook ((prog-mode LaTeX-mode latex-mode ess-r-mode ledger-mode) . company-mode)
- :bind
- (:map company-active-map
- ([tab] . smarter-yas-expand-next-field-complete)
- ("TAB" . smarter-yas-expand-next-field-complete))
- :custom
- (company-tooltip-align-annotations t)
- (company-begin-commands '(self-insert-command))
- (company-require-match 'never)
- ;; Don't use company in the following modes
- (company-global-modes '(not shell-mode eaf-mode))
- ;; Trigger completion immediately.
- (company-idle-delay 0.1)
- ;; Number the candidates (use M-1, M-2 etc to select completions).
- (company-show-numbers t)
- :config
- ;; clangd variable not present which was a problem
-;; (unless *clangd* (delete 'company-clang company-backends))
-;; (global-company-mode 1)
- (setq company-idle-delay 0)
- (setq company-minimum-prefix-length 3)
- (defun smarter-yas-expand-next-field-complete ()
- "Try to `yas-expand' and `yas-next-field' at current cursor position.
-
-If failed try to complete the common part with `company-complete-common'"
- (interactive)
- (if yas-minor-mode
- (let ((old-point (point))
- (old-tick (buffer-chars-modified-tick)))
- (yas-expand)
- (when (and (eq old-point (point))
- (eq old-tick (buffer-chars-modified-tick)))
- (ignore-errors (yas-next-field))
- (when (and (eq old-point (point))
- (eq old-tick (buffer-chars-modified-tick)))
- (company-complete-common))))
- (company-complete-common))))
-#+END_SRC
-** deft
-#+begin_src emacs-lisp
- (use-package deft
- :ensure t
- :config
- (defun mrl/kill-deft ()
- (kill-buffer "*Deft*"))
- (setq deft-directory "~/org-roam"
- deft-extensions '("org" "md" "txt")
- deft-recursive t
- deft-file-limit 40
- deft-use-filename-as-title t)
- (add-hook 'deft-open-file-hook 'mrl/kill-deft))
-#+end_src
-** ace-jump
-#+BEGIN_SRC emacs-lisp
- ;; Ace Jump
- (use-package ace-jump-mode
- :bind ("C-M-SPC" . ace-jump-mode))
-#+END_SRC
-** paredit
-#+BEGIN_SRC emacs-lisp
- ;; Lisp programming
- (use-package paredit
- :init
- (add-hook 'clojure-mode-hook #'enable-paredit-mode)
- (add-hook 'cider-repl-mode-hook #'enable-paredit-mode)
- (add-hook 'emacs-lisp-mode-hook #'enable-paredit-mode)
- (add-hook 'eval-expression-minibuffer-setup-hook #'enable-paredit-mode)
- (add-hook 'ielm-mode-hook #'enable-paredit-mode)
- (add-hook 'lisp-mode-hook #'enable-paredit-mode)
- (add-hook 'lisp-interaction-mode-hook #'enable-paredit-mode)
- (add-hook 'scheme-mode-hook #'enable-paredit-mode)
- :config
- (show-paren-mode t)
- :bind (("M-[" . paredit-wrap-square)
- ("M-{" . paredit-wrap-curly))
- :diminish nil)
-#+END_SRC
-** rainbow-delimiters
-#+BEGIN_SRC emacs-lisp
- (use-package rainbow-delimiters
- :config
- (add-hook 'prog-mode-hook 'rainbow-delimiters-mode))
-#+END_SRC
-** evil
-#+BEGIN_SRC emacs-lisp
- ;; EVIL
- (use-package evil
- :init
- :config
- (setq evil-respect-visual-line-mode t)
- (setq evil-default-state 'emacs)
- (evil-mode 0))
-#+END_SRC
-** which-key
-#+BEGIN_SRC emacs-lisp
- ;; which-key
- (use-package which-key
- :config
- (which-key-mode))
-#+END_SRC
-** elfeed
-#+BEGIN_SRC emacs-lisp
-(use-package elfeed
- :config
- (setq elfeed-feeds
- '(("http://feeds.bbci.co.uk/news/rss.xml?edition=uk" news)
- ("http://feeds.bbci.co.uk/news/technology/rss.xml" tech news)
- ("https://planet.emacslife.com/atom.xml" emacs)
- ("https://irreal.org/blog/?feed=rss2" emacs)
- ("https://karl-voit.at/feeds/lazyblorg-all.atom_1.0.links-only.xml" emacs)
- ("https://dominiccummings.com/rss.xml" blog tech)
- ("https://usesthis.com/feed.atom" tech blog)
- ("https://plaintextproject.online/feed.xml" plaintext productivity)
- ("https://feeds.feedburner.com/StudyHacks" productivity)
- ("http://newsrss.bbc.co.uk/rss/sportonline_uk_edition/rugby_union/rss.xml" rugby)
- ("http://feeds.bbci.co.uk/news/video_and_audio/politics/rss.xml" news)
- ("https://feeds.feedburner.com/arstechnica/open-source" opensource)
- ("https://www.computerweekly.com/rss/IT-security.xml" cyber)
- ("http://tonsky.me/blog/atom.xml" blog)
- ("https://akkshaya.blog/feed" blob)
- ("https://miguelmota.com/index.xml" blog)
- ("https://www.computerweekly.com/rss/IT-security.xml" security)
- ("https://www.fsf.org/static/fsforg/rss/news.xml" opensource)
- ("https://www.reddit.com/r/emacs.rss" emacs)
- ("https://www.reddit.com/r/rugbyunion/.rss" rugby)
- ("http://pragmaticemacs.com/feed/" emacs)
- ("https://200ok.ch/atom.xml" emacs)
- ("http://www.linuxinsider.com/perl/syndication/rssfull.pl" linux)
- ("http://planet.debian.org/rss20.xml" debian linux)
- ("http://feeds2.feedburner.com/Command-line-fu" linux)
- ("https://opensource.org/news.xml" opensource)
- ("https://www.wired.com/feed/rss" news tech)
- ("https://sivers.org/en.atom" blog))))
-#+END_SRC
-#+BEGIN_SRC emacs-lisp
-;; get scoring in elfeed
-(use-package elfeed-score
- :ensure t
- :config
- (progn
- (elfeed-score-enable)
- (define-key elfeed-search-mode-map "=" elfeed-score-map)))
-#+END_SRC
-** magit
-#+BEGIN_SRC emacs-lisp
-;; Basic magit
-(use-package magit
- :bind ("C-x g" . magit-status))
-#+END_SRC
-** clojure
-#+begin_src emacs-lisp
- (use-package cider
- :ensure t)
-#+end_src
-** ido
-#+BEGIN_SRC emacs-lisp
- ;; Interactively Do Things (ido)
- (use-package ido
- :config
- (ido-mode t)
- (ido-everywhere t)
- (setq ido-enable-flex-matching t)
- (setq ido-create-new-buffer 'always)
- (setq ido-everywhere t)
- (setq ido-file-extensions-order '(".org" ".txt" ".py" ".emacs" ".md" ".xml" ".el" ".ini"))
- (setq ido-enable-flex-matching t))
-#+END_SRC
-** helm (disbaled)
-#+BEGIN_SRC emacs-lisp
-;; ;; helm
-;; (require 'helm-config)
-;; (global-set-key (kbd "M-x") #'helm-M-x)
-;; (global-set-key (kbd "C-x r b") #'helm-filtered-bookmarks)
-;; (global-set-key (kbd "C-x C-f") #'helm-find-files)
-;; ;; The default "C-x c" is quite close to "C-x C-c", which quits Emacs.
-;; ;; Changed to "C-c h". Note: We must set "C-c h" globally, because we
-;; ;; cannot change `helm-command-prefix-key' once `helm-config' is loaded.
-;; (global-set-key (kbd "C-c h") 'helm-command-prefix)
-;; (global-unset-key (kbd "C-x c"))
-;; (helm-mode 1)
-#+END_SRC
-** ledger
-#+BEGIN_SRC emacs-lisp
- ;; ledger mode
- (use-package ledger-mode
- :ensure t
- :mode ("\\.ledger\\'")
- :config
- ;; (setq ledger-default-date-format "%d/%m/%Y")
- (setq ledger-reports
- '(("hsbc_current_account" "ledger [[ledger-mode-flags]] --date-format \"%d/%m/%Y\" -f /home/lemon/Documents/Budget/ledger/2021/budget2021.ledger reg Assets\\:HSBC\\:Current")
- ("bal" "%(binary) -f %(ledger-file) bal")
- ("reg" "%(binary) -f %(ledger-file) reg")
- ("payee" "%(binary) -f %(ledger-file) reg @%(payee)")
- ("account" "%(binary) -f %(ledger-file) reg %(account)")))
- (add-hook 'ledger-mode-hook
- (lambda ()
- (setq-local tab-always-indent 'complete)
- (setq-local completion-cycle-threshold t)
- (setq-local ledger-complete-in-steps t)))
- :custom (ledger-clear-whole-transactions t))
-#+END_SRC
-** ivy (disabled)
-#+BEGIN_SRC emacs-lisp
-;; (use-package ivy
-;; :bind (("C-s" . swiper)
-;; :map ivy-minibuffer-map
-;; ("TAB" . ivy-alt-done)
-;; ("C-l" . ivy-alt-done)
-;; ("C-j" . ivy-next-line)
-;; ("C-k" . ivy-previous-line)
-;; :map ivy-switch-buffer-map
-;; ("C-k" . ivy-previous-line)
-;; ("C-l" . ivy-done)
-;; ("C-d" . ivy-switch-buffer-kill)
-;; :map ivy-reverse-i-search-map
-;; ("C-k" . ivy-previous-line)
-;; ("C-d" . ivy-reverse-i-search-kill))
-;; :config
-;; (ivy-mode 1))
-#+END_SRC
-** ivy (active)
-#+BEGIN_SRC emacs-lisp
- (use-package ivy
- :diminish
- :init
- (use-package amx :defer t)
- (use-package counsel :diminish :config (counsel-mode 1))
- (use-package swiper :defer t)
- (ivy-mode 1)
- :bind
- (("C-s" . swiper-isearch)
- ("C-x C-f" . counsel-find-file)
- ("C-x C-m" . counsel-M-x)
- ("C-h f" . counsel-describe-function)
- ("C-h v" . counsel-describe-variable)
- ("C-z s" . counsel-rg)
- ("C-x C-r" . counsel-recentf)
- ("C-z b" . counsel-buffer-or-recentf)
- ("C-z C-b" . counsel-ibuffer)
- (:map ivy-minibuffer-map
- ("C-r" . ivy-previous-line-or-history)
- ("M-RET" . ivy-immediate-done))
- (:map counsel-find-file-map
- ("C-~" . counsel-goto-local-home)))
- :custom
- (ivy-use-virtual-buffers t)
- (ivy-height 13)
- (ivy-on-del-error-function nil)
- (ivy-magic-slash-non-match-action 'ivy-magic-slash-non-match-create)
- (ivy-count-format "【%d/%d】")
- (ivy-wrap t)
- :config
- (setq projectile-completion-system 'ivy)
- (defun counsel-goto-local-home ()
- "Go to the $HOME of the local machine."
- (interactive)
- (ivy--cd "~/")))
-#+END_SRC
-** beacon
-#+BEGIN_SRC emacs-lisp
-;; beacon mode
-(use-package beacon
- :config
- (setq beacon-color "OrangeRed")
- (beacon-mode 1))
-#+END_SRC
-** flycheck
-#+BEGIN_SRC emacs-lisp
-;; flycheck syntax highlighting
-(use-package flycheck
- :ensure t
- :init (global-flycheck-mode))
-
-;; turn off flycheck-mode for org
-(setq flycheck-global-modes '(not org-mode))
-#+END_SRC
-** pdf-tools
-#+BEGIN_SRC emacs-lisp
-;; install pdf-tools
-(use-package pdf-tools)
-(pdf-tools-install)
-#+END_SRC
-** dired
-#+BEGIN_SRC emacs-lisp
-;; dired
-(use-package dired
- :ensure nil
- :bind
- (("C-x C-j" . dired-jump)
- ("C-x j" . dired-jump-other-window))
- :custom
- ;; Always delete and copy recursively
- (dired-recursive-deletes 'always)
- (dired-recursive-copies 'always)
- ;; Auto refresh Dired, but be quiet about it
- (global-auto-revert-non-file-buffers t)
- (auto-revert-verbose nil)
- ;; Quickly copy/move file in Dired
- (dired-dwim-target t)
- ;; Move files to trash when deleting
- (delete-by-moving-to-trash t)
- :config
- ;; Reuse same dired buffer, to prevent numerous buffers while navigating in dired
- (put 'dired-find-alternate-file 'disabled nil)
- :hook
- (dired-mode . (lambda ()
- (local-set-key (kbd "<mouse-2>") #'dired-find-alternate-file)
- (local-set-key (kbd "RET") #'dired-find-alternate-file)
- (local-set-key (kbd "^")
- (lambda () (interactive) (find-alternate-file ".."))))))
-
-;; dired config
-;; human readable
-(setq-default dired-listing-switches "-alh")
-;; Ability to use a to visit a new directory or file in dired instead of using RET. RET works just fine,
-;; but it will create a new buffer for every interaction whereas a reuses the current buffer.
-(put 'dired-find-alternate-file 'disabled nil)
-(setq dired-recursive-copies 'always)
-#+END_SRC
-** auto-package-update
-#+BEGIN_SRC emacs-lisp
-;; auto-package-update
-(use-package auto-package-update
- :if (not (daemonp))
- :custom
- (auto-package-update-interval 7) ;; in days
- (auto-package-update-prompt-before-update t)
- (auto-package-update-delete-old-versions t)
- (auto-package-update-hide-results t)
- :config
- (auto-package-update-maybe))
-#+END_SRC
-** diminish
-#+BEGIN_SRC emacs-lisp
-;; remove certain minor modes from the mode line
-(use-package diminish)
-#+END_SRC
-** winner
-#+BEGIN_SRC emacs-lisp
-;; Windmove - use Shift and arrow keys to move in windows
-;; this fucks around with org mode - we want to shift timestamps and stuff
-;;(when (fboundp 'windmove-default-keybindings)
-;; (windmove-default-keybindings))
-
-;; Winner mode - undo and redo changes in window config
-;; with C-c left and C-c right
-(use-package winner
- :ensure nil
- :custom
- (winner-boring-buffers
- '("*Completions*"
- "*Compile-Log*"
- "*inferior-lisp*"
- "*Fuzzy Completions*"
- "*Apropos*"
- "*Help*"
- "*cvs*"
- "*Buffer List*"
- "*Ibuffer*"
- "*esh command on file*"))
- :config
- (winner-mode 1))
-#+END_SRC
-** python (elpy)
-#+BEGIN_SRC emacs-lisp
-;; elpy for python
-(use-package elpy
- :ensure t
- :config
- (setq elpy-modules (delq 'elpy-module-flymake elpy-modules))
- (add-hook 'elpy-mode-hook 'flycheck-mode)
- :init
- (elpy-enable))
-
-(when (load "flycheck" t t)
-(setq elpy-modules (delq 'elpy-module-flymake elpy-modules))
-(add-hook 'elpy-mode-hook 'flycheck-mode))
-#+END_SRC
-** ace-window
-#+BEGIN_SRC emacs-lisp
-;; Ace Window
-(use-package ace-window
- :bind (("C-x o" . ace-window)
- ("M-2" . ace-window))
- :init
- (setq aw-background t
- aw-keys '(?a ?o ?e ?u ?i ?d ?h ?t ?n ?s)))
-#+END_SRC
-** expand-region
-#+BEGIN_SRC emacs-lisp
-;; expand-region
-(use-package expand-region
- :bind (("C-@" . er/expand-region)
- ("C-=" . er/expand-region)
- ("M-3" . er/expand-region)))
-#+END_SRC
-** browse-kill-ring
-#+BEGIN_SRC emacs-lisp
-;; browse-kill-ring
-(use-package browse-kill-ring
- :bind ("C-x C-y" . browse-kill-ring)
- :config
- (setq browse-kill-ring-quit-action 'kill-and-delete-window))
-
-(setq save-interprogram-paste-before-kill t)
-#+END_SRC
-** recentf
-#+BEGIN_SRC emacs-lisp
-;; recentf
-(use-package recentf
-:hook (after-init . recentf-mode)
-:custom
-(recentf-auto-cleanup "05:00am")
-(recentf-exclude '((expand-file-name package-user-dir)
- ".cache"
- ".cask"
- ".elfeed"
- "bookmarks"
- "cache"
- "ido.*"
- "persp-confs"
- "recentf"
- "undo-tree-hist"
- "url"
- "COMMIT_EDITMSG\\'"))
-(setq recentf-auto-cleanup 'never
- recentf-max-saved-items 50
- recentf-save-file (concat user-emacs-directory ".recentf"))
-(setq recentf-max-menu-items 25)
-(setq recentf-max-saved-items 25)
-(recentf-mode t))
-#+END_SRC
-** org-roam
-#+BEGIN_SRC emacs-lisp
- (use-package org-roam
- :ensure t
- :custom
- (org-roam-dailies-directory "daily/")
- (org-roam-directory "~/org-roam")
- (org-roam-capture-ref-templates
- '(("d" "default" plain
- "%?"
- :target (file+head "%<%Y%m%d%H%M%S>-${slug}.org" "#+title: ${title}\n")
- :unnarrowed t)))
- (org-roam-capture-templates
- '(("d" "default" plain
- "%?"
- :target (file+head "%<%Y%m%d%H%M%S>-${slug}.org" "#+title: ${title}\n")
- :unnarrowed t)
- ("e" "encrypted" plain
- "%?"
- :target (file+head "%<%Y%m%d%H%M%S>-${slug}.org.gpg" "#+title: ${title}\n")
- :unnarrowed t)))
- (org-roam-dailies-capture-templates
- '(("d" "default" entry "* %<%T>: %?"
- :target (file+head "%<%Y-%m-%d>.org" "#+title: %<%Y-%m-%d>\n")
- :unnarrowed t)))
- :bind (("C-c n l" . org-roam-buffer-toggle)
- ("C-c n f" . org-roam-node-find)
- ("C-c n i" . org-roam-node-insert)
- ("C-c n n" . org-roam-dailies-capture-today)
- ("C-c n t" . org-roam-dailies-goto-today)
- :map org-roam-mode-map
- ("y" . org-roam-dailies-goto-previous-note)
- ("t" . org-roam-dailies-goto-next-note)
- ("d" . org-roam-dailies-goto-date)
- ("D" . org-roam-dailies-capture-date))
- :bind-keymap ("C-c n D" . org-roam-mode-map)
- :config
- (require 'org-roam-protocol)
- (org-roam-db-autosync-mode)
- ;; Bind this to C-c n I
- (defun org-roam-node-insert-immediate (arg &rest args)
- (interactive "P")
- (let ((args (cons arg args))
- (org-roam-capture-templates (list (append (car org-roam-capture-templates)
- '(:immediate-finish t)))))
- (apply #'org-roam-node-insert args)))
- :bind (("C-c n I" . org-roam-node-insert-immediate)))
-#+END_SRC
-** unicode fonts
-#+begin_src emacs-lisp
- (use-package unicode-fonts
- :ensure t
- :config
- (unicode-fonts-setup))
-#+end_src
-* Keybindings
-** movement
-#+begin_src emacs-lisp
-;; some core bindings
-;; Use iBuffer instead of Buffer List
-;;(global-set-key (kbd "C-x C-b") #'ibuffer)
-;; Truncate lines
-(global-set-key (kbd "C-x C-l") #'toggle-truncate-lines)
-;; Adjust font size like web browsers
-(global-set-key (kbd "C-+") #'text-scale-increase)
-(global-set-key (kbd "C--") #'text-scale-decrease)
-;; Move up/down paragraph
-(global-set-key (kbd "M-n") #'forward-paragraph)
-(global-set-key (kbd "M-p") #'backward-paragraph)
-#+end_src
-* My functions
-#+BEGIN_SRC emacs-lisp
-;; kill other buffers
-(defun kill-other-buffers ()
- "Kill all other buffers."
- (interactive)
- (mapc 'kill-buffer (delq (current-buffer) (buffer-list))))
-#+END_SRC
-* org-mode
-** sunrise and sunset
-#+BEGIN_SRC emacs-lisp
-(setq calendar-latitude 55.77)
-(setq calendar-longitude -2.01)
-(setq calendar-location-name "Berwick-upon-Tweed")
-#+END_SRC
-** org main config
-#+BEGIN_SRC emacs-lisp
- (use-package org
- :init
- (add-to-list 'org-modules 'org-habit)
- :bind (("C-c l" . 'org-store-link)
- ("C-c a" . 'org-agenda)
- ("C-c b" . 'org-iswitchb)
- ("C-c c" . 'org-capture))
- :config
- (setq org-src-tab-acts-natively t)
- (setq org-directory "~/org/")
- (setq org-highest-priority ?A)
- (setq org-default-priority ?C)
- (setq org-lowest-priority ?E)
- (setq org-priority-faces
- '((?A . (:foreground "#CC0000" :background "#FFE3E3"))
- (?B . (:foreground "#64992C" :background "#EBF4DD"))
- (?C . (:foreground "#64992C" :background "#FFFFFF"))))
- (setq org-ellipsis "...")
- (setq org-startup-indented nil)
- (setq org-hide-leading-stars nil)
- (setq org-log-into-drawer t)
- (setq org-deadline-warning-days 4)
- (setq org-clock-persist 'history)
- (org-clock-persistence-insinuate)
- (setq org-default-notes-file (concat org-directory "/notes.org"))
- (setq org-M-RET-may-split-line '(default . nil))
- (setq org-enforce-todo-dependencies t)
- (setq org-log-done 'time)
- (setq org-log-done-with-time 'note)
- (setq diary-file "~/org/diary")
- (setq org-reverse-note-order t)
- (setq +org-habit-min-width 45)
- (setq org-habit-show-habits t)
- (setq org-habit-show-habits-only-for-today nil)
- (setq org-columns-default-format "%50ITEM(Task) %10CLOCKSUM %25TIMESTAMP_IA")
- (setq org-archive-location "~/org/archive.org::* From %s")
- (setq org-refile-targets (quote ((nil :maxlevel . 9)
- (org-agenda-files :maxlevel . 9))))
-#+END_SRC
-** org agenda specific
-#+BEGIN_SRC emacs-lisp
- (setq org-agenda-span 'day)
- (setq org-agenda-start-day "today")
- (setq org-agenda-files (quote ("~/org/home.org"
- "~/org/projects.org"
- "~/org/refile.org"
- "~/org/mod.org"
- "~/org/notes.org"
- "~/org/habits.org")))
- (setq org-agenda-window-setup 'current-window)
- (setq org-agenda-start-with-log-mode t)
- (setq org-agenda-include-diary nil)
- (setq org-agenda-diary-file "~/org/calendar/cal.org")
- (setq org-agenda-show-future-repeats t)
- (setq org-agenda-skip-deadline-if-done t)
- (setq org-agenda-skip-scheduled-if-done t)
- (setq org-agenda-sort-notime-is-late nil)
-#+END_SRC
-** org dispatcher
-#+BEGIN_SRC emacs-lisp
- (setq org-agenda-custom-commands
- '(
- ("w" "Work"
- (
- (agenda)
- (tags "TODO=\"DOING\"|REFILE+LEVEL=2|current|PRIORITY=\"A\"" ((org-agenda-overriding-header "DEAL")))
- (tags-todo "TODO=\"WAITING\"" ((org-agenda-overriding-header "MOD WAITING")
- (org-agenda-sorting-strategy '(deadline-down scheduled-down priority-down))))
- (tags-todo "-SCHEDULED>=\"<today>\"&TODO=\"NEXT\""
- ((org-agenda-overriding-header "MOD NEXT UNSCHEDULED")
- (org-agenda-sorting-strategy '(deadline-up priority-down))))
- (tags-todo "TODO=\"PROJ\"" ((org-agenda-overriding-header "Projects")))
- (tags-todo "TODO=\"NEXT\"" ((org-agenda-overriding-header "All Next Actions")
- (org-agenda-sorting-strategy '(deadline-up scheduled-down priority-down))))
- (tags-todo "TODO=\"TODO\"" ((org-agenda-overriding-header "TODO")
- (org-agenda-sorting-strategy '(deadline-up)))))
- ((org-agenda-category-filter-preset '("+MOD" "+Proj/Task" "+Meeting" "+WorkTrip" "+refile"))))
-
- ("h" "Home"
- (
- (agenda)
- (tags "TODO=\"DOING\"|REFILE+LEVEL=2|current|PRIORITY=\"A\"" ((org-agenda-overriding-header "DEAL")))
- (tags-todo "TODO=\"WAITING\"" ((org-agenda-overriding-header "Home WAITING")
- (org-agenda-sorting-strategy '(deadline-down scheduled-down priority-down))))
- (tags-todo "-SCHEDULED>=\"<today>\"&TODO=\"NEXT\""
- ((org-agenda-overriding-header "Home NEXT UNSCHEDULED")
- (org-agenda-sorting-strategy '(deadline-down scheduled-down priority-down))))
- (tags-todo "TODO=\"PROJ\"" ((org-agenda-overriding-header "Projects")))
- (tags-todo "TODO=\"NEXT\"" ((org-agenda-overriding-header "All Next Actions")
- (org-agenda-sorting-strategy '(deadline-down scheduled-down priority-down))))
- (tags-todo "TODO=\"TODO\"" ((org-agenda-overriding-header "TODO"))))
- ((org-agenda-category-filter-preset '("+home" "+habits" "+refile"))))
- ("i" tags "idea")
- ("r" tags "LEVEL=2+REFILE" ((org-agenda-overriding-header "Stuff to refile")))))
-#+END_SRC
-** org capture templates
-#+BEGIN_SRC emacs-lisp
- (setq org-capture-templates
- (quote (("i" "Inbox" entry (file+headline "~/org/refile.org" "Inbox")
- "* %?\nCaptured: %U\n")
- ("h" "Home Tasks & Notes")
- ;; ("w" "Protocol Capture" entry (file+headline "~/org/refile.org" "Web Capture")
- ;; "* %^{Title or Comment}\nDescription: %:description\nSource: %:link\n%:initial\nCaptured: %U\n")
- ("x" "Protocol Capture" entry (file+headline "~/org/refile.org" "Web Capture")
- "* TODO Review %:description\nSource: %:link\n%:initial\nCaptured: %U\n" :immediate-finish t)
- ("w" "Protocol Capture" entry (file+headline "~/org/refile.org" "Web Capture")
- "* %:description\nSource: %:link\n%:initial\nCaptured: %U\n")
- ("ht" "Home TODO" entry (file+headline "~/org/home.org" "Tasks")
- "** TODO %?\nEntered on %U\n"
- :prepend t)
- ("hn" "Home NEXT" entry (file+headline "~/org/home.org" "Tasks")
- "** NEXT %?\nEntered on %U\n"
- :prepend t)
- ("hS" "Home Someday" entry (file+headline "~/org/home.org" "Someday")
- "** SOMEDAY %?\nEntered on %U\n")
- ;; ("hN" "Home Note" entry (file+headline "~/org/home.org" "Notes")
- ;; "** %?\nEntered on %U\n")
- ;; ("hj" "Journal" entry (file+olp+datetree "~/org/home.org" "Journal")
- ;; "* %?\nEntered on %U\n")
- ("hi" "Home Idea" entry (file+headline "~/org/home.org" "Notes")
- "** %? :idea:\nEntered on %U\n")
- ("hs" "Home Calendar - Single" entry (file+headline "~/org/home.org" "Calendar")
- "* %?\n%^T")
- ("hb" "Home Calendar - Block" entry (file+headline "~/org/home.org" "Calendar")
- "* %?\n%^t--%^t")
- ("w" "Work Tasks & Notes")
- ("wt" "Work TODO" entry (file+headline "~/org/mod.org" "Tasks")
- "** TODO %?\nEntered on %U\n"
- :prepend t)
- ("wn" "Work NEXT" entry (file+headline "~/org/mod.org" "Tasks")
- "** NEXT %?\nEntered on %U\n"
- :prepend t)
- ("wS" "Work Someday" entry (file+headline "~/org/mod.org" "Someday")
- "** SOMEDAY %?\nEntered on %U\n")
- ("wN" "Note" entry (file+headline "~/org/mod.org" "Notes")
- "* %?\nEntered on %U\n")
- ("wc" "Note from Clipboard" entry (file+headline "~/org/mod.org" "Notes")
- "* %?\n\t\n%c")
- ("wr" "Note from Region" entry (file+headline "~/org/mod.org" "Notes")
- "* %?\n\t\n%i")
- ("wj" "Journal" entry (file+olp+datetree "~/org/mod.org" "Journal")
- "* %?\nEntered on %U\n")
- ("wd" "Retrospective Tasks" entry (file+headline "~/org/mod.org" "Tasks")
- "* DONE %?\nCLOSED: %U")
- ("ws" "Work Calendar - Single" entry (file+headline "~/org/mod.org" "Calendar")
- "* %?\n%^T")
- ("wb" "Work Calendar - Block" entry (file+headline "~/org/mod.org" "Calendar")
- "* %?\n%^t--%^t")
- ("wp" "Work Calendar - Trip" entry (file+headline "~/org/mod.org" "Work Trips")
- "* %?\n%^t--%^t")
- ("wm" "Work Calendar - Meeting" entry (file+headline "~/org/mod.org" "Meetings")
- "* %?\n:PROPERTIES:\n:CATEGORY: Meeting\n:END:\n%^T")
- ("e" "Emacs Tip")
- ("et" "Emacs Tip" entry (file+headline "~/org/emacs-tips.org" "Emacs Tips")
- "* %?\n\t%a")
- ("er" "Emacs Tip from Region" entry (file+headline "~/org/emacs-tips.org" "Emacs Tips")
- "* %?\n\t%i"))))
-#+END_SRC
-** org tags
-#+BEGIN_SRC emacs-lisp
- (setq org-tag-alist '(
- ;; Type
- ("brainstorm" . ?b)
- ("idea" . ?d)
- ;; Context
- ("work" . ?w)
- ("home" . ?h)
- ("errand" . ?e)
- ("emacs" . ?E)
- ("orgmode" . ?o)
- ("joanna" . ?j)
- ("harvey" . ?h)
- ("sophie" . ?s)))
-#+END_SRC
-** org open agenda full screen
-#+BEGIN_SRC emacs-lisp
- (defun open-agenda ()
- "Open the org-agenda."
- (interactive)
- (let ((agenda "*Org Agenda*"))
- (if (equal (get-buffer agenda) nil)
- (org-agenda-list)
- (unless (equal (buffer-name (current-buffer)) agenda)
- (switch-to-buffer agenda))
- (org-agenda-redo t)
- (beginning-of-buffer))))
-#+END_SRC
-** org stuck projects
-#+BEGIN_SRC emacs-lisp
- (setq org-stuck-projects
- '("+LEVEL=2/+PROJ" ("NEXT" "DOING") nil ""))
-#+END_SRC
-** org keywords
-#+BEGIN_SRC emacs-lisp
- (setq org-todo-keywords
- (quote ((sequence "TODO(t)" "NEXT(n)" "DOING(D)" "PROJ(p)" "|" "DONE(d!)")
- (sequence "WAITING(w@/!)" "SOMEDAY(s@/!)" "HOLD(h@/!)" "|" "CANCELLED(c@/!)"))))
-
-
- (setq org-todo-keyword-faces
- (quote (("TODO" :foreground "tomato4" :weight bold)
- ("NEXT" :foreground "turquoise4" :weight bold)
- ("PROJ" :foreground "DarkViolet" :weight bold)
- ("DOING" :foreground "brown" :weight bold)
- ("DONE" :foreground "forest green" :weight bold)
- ("WAITING" :foreground "orange" :weight bold)
- ("SOMEDAY" :foreground "blue" :weight bold)
- ("HOLD" :foreground "magenta" :weight bold)
- ("CANCELLED" :foreground "snow4" :weight bold))))
-#+END_SRC
-** org todo state triggers
-#+BEGIN_SRC emacs-lisp
- (setq org-todo-state-tags-triggers
- (quote (("CANCELLED" ("CANCELLED" . t))
- ("WAITING" ("WAITING" . t))
- ("HOLD" ("WAITING") ("HOLD" . t))
- (done ("WAITING") ("HOLD"))
- ("TODO" ("WAITING") ("CANCELLED") ("HOLD"))
- ("NEXT" ("WAITING") ("CANCELLED") ("HOLD"))
- ("DONE" ("WAITING") ("CANCELLED") ("HOLD"))))))
-#+END_SRC
-
-
-
-