diff options
Diffstat (limited to 'lisp')
-rw-r--r-- | lisp/ldg-complete.el | 2 | ||||
-rw-r--r-- | lisp/ldg-mode.el | 18 | ||||
-rw-r--r-- | lisp/ldg-regex.el | 24 |
3 files changed, 12 insertions, 32 deletions
diff --git a/lisp/ldg-complete.el b/lisp/ldg-complete.el index 2faef5df..3dd48a74 100644 --- a/lisp/ldg-complete.el +++ b/lisp/ldg-complete.el @@ -82,7 +82,7 @@ (dolist (account (delete-dups (progn - (while (re-search-forward ledger-account-or-metadata-regex nil t) + (while (re-search-forward ledger-account-any-status-regex nil t) (unless (between origin (match-beginning 0) (match-end 0)) (setq accounts (cons (match-string-no-properties 2) accounts)))) accounts))) diff --git a/lisp/ldg-mode.el b/lisp/ldg-mode.el index 75b842e2..f7e3d0e6 100644 --- a/lisp/ldg-mode.el +++ b/lisp/ldg-mode.el @@ -84,18 +84,12 @@ And calculate the target-delta of the account being reconciled." "Decide what to with with <TAB>. Can indent, complete or align depending on context." (interactive "p") - (when (= (point) (line-end-position)) - (if (= (point) (line-beginning-position)) - (indent-to ledger-post-account-alignment-column) - (save-excursion - (re-search-backward - (rx-static-or ledger-account-any-status-regex - ledger-metadata-regex - ledger-payee-any-status-regex) - (line-beginning-position) t)) - (when (= (point) (match-end 0)) - (ledger-pcomplete interactively)))) - (ledger-post-align-postings)) + (if (= (point) (line-beginning-position)) + (indent-to ledger-post-account-alignment-column) + (if (and (> (point) 1) + (looking-back "[:A-Za-z0-9]" 1)) + (ledger-pcomplete interactively) + (ledger-post-align-postings)))) (defvar ledger-mode-abbrev-table) diff --git a/lisp/ldg-regex.el b/lisp/ldg-regex.el index cdd06d39..b15cd1de 100644 --- a/lisp/ldg-regex.el +++ b/lisp/ldg-regex.el @@ -52,10 +52,10 @@ (defconst ledger-multiline-comment-regex "^!comment\n\\(.*\n\\)*?!end_comment$") -(defconst ledger-payee-any-status-regex +(defconst ledger-payee-any-status-regex "^[0-9]+[-/][-/.=0-9]+\\(\\s-+\\*\\)?\\(\\s-+(.*?)\\)?\\s-+\\(.+?\\)\\s-*\\(;\\|$\\)") -(defconst ledger-payee-pending-regex +(defconst ledger-payee-pending-regex "^[0-9]+[-/][-/.=0-9]+\\s-\\!\\s-+\\(([^)]+)\\s-+\\)?\\([^*].+?\\)\\s-*\\(;\\|$\\)") (defconst ledger-payee-cleared-regex @@ -68,7 +68,7 @@ "^--.+?\\($\\|[ ]\\)") (defconst ledger-account-any-status-regex - "^[ \t]+\\(?1:[*!]\\s-*\\)?\\(?2:[^ ;].*?\\)\\( \\|\t\\|$\\)") + "^[ \t]+\\([*!]\\s-+\\)?[[(]?\\(.+?\\)\\(\t\\|\n\\| [ \t]\\)") (defconst ledger-account-pending-regex "\\(^[ \t]+\\)\\(!\\s-*.*?\\)\\( \\|\t\\|$\\)") @@ -76,20 +76,6 @@ (defconst ledger-account-cleared-regex "\\(^[ \t]+\\)\\(*\\s-*.*?\\)\\( \\|\t\\|$\\)") -(defconst ledger-metadata-regex - "[ \t]+\\(?2:;[ \t]+.+\\)$") - -(defconst ledger-account-or-metadata-regex - (concat - ledger-account-any-status-regex - "\\|" - ledger-metadata-regex)) - -(defmacro rx-static-or (&rest rx-strs) - "Returns rx union of regexps which can be symbols that eval to strings." - `(rx (or ,@(mapcar #'(lambda (rx-str) - `(regexp ,(eval rx-str))) - rx-strs)))) (defmacro ledger-define-regexp (name regex docs &rest args) "Simplify the creation of a Ledger regex and helper functions." @@ -126,7 +112,7 @@ ,(intern (concat "ledger-regex-" (symbol-name name) "-group")) string))))) - + (dolist (arg args) (let (var grouping target) (if (symbolp arg) @@ -187,7 +173,7 @@ (put 'ledger-define-regexp 'lisp-indent-function 1) (ledger-define-regexp iso-date - ( let ((sep '(or ?- ?/))) + ( let ((sep '(or ?- ?/))) (rx (group (and (group (? (= 4 num))) (eval sep) |