diff options
author | Craig Earls <enderw88@gmail.com> | 2013-03-01 09:38:14 -0700 |
---|---|---|
committer | Craig Earls <enderw88@gmail.com> | 2013-03-01 09:38:14 -0700 |
commit | 5f79687c9332c818db726c0545c96db4a195eae8 (patch) | |
tree | df000efa7189a2600966a18060430651dcad19e4 | |
parent | d00ebb4875a25f0f80bd15f93c9da68b0b3bc347 (diff) | |
parent | 3a0182d8d7a20ac33f78ab7e614881c6fe87a129 (diff) | |
download | fork-ledger-5f79687c9332c818db726c0545c96db4a195eae8.tar.gz fork-ledger-5f79687c9332c818db726c0545c96db4a195eae8.tar.bz2 fork-ledger-5f79687c9332c818db726c0545c96db4a195eae8.zip |
Merge branch 'next' into ledger-mode-automatic-transactions
-rw-r--r-- | doc/ledger-mode.texi | 109 | ||||
-rw-r--r-- | lisp/ldg-commodities.el | 27 | ||||
-rw-r--r-- | lisp/ldg-reconcile.el | 29 |
3 files changed, 88 insertions, 77 deletions
diff --git a/doc/ledger-mode.texi b/doc/ledger-mode.texi index 9b2c1262..336f5ba8 100644 --- a/doc/ledger-mode.texi +++ b/doc/ledger-mode.texi @@ -1,5 +1,5 @@ \input texinfo @c -*-texinfo-*- -@setfilename ledger3.info +@setfilename ledger-mode.info @settitle Ledger: Command-Line Accounting @dircategory Major Modes @@ -93,9 +93,9 @@ reports and much more... @node Quick Installation, Menus, Introduction to Ledger Mode, Introduction to Ledger Mode @section Quick Installation -The emacs lisp source for Ledger-mode is included with the source +The Emacs lisp source for Ledger-mode is included with the source distribution of Ledger. It is entirely included in the @file{lisp} -subdirectory. To use ledger mode include the following in your emacs +subdirectory. To use ledger mode include the following in your Emacs initialization file (@file{~/.emacs}, @file{~/.emacs.d/init.el}, @file{~/.Aquamacs/Preferences.el} @@ -137,15 +137,15 @@ Ledger from a convenient command line. As simple as the ledger transaction format is, it can still be daunting to add many transactions manually. Ledger provides two way to add transactions with minimal typing. Both are based on the idea that most -tranactions are repretitions of earlier transactions. +transactions are repetitions of earlier transactions. In the @file{demo.ledger} buffer enter a date using the correct -format. The tpye the first few characters of another payee in the +format. Then type the first few characters of another payee in the @file{demo.ledger} buffer. Type @code{C-c TAB}. Ledger-mode will search for a Payee that has the same beginning and copy the rest of the transaction to you new entry. -Additionally you can ust the ledger xact command, by typing @code{C-c +Additionally you can use the ledger xact command, by typing @code{C-c C-a} then typing a close match to the payee. Ledger mode will call @code{ledger xact} with the data you enter and place the transaction in the proper chronological place in the ledger. @@ -154,7 +154,7 @@ the proper chronological place in the ledger. @subsection Reconciliation The biggest task of maintaining a ledger is ensuring the it matches the -outside world. This process is called reconciliation (@xref{Basics of +outside world. This process is called reconciliation (@pxref{Basics of Reconciliation}) and can be quite onerous. Ledger mode attempts to make it as painless as possible. @@ -166,14 +166,14 @@ Normally this would be the ending value from your bank statement, or the latest value in your on-line transaction summary. Enter @code{1710}. Note that Ledger-mode assumes your are using $ (USD) as your default commodity, this can be easily changed in the customization -variables. @xref{Ledger-mode Customization} +variables. @xref{Ledger-mode Customization}. You now see a list of uncleared transactions in a buffer below the @file{demo.ledger} buffer. Touching the space bar will mark a transaction as pending and display the current cleared (and pending) balance, along with the difference remaining to meet your target. Clear the first three transactions, and you will see the difference to target -reach $0. End the reconcilitation by typing @code{C-c C-c}. This saves +reach $0. End the reconciliation by typing @code{C-c C-c}. This saves the demo.ledger buffer and marks the transactions and finally cleared. Type @code{q} to close out the reconciliation buffer. @@ -181,16 +181,16 @@ Type @code{q} to close out the reconciliation buffer. @subsection Reports The real power of Ledger is in it reporting capabilities. Reports can -be run and displayed in a spearate Emacs buffer. In the +be run and displayed in a separate Emacs buffer. In the @file{demo.ledger} buffer, type @code{C-c C-o C-r}. In the mini-buffer Emacs will prompt for a report name. There are a few built-in reports, -and you can add any report you need @xref{Adding New Reports}. +and you can add any report you need @xref{Adding and Editing Reports}. In the mini-buffer type @code{account}. When prompted for an account type @code{checking}. In another buffer you will see a Ledger register report. You can move around the buffer, with the point on a transaction, type @code{C-c C-c}. Ledger mode will take you directly to that -transaction in the @file{demo.ledger} buffer. +transaction in the @file{demo.ledger} buffer. Another built-in report is the balance report. In the @file{demo.ledger} buffer, type @code{C-c C-o C-r}. When prompted for a @@ -231,7 +231,7 @@ Ledger mode can also help you keep your amounts in alignment. Setting @code{ledger-post-auto-adjust-amounts} to true tells Ledger-mode to automatically place any amounts such that their last digit is aligned to the column specified by @code{ledger-post-amount-alignment-column}, -which defautls to 52. @xref{Ledger Post Customization Group} +which defaults to 52. @xref{Ledger Post Customization Group}. @node Editing Amounts, Marking Transactions, Adding Transactions, The Ledger Buffer @section Editing Amounts @@ -240,8 +240,8 @@ into all recent version of Emacs. Ledger-mode makes it easy to calculate values for amount by integrating GNU Calc. With the point anywhere in the same line as a posting, typing @code{C-c C-b} will bring up the Calc buffer, and push the current amount for the posting -onto the top of the Calc stack. Perform any calculations you ened to -arrive at the final vlaue, then type @code{y} to ynk the value at the +onto the top of the Calc stack. Perform any calculations you need to +arrive at the final value, then type @code{y} to yank the value at the top of stack back into the ledger buffer. Note: GNU Calc does not directly support commas as decimal separators. Ledger mode will translate values from decimal-comma format to decimal-period format for @@ -262,7 +262,7 @@ No state. This is equivalent to sticking a check in the mail. It has been obligated, but not been cashed by the recipient. It could also apply to credit/debit card transactions that have not been cleared into your account balance. You bank may call these transactions 'pending', -but Ledger-mode usues a slightly different meaning. +but Ledger-mode uses a slightly different meaning. @item Pending. Ledger-mode's reconciliation function see pending transactions as an intermediate step in reconciling an account. When doing a @@ -291,7 +291,7 @@ transaction operation is in the undo buffer. As you operating on the Ledger files, they may become disorganized. For the most part, Ledger doesn't care, but our human brains prefer a bit of order. Sorting the transactions in a buffer into chronological order -can help bring order to chaos. Ledger sort (@code C-c C-s) will sort +can help bring order to chaos. Ledger sort (@code{C-c C-s}) will sort all of the transactions in a region by date. Ledger-mode isn't particularly smart about handling dates and it simply sorts the transactions using the string at the beginning of the transaction. So, @@ -299,40 +299,41 @@ you should use the preferred ISO 8601 standard date format @code{YYYY/MM/DD} which easily sorts. Note, there is a menu entry to sort the entire buffer. Special -transactions like automated transactsion, will be moved in the sorting -process and may not fucntion correctly afterwards. For this reason +transactions like automated transaction, will be moved in the sorting +process and may not function correctly afterwards. For this reason there is no key sequence. @node Hiding Transactions, , Sorting Transactions, The Ledger Buffer @section Hiding Transactions -Ofen times you will want to run Ledger register reports just to look at -a specific set of transactions. If you don't need the running total -calculation hadnled by Ledger, Ledger-mode provides a rapid way of -narrowing what is displayed in the buffer in a way that is sipler than -the Ledger register command. +Often you will want to run Ledger register reports just to look at a +specific set of transactions. If you don't need the running total +calculation handled by Ledger, Ledger-mode provides a rapid way of +narrowing what is displayed in the buffer in a way that is simpler than +the Ledger register command. Based on the Emacs Occur mode by Alexey Veretennikov, Ledger-occur hides all transactions that do NOT meet a specific regular expression. The regular expression can match on any part of the transaction. If you want to find all transactions whose amount ends in .37, you can do that -( I don't know why, but hey, whatever ever flaots you aerostat). +( I don't know why, but hey, whatever ever floats you aerostat). -Using @code(C-c C-f) or the @code{Hide Xacts} menu entry, enter a -regualr expression in the minbuffer. Ledger-mode will hide all oter -transactions. For details of the regualr expression syntax, see the -Emacs Manual or the Emac Elisp Reference Manual. A few examples using -the @file{demo.ledger} are given here: +Using @code{C-c C-f} or the @code{Hide Xacts} menu entry, enter a +regular expression in the minibuffer. Ledger-mode will hide all other +transactions. For details of the regular expression syntax, see +@ref{(emacs)Regexps, Syntax of Regular Expressions} or +@ref{(elisp)Regular Expressions, Regular Expressions}. A few examples +using the @file{demo.ledger} are given here: @table @samp @item Groceries Show only transactions that have a posting to the `Groceries' account. @item ^2011/01 -Show only transactions occuring in January of 2011. +Show only transactions occurring in January of 2011. @item ^2011/.*/25 -Show only transactions occuring on the 25th of the month in 2011 +Show only transactions occurring on the 25th of the month in 2011 @item .*ore -Show only transaction with payeees or accounts ending in `ore' +Show only transaction with payees or accounts ending in `ore' @end table To show all transactions simply invoke @code{Hide Xacts} or @code{C-c @@ -345,7 +346,7 @@ C-f} again. * Starting a Reconciliation:: * Mark Transactions Pending:: * Edit Transactions During Reconciliation:: -* Finialize Reconciliation:: +* Finalize Reconciliation:: * Adding and Deleting Transactions during Reconciliation:: * Changing Reconciliation Account:: * Changing Reconciliation Target:: @@ -354,12 +355,12 @@ C-f} again. @node Basics of Reconciliation, Starting a Reconciliation, The Reconcile Buffer, The Reconcile Buffer @section Basics of Reconciliation -Even in this relativley modern era, financial transactions do not happen +Even in this relatively modern era, financial transactions do not happen instantaneously, unless you are paying cash. When you swipe your debit card the money may take several days to actually come out of your account, or a check may take several days to ``clear''. That is the root of the difference between ``obligating'' funds and ``expending'' -funds. Obligation says you have agreed to pay it, the expnediture +funds. Obligation says you have agreed to pay it, the expenditure doesn't happen until the money actually leaves your account. Or in the case of receiving payment, you have an account receivable until the money has actually made it to you. @@ -385,7 +386,7 @@ enter the account enter the target amount. Ledger expects you to enter an amount with a commodity. It assumes initially that you are using $ (USD) as your default commodity. If you are working in a difference currency you can change the default in variable -@code(ledger-reconcile-default-commodity) to whatever you need. If you +@code{ledger-reconcile-default-commodity} to whatever you need. If you work in multiple commodities simply enter the commoditized amount (for example @code{340 VSDX}, for 340 shares of VSDX). @@ -400,12 +401,12 @@ not display the complete list of commodities. The @file{*Reconcile*} buffer will show all the uncleared transactions that meeting the criteria set in the regex. By default uncleared transactions are shown in red. When you have verified that a -transaction ahs been correctly and compeltely recorded by the opposing +transaction has been correctly and completely recorded by the opposing party, mark the transaction as pending using the space bar. Continue this process until you agree with the opposing party and the difference from your target is zero. -@node Edit Transactions During Reconciliation, Finialize Reconciliation, Mark Transactions Pending, The Reconcile Buffer +@node Edit Transactions During Reconciliation, Finalize Reconciliation, Mark Transactions Pending, The Reconcile Buffer @section Edit Transactions during Reconciliation If you find errors during reconciliation. You can visit the transaction @@ -415,14 +416,14 @@ you have finished editing the transaction saving the buffer will automatically return you to the @file{*Reconcile*} buffer and you can mark the transaction if appropriate. -@node Finialize Reconciliation, Adding and Deleting Transactions during Reconciliation, Edit Transactions During Reconciliation, The Reconcile Buffer +@node Finalize Reconciliation, Adding and Deleting Transactions during Reconciliation, Edit Transactions During Reconciliation, The Reconcile Buffer @section Finalize Reconciliation Once you have marked all transactions as pending and the cleared balance is correct. Finish the reconciliation by typing @code{C-c C-c}. This marks all pending transaction as cleared and saves the ledger buffer. -@node Adding and Deleting Transactions during Reconciliation, Changing Reconciliation Account, Finialize Reconciliation, The Reconcile Buffer +@node Adding and Deleting Transactions during Reconciliation, Changing Reconciliation Account, Finalize Reconciliation, The Reconcile Buffer @section Adding and Deleting Transactions during Reconciliation While reconciling, you may find new transactions that need to be entered @@ -437,7 +438,7 @@ Typing @code{d} will delete the transaction under point in the You can conveniently switch the account being reconciled by typing @code{g}, and entering a new account to reconcile. This simply restarts -teh reconcile process. Any transactions that were marked `pending' in +the reconcile process. Any transactions that were marked `pending' in the ledger buffer are left in that state when the account is switched. @node Changing Reconciliation Target, , Changing Reconciliation Account, The Reconcile Buffer @@ -457,11 +458,11 @@ type @code{t} and enter the new target value. @node Running Basic Reports, Adding and Editing Reports, The Report Buffer, The Report Buffer @section Running Reports -The real popwer behing Ledger is in its amazing reporting capability. -Ledger-mode provides easy facility to run reports directly from emacs. +The real power behind Ledger is in its amazing reporting capability. +Ledger-mode provides easy facility to run reports directly from Emacs. It has four reports built-in and facilities for adding custom reports. -Typeing @code{C-c C-o C-r} or using menu @code{Ledger Run Report} prompt +Typing @code{C-c C-o C-r} or using menu @code{Ledger Run Report} prompt for the name of a saved report. The built-in reports are: @table @samp @item bal @@ -490,7 +491,7 @@ automatically saved with the name given and you can re-run it at any time. There are two ways to edit the command line for a report. The first is -to privide a prefix argument to the run-report command. For example, +to provide a prefix argument to the run-report command. For example, type @code{M-1 C-c C-o C-r}. This will prompt you for the report name, then present the report command line to be edited. When you hit enter, the report will be run, but it will not be permanently saved. If you @@ -499,7 +500,7 @@ will have the option to give it a new name, or overwrite the old report. Deleting reports is accomplished by type @code{C-c C-o C-e} Edit Reports in the ledger buffer, or typing @code{E} in the @file{*Ledger Report*} -buffer. This takes you to the emacs customization window for the +buffer. This takes you to the Emacs customization window for the @code{ledger-reports} variable. Use the widgets to delete the report you want removed. @@ -526,7 +527,7 @@ Prompt for a tag value. You can use these expansion values in your ledger report commands. For example, if you wanted to specify a register report the displayed -trnasactions from a user-determined account with a particular meta-data +transactions from a user-determined account with a particular meta-data tag value, you specify the following command line: @smallexample ledger -f %(ledger-file) reg %(account) --limit \"tag('my-tag') =~ @@ -538,7 +539,7 @@ ledger -f %(ledger-file) reg %(account) --limit \"tag('my-tag') =~ @node Make Report Transactions Active, , Expansion Formats, Adding and Editing Reports @subsection Make Report Transactions Active -In a large register report it is convenient to be anle to jump to the +In a large register report it is convenient to be able to jump to the source transaction. Ledger-mode will automatically include source information in every register file that doesn't contain a @code{--subtotal} option. It does this by adding a @@ -550,9 +551,9 @@ may not get stripped out of the visible report. @node Reversing Report Order, , Adding and Editing Reports, The Report Buffer @section Reversing Report Order -Often, banks show their online transaction historyies with the most recent +Often, banks show their online transaction histories with the most recent transaction at the top. Ledger itself cannot do a sensible ledger -report in reverse chronoligcal order, if you sort on reverse date the +report in reverse chronological order, if you sort on reverse date the calculation will also run in the opposite direction. If you want to compare a ledger register report to a bank report with the most recent transactions at the top, type R in the @file{*Ledger Report*} buffer and @@ -574,9 +575,9 @@ Ledger-mode has several options available for configuration. All options can be configure through the Emacs customization menus, or specified in your Emacs initialization file. The complete list of options is show below. To change the option using the Emacs -customization menu, simply choe customize in the Options menu and look +customization menu, simply chose customize in the Options menu and look for Ledger under the data options. Alternately you can choose -``Customize Specific Group'' and enger ``Ledger'' as the group. +``Customize Specific Group'' and enter ``Ledger'' as the group. @node Customization Variables, , Ledger-mode Customization, Customizing Ledger-mode @section Customization Variables @@ -625,7 +626,7 @@ reconcile. Defaults to $ (USD) register window and resize. @item ledger-reconcile-toggle-to-pending If non-nil, then toggle between uncleared and pending (@code{!}). If false - toggle between unlceared and cleared (@code{*}) + toggle between uncleared and cleared (@code{*}) @end table @node Ledger Report Customization Group, Ledger Faces Customization Group, Ledger Reconcile Customization Group, Customization Variables diff --git a/lisp/ldg-commodities.el b/lisp/ldg-commodities.el index c5500785..a3cc8951 100644 --- a/lisp/ldg-commodities.el +++ b/lisp/ldg-commodities.el @@ -38,16 +38,23 @@ (with-temp-buffer (insert str) (goto-char (point-min)) - (re-search-forward "-?[1-9][0-9]*[.,][0-9]*" nil t) - (setq val - (string-to-number - (ledger-commodity-string-number-decimalize - (delete-and-extract-region (match-beginning 0) (match-end 0)) :from-user))) - (goto-char (point-min)) - (re-search-forward "[^[:space:]]" nil t) - (setq comm - (delete-and-extract-region (match-beginning 0) (match-end 0))) - (list val comm)))) + (cond ((re-search-forward "-?[1-9][0-9]*[.,][0-9]*" nil t) + ;; found a decimal number + (setq val + (string-to-number + (ledger-commodity-string-number-decimalize + (delete-and-extract-region (match-beginning 0) (match-end 0)) :from-user))) + (goto-char (point-min)) + (re-search-forward "[^[:space:]]" nil t) + (setq comm + (delete-and-extract-region (match-beginning 0) (match-end 0))) + (list val comm)) + ((re-search-forward "0" nil t) + ;; couldn't find a decimal number, look for a single 0, + ;; indicating account with zero balance + (list 0 ledger-reconcile-default-commodity)) + (t + (error "split-commodity-string: cannot parse commodity string: %S" str)))))) (defun ledger-string-balance-to-commoditized-amount (str) diff --git a/lisp/ldg-reconcile.el b/lisp/ldg-reconcile.el index 6093f9df..f64f1bca 100644 --- a/lisp/ldg-reconcile.el +++ b/lisp/ldg-reconcile.el @@ -63,10 +63,8 @@ reconcile-finish will mark all pending posting cleared." :group 'ledger-reconcile) -(defun ledger-reconcile-get-balances () - "Calculate the cleared and uncleared balance of the account. -Return a list with the account, uncleared and cleared balances as -numbers" +(defun ledger-reconcile-get-cleared-or-pending-balance () + "Calculate the cleared or pending balance of the account." (interactive) (let ((buffer ledger-buf) (account ledger-acct) @@ -77,15 +75,17 @@ numbers" ; separated from the actual format string. emacs does not ; split arguments like the shell does, so you need to ; specify the individual fields in the command line. - "balance" "--limit" "cleared or pending" - "--format" "(\"%(display_total)\")" account) - (setq val (read (buffer-substring-no-properties (point-min) (point-max))))))) + "balance" "--limit" "cleared or pending" "--empty" + "--format" "%(display_total)" account) + (setq val + (ledger-split-commodity-string + (buffer-substring-no-properties (point-min) (point-max))))))) (defun ledger-display-balance () - "Calculate the cleared balance of the account being reconciled." + "Display the cleared-or-pending balnce and calculate the +target-delta of the account being reconciled." (interactive) - (let* ((pending (car (ledger-string-balance-to-commoditized-amount - (car (ledger-reconcile-get-balances))))) + (let* ((pending (ledger-reconcile-get-cleared-or-pending-balance)) (target-delta (if ledger-target (-commodity ledger-target pending) nil))) @@ -156,7 +156,8 @@ numbers" (ledger-do-reconcile) (set-buffer-modified-p t) (goto-char (point-min)) - (forward-line line))) + (forward-line line) + (ledger-display-balance))) (defun ledger-reconcile-refresh-after-save () "Refresh the recon-window after the ledger buffer is saved." @@ -375,7 +376,8 @@ POSTING is used in `ledger-clear-whole-transactions' is nil." (ledger-reconcile-refresh) (goto-char (point-min)) (setq ledger-target - (ledger-read-commodity-string "Set reconciliation target"))) + (ledger-read-commodity-string "Set reconciliation target")) + (ledger-display-balance)) (progn ;; no recon-buffer, starting from scratch. (add-hook 'after-save-hook 'ledger-reconcile-refresh-after-save nil t) @@ -389,7 +391,8 @@ POSTING is used in `ledger-clear-whole-transactions' is nil." (set (make-local-variable 'ledger-acct) account) (ledger-do-reconcile) (set (make-local-variable 'ledger-target) - (ledger-read-commodity-string "Set reconciliation target"))))))) + (ledger-read-commodity-string "Set reconciliation target")) + (ledger-display-balance)))))) (defvar ledger-reconcile-mode-abbrev-table) |