summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lisp/ledger.el55
1 files changed, 20 insertions, 35 deletions
diff --git a/lisp/ledger.el b/lisp/ledger.el
index 0aff5eaf..0e2f4b11 100644
--- a/lisp/ledger.el
+++ b/lisp/ledger.el
@@ -152,46 +152,31 @@ customizable to ease retro-entry.")
"Start a ledger session with the current month, but make it
customizable to ease retro-entry.")
-(defvar ledger-rx-constituents
- (append (list (cons 'date
- (rx (opt (group (= 4 digit)) (in "./"))
- (group (1+ digit)) (in "./")
- (group (1+ digit))))
- (cons 'opt-mark
- (rx (opt (group "*") (1+ blank)))))
- rx-constituents))
-
-(defmacro ledger-rx (&rest body)
- `(let ((rx-constituents ledger-rx-constituents))
- (rx ,@body)))
-
-(defun ledger--iterate-dispatch (nyear nmonth nday nmark ndesc)
- (let ((start (point))
- (year (match-string nyear))
- (month (string-to-number (match-string nmonth)))
- (day (string-to-number (match-string nday)))
- (mark (match-string nmark))
- (desc (match-string ndesc)))
- (if (and year (> (length year) 0))
- (setq year (string-to-number year)))
- (funcall callback start
- (encode-time 0 0 0 day month
- (or year current-year))
- mark desc)))
-
(defun ledger-iterate-entries (callback)
(goto-char (point-min))
(let* ((now (current-time))
(current-year (nth 5 (decode-time now))))
(while (not (eobp))
- (cond ((looking-at (rx "Y" (1+ blank) (group (1+ digit))))
- (setq current-year (string-to-number (match-string 1))))
-
- ((looking-at (ledger-rx date "=" date (1+ blank) opt-mark (group (1+ nonl))))
- (ledger--iterate-dispatch 1 2 3 7 8))
-
- ((looking-at (ledger-rx date (1+ blank) opt-mark (group (1+ nonl))))
- (ledger--iterate-dispatch 1 2 3 4 5)))
+ (when (looking-at
+ (concat "\\(Y\\s-+\\([0-9]+\\)\\|"
+ "\\([0-9]\\{4\\}+\\)?[./]?"
+ "\\([0-9]+\\)[./]\\([0-9]+\\)\\s-+"
+ "\\(\\*\\s-+\\)?\\(.+\\)\\)"))
+ (let ((found (match-string 2)))
+ (if found
+ (setq current-year (string-to-number found))
+ (let ((start (match-beginning 0))
+ (year (match-string 3))
+ (month (string-to-number (match-string 4)))
+ (day (string-to-number (match-string 5)))
+ (mark (match-string 6))
+ (desc (match-string 7)))
+ (if (and year (> (length year) 0))
+ (setq year (string-to-number year)))
+ (funcall callback start
+ (encode-time 0 0 0 day month
+ (or year current-year))
+ mark desc)))))
(forward-line))))
(defun ledger-time-less-p (t1 t2)