summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCraig Earls <enderw88@gmail.com>2013-03-26 19:34:37 -0400
committerCraig Earls <enderw88@gmail.com>2013-03-26 19:34:37 -0400
commit5b1778b3ca8202677aeb7096c17452e8445a25c9 (patch)
treee1a3f0f2cbae5df0dffdfe17a7030a3a26badf22
parentc8c94e960206f705610b92b6957a2209208c69c5 (diff)
downloadfork-ledger-5b1778b3ca8202677aeb7096c17452e8445a25c9.tar.gz
fork-ledger-5b1778b3ca8202677aeb7096c17452e8445a25c9.tar.bz2
fork-ledger-5b1778b3ca8202677aeb7096c17452e8445a25c9.zip
More speed improvements for align-postings.
-rw-r--r--lisp/ldg-post.el21
1 files changed, 6 insertions, 15 deletions
diff --git a/lisp/ldg-post.el b/lisp/ldg-post.el
index a39dea65..e0b5f8fa 100644
--- a/lisp/ldg-post.el
+++ b/lisp/ldg-post.el
@@ -137,27 +137,17 @@ point at beginning of the commodity."
(defvar ledger-post-account-regex
(concat "\\(^[ \t]+\\)"
- "\\([\\[(*!;a-zA-Z0-9]+?\\)"))
+ "\\([\\[(*!;a-zA-Z0-9]\\)"))
(defsubst ledger-next-account (&optional end)
"Move point to the beginning of the next account, or status marker (!*), as long as it is not past END.
Return the column of the beginning of the account and leave point
at beginning of account"
- ;; (beginning-of-line)
(if (> end (point))
(when (re-search-forward ledger-post-account-regex end t)
(goto-char (match-beginning 2))
(current-column))))
-
-(defsubst ledger-post-end-of-line-or-region (end-region)
- "Return a number the END-REGION or end of line
-position, whichever is closer."
- (let ((eol (line-end-position)))
- (if (< end-region eol)
- end-region
- eol)))
-
(defsubst ledger-post-adjust (adjust-by)
(if (> adjust-by 0)
(insert (make-string adjust-by ? ))
@@ -189,15 +179,16 @@ region align the posting on the current line."
(goto-char
(setq begin-region
(line-beginning-position)))
- (while (or (setq acc-col (ledger-next-account (ledger-post-end-of-line-or-region end-region)))
+
+ ;; This is the guts of the alignment loop
+ (while (or (setq acc-col (ledger-next-account (line-end-position)))
(and (< (point) end-region)
lines-left))
(when acc-col
- (setq acc-adjust (- ledger-post-account-alignment-column acc-col))
- (if (/= acc-adjust 0)
+ (if (/= (setq acc-adjust (- ledger-post-account-alignment-column acc-col)) 0)
(ledger-post-adjust acc-adjust))
- (when (setq amt-offset (ledger-next-amount (ledger-post-end-of-line-or-region end-region)))
+ (when (setq amt-offset (ledger-next-amount (line-end-position)))
(let* ((amt-adjust (- ledger-post-amount-alignment-column
amt-offset
(current-column))))