summaryrefslogtreecommitdiff
path: root/ledger.el
diff options
context:
space:
mode:
Diffstat (limited to 'ledger.el')
-rw-r--r--ledger.el56
1 files changed, 40 insertions, 16 deletions
diff --git a/ledger.el b/ledger.el
index ac52c37c..8d6a737e 100644
--- a/ledger.el
+++ b/ledger.el
@@ -1,4 +1,4 @@
-;;; ledger.el --- Helper code for using my "ledger" command-line tool
+;;; ledger.el --- Helper code for use with the "ledger" command-line tool
;; Copyright (C) 2004 John Wiegley (johnw AT gnu DOT org)
@@ -32,7 +32,14 @@
;;; Commentary:
-;; This code is only meaningful if you are using "ledger".
+;; To use this module: Load this file, open a ledger data file, and
+;; type M-x ledger-mode. Once this is done, you can type:
+;;
+;; C-c C-a add a new entry, based on previous entries
+;; C-c C-r reconcile the entries related to an account
+;;
+;; In the reconcile buffer, use SPACE to toggle the cleared status of
+;; a transaction.
(defvar ledger-version "1.1"
"The version of ledger.el currently loaded")
@@ -46,6 +53,11 @@
:type 'file
:group 'ledger)
+(defcustom ledger-data-file (getenv "LEDGER")
+ "Path to the ledger data file."
+ :type 'file
+ :group 'ledger)
+
(defvar bold 'bold)
(defvar ledger-font-lock-keywords
@@ -88,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))
@@ -106,14 +117,20 @@
(insert
(with-temp-buffer
(setq exit-code
- (apply 'call-process ledger-binary-path nil t nil
- (cons "entry" args)))
+ (ledger-run-ledger
+ "entry"
+ (with-temp-buffer
+ (insert entry-text)
+ (goto-char (point-min))
+ (while (re-search-forward "\\([&$]\\)" nil t)
+ (replace-match "\\\\\\1"))
+ (buffer-string))))
(if (= 0 exit-code)
(if insert-year
- (buffer-string)
- (buffer-substring 5 (point-max)))
- (concat (if insert-year entry
- (substring entry 5)) "\n\n")))))))
+ (buffer-substring 2 (point-max))
+ (buffer-substring 7 (point-max)))
+ (concat (if insert-year entry-text
+ (substring entry-text 6)) "\n"))) "\n"))))
(defun ledger-expand-entry ()
(interactive)
@@ -206,9 +223,7 @@
(defun ledger-update-balance-display ()
(let ((account ledger-acct))
(with-temp-buffer
- (let ((exit-code
- (apply 'call-process ledger-binary-path nil t nil
- (list "-C" "balance" account))))
+ (let ((exit-code (ledger-run-ledger "-C" "balance" account)))
(if (/= 0 exit-code)
(setq ledger-reconcile-text "Reconcile [ERR]")
(goto-char (point-min))
@@ -218,7 +233,7 @@
(concat "Reconcile ["
(buffer-substring-no-properties (point-min) (point))
"]"))))))
- (redraw-modeline))
+ (force-mode-line-update))
(defun ledger-reconcile-toggle ()
(interactive)
@@ -290,6 +305,15 @@
(insert " ")))
(forward-line))))
+(defun ledger-run-ledger (&rest args)
+ "run ledger with supplied arguments"
+ (let ((command
+ (mapconcat 'identity
+ (append (list ledger-binary-path
+ "-f" ledger-data-file) args) " ")))
+ (insert (shell-command-to-string command)))
+ 0)
+
(provide 'ledger)
;;; ledger.el ends here