summaryrefslogtreecommitdiff
path: root/ledger.el
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-09-23 21:08:42 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-09-23 21:08:42 -0400
commitc57bfb72c3fd0c40bab1c47503c7f22c6a79a643 (patch)
tree4b3965e5df8bc9a5c58160f6ac8e08a542466df0 /ledger.el
parent02580c2efbad9b364ab0dfa535c5fe0577cb818d (diff)
downloadfork-ledger-c57bfb72c3fd0c40bab1c47503c7f22c6a79a643.tar.gz
fork-ledger-c57bfb72c3fd0c40bab1c47503c7f22c6a79a643.tar.bz2
fork-ledger-c57bfb72c3fd0c40bab1c47503c7f22c6a79a643.zip
moved entry hooking mechanism to journal_t; further improvements to "entry"
Diffstat (limited to 'ledger.el')
-rw-r--r--ledger.el20
1 files changed, 11 insertions, 9 deletions
diff --git a/ledger.el b/ledger.el
index 416026b0..f50fc3b8 100644
--- a/ledger.el
+++ b/ledger.el
@@ -100,11 +100,10 @@
(if (time-less-p moment date)
(throw 'found t)))))))
-(defun ledger-add-entry (entry)
+(defun ledger-add-entry (entry-text)
(interactive
- (list (read-string "Entry: " (format-time-string "%Y/%m/%d "))))
- (let* ((args (mapcar 'shell-quote-argument (split-string entry)))
- (date (car args))
+ (list (read-string "Entry: " (format-time-string "%Y/%m/"))))
+ (let* ((date (car (split-string entry-text)))
(insert-year t) exit-code)
(if (string-match "\\([0-9]+\\)/\\([0-9]+\\)/\\([0-9]+\\)" date)
(setq date (encode-time 0 0 0 (string-to-int (match-string 3 date))
@@ -117,7 +116,7 @@
(save-excursion
(insert
(with-temp-buffer
- (setq exit-code (apply 'ledger-run-ledger "entry" args))
+ (setq exit-code (ledger-run-ledger "entry" entry-text))
(if (= 0 exit-code)
(progn
(goto-char (point-min))
@@ -125,8 +124,8 @@
(if insert-year
(buffer-string)
(buffer-substring 5 (point-max))))
- (concat (if insert-year entry
- (substring entry 5)) "\n"))) "\n"))))
+ (concat (if insert-year entry-text
+ (substring entry-text 5)) "\n"))) "\n"))))
(defun ledger-expand-entry ()
(interactive)
@@ -303,8 +302,11 @@
(defun ledger-run-ledger (&rest args)
"run ledger with supplied arguments"
- (apply 'call-process ledger-binary-path nil t nil
- (append (list "-f" ledger-data-file) args)))
+ (let ((command (mapconcat 'identity
+ (append (list ledger-binary-path
+ "-f" ledger-data-file) args) " ")))
+ (insert (shell-command-to-string command)))
+ 0)
(provide 'ledger)