2021-04-13 20:09:08 -04:00
|
|
|
;;; lang/beancount/config.el -*- lexical-binding: t; -*-
|
|
|
|
|
2021-04-15 14:15:42 -04:00
|
|
|
(use-package! beancount
|
2021-04-13 20:09:08 -04:00
|
|
|
:mode "\\.beancount\\'"
|
|
|
|
:init
|
|
|
|
(add-hook 'beancount-mode-hook #'outline-minor-mode)
|
|
|
|
|
|
|
|
(after! all-the-icons
|
|
|
|
(add-to-list 'all-the-icons-icon-alist
|
|
|
|
'("\\.beancount\\'" all-the-icons-material "attach_money" :face all-the-icons-lblue))
|
|
|
|
(add-to-list 'all-the-icons-mode-icon-alist
|
|
|
|
'(beancount-mode all-the-icons-material "attach_money" :face all-the-icons-lblue)))
|
2021-04-15 14:15:42 -04:00
|
|
|
|
|
|
|
;; TODO PR this upstream
|
|
|
|
(defadvice! +beancount--fix-faces-a ()
|
|
|
|
"`beancount-outline-face' returns org-level-N faces for beancount-mode's
|
|
|
|
font-lock keywords, but there is no guarantee `org' will be loaded when
|
|
|
|
beancount-mode is activated. If it is absent, you will see a flood of 'invalid
|
|
|
|
face' errors. Just use the outline-N faces to get around this.
|
|
|
|
|
|
|
|
This msut be advised *before* beancount-mode loads, because
|
|
|
|
`beancount-outline-face' is used at load time."
|
|
|
|
:override #'beancount-outline-face
|
|
|
|
(if outline-minor-mode
|
|
|
|
(let ((level (funcall outline-level)))
|
|
|
|
(if (integerp level)
|
|
|
|
(intern (format "outline-%d" level))))
|
|
|
|
nil))
|
|
|
|
|
2021-04-13 20:09:08 -04:00
|
|
|
:config
|
|
|
|
(when (featurep! +lsp)
|
|
|
|
(add-hook 'beancount-mode-local-vars-hook #'lsp!))
|
|
|
|
|
|
|
|
(setq beancount-electric-currency t)
|
|
|
|
|
|
|
|
(map! :map beancount-mode-map
|
2021-04-15 14:15:42 -04:00
|
|
|
"TAB" (cmds! (and outline-minor-mode (outline-on-heading-p))
|
|
|
|
#'beancount-outline-cycle
|
|
|
|
#'indent-according-to-mode)
|
2021-04-13 20:09:08 -04:00
|
|
|
:localleader
|
|
|
|
"b" #'+beancount/balance
|
|
|
|
"c" #'beancount-check
|
|
|
|
"l" #'beancount-linked
|
|
|
|
"q" #'beancount-query
|
|
|
|
"x" #'beancount-context
|
|
|
|
(:prefix ("i" . "insert")
|
|
|
|
"a" #'beancount-insert-account
|
|
|
|
"p" #'beancount-insert-prices
|
2021-04-15 14:15:42 -04:00
|
|
|
"d" #'beancount-insert-date))
|
|
|
|
|
|
|
|
;; TODO PR this upstream?
|
|
|
|
(defun +beancount-electric-align-h ()
|
|
|
|
"Align amount in current line to `beancount-number-alignment-column'."
|
|
|
|
(when (and beancount-electric-currency (eq last-command-event ?\n))
|
|
|
|
(save-excursion
|
|
|
|
(forward-line -1)
|
|
|
|
(ignore-errors (beancount-align-to-previous-number)))))
|
|
|
|
(add-hook! 'beancount-mode-hook
|
|
|
|
(add-hook 'post-self-insert-hook #'+beancount-electric-align-h 'append t))
|
|
|
|
|
|
|
|
;; TODO PR this upstream
|
|
|
|
(defadvice! +beancount--fix-account-currency-a (account)
|
|
|
|
"Fixes `beancount-electric-currency', which could never find the currency
|
|
|
|
for the current account. Also allows it to fall back to the operating_currency."
|
|
|
|
:override #'beancount--account-currency
|
|
|
|
(save-excursion
|
|
|
|
(goto-char (point-min))
|
|
|
|
(when (or (re-search-forward
|
|
|
|
(concat "^" beancount-date-regexp " +open"
|
|
|
|
"\\s-+" (regexp-quote account)
|
|
|
|
"\\s-+\\(" beancount-currency-regexp "\\)\\>")
|
|
|
|
nil t)
|
|
|
|
(re-search-forward
|
|
|
|
(concat "^option\\s-+\"operating_currency\"\\s-+\"\\("
|
|
|
|
beancount-currency-regexp
|
|
|
|
"\\)\"")
|
|
|
|
nil t))
|
|
|
|
(match-string-no-properties 1)))))
|