diff options
-rw-r--r-- | doc/ledger3.texi | 308 |
1 files changed, 307 insertions, 1 deletions
diff --git a/doc/ledger3.texi b/doc/ledger3.texi index 3eb913c6..d41df108 100644 --- a/doc/ledger3.texi +++ b/doc/ledger3.texi @@ -45,7 +45,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. @titlepage @title Ledger: Command-Line Accounting @subtitle For Version 3.0 of Ledger -@subtitle Draft Manual Time-stamp: <2011-10-27 21:55 (cpearls)> +@subtitle Draft Manual Time-stamp: <2011-10-29 11:28 (cpearls)> @author John Wiegley @end titlepage @@ -3143,6 +3143,312 @@ The @code{org} command produces a journal file suitable for use in the emacs org mode. More details on using org mode can be found at @url{http://www.orgmode.org}. +Org mode has a sub-system known as babel which allows for literate +programming. This allows you to mix text and code within the same +document and automatically execute code which may generate results which +will then appear in the text. + +One of the languages supported by org+babel is ledger so that you can +have ledger commands embedded in a text file and have the output of +ledger commands also appear in the text file. The output can be +updated whenever any new ledger entries are added. + +For instance, the following org mode text document snippet illustrates a +very naive but still useful of the org+babel system: + +@smallexample +* A simple test of ledger in an org file +The following are some entries and I have requested that ledger be run +to generate a balance on the accounts. I could have asked for a +register or, in fact, anything at all the ledger can do through command +line options. + +#+begin_src ledger :cmdline -s bal :results value +2010/01/01 * Starting balance + assets:bank:savings £1300.00 + income:starting balances +2010/07/22 * Got paid + assets:bank:chequing £1000.00 + income:salary +2010/07/23 Rent + expenses:rent £500.00 + assets:bank:chequing +#+end_src + +#+results: +: £1800.00 assets:bank +: £500.00 chequing +: £1300.00 savings +: £500.00 expenses:rent +: £-2300.00 income +: £-1000.00 salary +: £-1300.00 starting balances +@end smallexample + +Typing @command{C-c C-c} anywhere in the ``ledger source code block'' +will invoke ledger on the contents of that block and generate a +``results'' block. The results block can appear anywhere in the file +but, by default, will appear immediately below the source code block. + +You can combine multiple source code blocks before executing ledger and +do all kinds of other wonderful things with Babel (and org). + + +@subsubsection Using Ledger for Accounting in Org-mode with Babel + +Using Babel, it is possible to record financial transactions +conveniently in an org file and subsequently generate the financial +reports required. + +@unnumberedsubsubsec Getting Started + +With a recent version of org (7.01+), Ledger support is provided. To use +it, enable Ledger support. Check the Babel documentation on Worg for +instructions on how to achieve this but I currently do this directly as +follows: +@smallexample +(org-babel-do-load-languages + 'org-babel-load-languages + '((ledger . t) ;this is the important one for this tutorial + )) +@end smallexample +Once Ledger support in Babel has been enabled, we can use proceed to +include Ledger entries within an org file. There are three ways (at +least) in which these can be included: + +@enumerate +@item + place all Ledger entries within one source block and execute + this block with different arguments to generate the appropriate + reports; +@item + place Ledger entries in more than one source block and use the + noweb literary programming approach, supported by babel, to + combine these into one block elsewhere in the file for + processing by Ledger; and, +@item + place Ledger entries in different source blocks and use + tangling to generate a Ledger file which you can subsequently + process using Ledger directly. +@end enumerate + +The first two are described in more detail in this short tutorial. + +@unnumberedsubsubsec Embedded Ledger example with single source block + +The easiest, albeit possibly less useful, way in which to use Ledger +within an org file is to use a single source block to record all Ledger +entries. The following is an example source block: +@smallexample +#+srcname: allinone +#+begin_src ledger +2010/01/01 * Starting balance + assets:bank:savings £1300.00 + income:starting balances +2010/07/22 * Got paid + assets:bank:chequing £1000.00 + income:salary +2010/07/23 Rent + expenses:rent £500.00 + assets:bank:chequing +2010/07/24 Food + expenses:food £150.00 + assets:bank:chequing +2010/07/31 * Interest on bank savings + assets:bank:savings £3.53 + income:interest +2010/07/31 * Transfer savings + assets:bank:savings £250.00 + assets:bank:chequing +2010/08/01 got paid again + assets:bank:chequing £1000.00 + income:salary +#+end_src +@end smallexample +In this example, we have combined both expenses and income into one set +of Ledger entries. We can now generate register and balance reports (as +well as many other types of reports) using babel to invoke Ledger with +specific arguments. The arguments are passed to Ledger using the +:cmdline header argument. In the code block above, there is no such +argument so the system takes the default. For Ledger code blocks, the +default :cmdline argument is bal and the result of evaluating this code +block (@command{C-c C-c}) would be: +@smallexample +#+results: allinone() +: £2653.53 assets +: £650.00 expenses +: £-3303.53 income +@end smallexample +If, instead, you wished to generate a register of all the transactions, +you would change the #+begin_src line for the code block to include the +required command line option: +@smallexample +#+begin_src ledger :cmdline reg +@end smallexample +Evaluating the code block again would generate a different report. + +Having to change the actual directive on the code block and re-evaluate +makes it difficult to have more than one view of your transactions and +financial state. Eventually, babel will support passing arguments to +#+call evaluations of code blocks but this support is missing +currently. Instead, we can use the concepts of literary programming, as +implemented by the noweb features of babel, to help us. + +@unnumberedsubsubsec Multiple Ledger source blocks with noweb + +The noweb feature of babel allows us to expand references to other code +blocks within a code block. For Ledger, this can be used to group +transactions according to type, say, and then bring various sets of +transactions together to generate reports. + +Using the same transactions used above, we could consider splitting +these into expenses and income, as follows: +@unnumberedsubsubsec Income Entries + +The first set of entries relates to income, either monthly pay or +interest, all typically going into one of my bank accounts. Here, I have +placed several entries, but we could have had each entry in a separate +src block. Note that all code blocks you wish to refer to later must +have the :noweb yes babel header argument specified. +@smallexample +#+srcname: income +#+begin_src ledger :noweb yes +2010/01/01 * Starting balance + assets:bank:savings £1300.00 + income:starting balances +2010/07/22 * Got paid + assets:bank:chequing £1000.00 + income:salary +2010/07/31 * Interest on bank savings + assets:bank:savings £3.53 + income:interest +2010/07/31 * Transfer savings + assets:bank:savings £250.00 + assets:bank:chequing +2010/08/01 got paid again + assets:bank:chequing £1000.00 + income:salary +#+end_src +@end smallexample +@unnumberedsubsubsec Expenses + +The following entries relate to personal expenses, such as rent and +food. Again, these have all been placed in a single src block but could +have been done individually. +@smallexample +#+srcname: expenses +#+begin_src ledger :noweb yes +2010/07/23 Rent + expenses:rent £500.00 + assets:bank:chequing +2010/07/24 Food + expenses:food £150.00 + assets:bank:chequing +#+end_src +@end smallexample + +@unnumberedsubsubsec Financial Summaries + +Given the ledger entries defined above in the income and expenses code +blocks, we can now refer to these using the noweb expansion directives, +<<name>>. We can now define different code blocks to generate specific +reports for those transactions. Below are two examples, one to generate +a balance report and one to generate a register report of all +transactions. +@unnumberedsubsubsec An overall balance summary + +The overall balance of your account and expenditure with a breakdown +according to category is specified by passing the :cmdline bal argument +to Ledger. This code block can now be evaluated (C-c C-c) and the +results generated by incorporating the transactions referred to by the +<<income>> and <<expenses>>= lines. +@smallexample +#+srcname: balance +#+begin_src ledger :cmdline bal :noweb yes +<<income>> +<<expenses>> +#+end_src + +#+results: balance +: £2653.53 assets +: £650.00 expenses +: £-3303.53 income +@end smallexample + +If you want a more detailed breakdown of where your money is and where +it has been spent, you can specify the -s flag (i.e. :cmdline -s bal) to +tell Ledger to include sub-accounts in the report. + +@smallexample +#+begin_src ledger :cmdline -s bal :noweb yes +<<income>> +<<expenses>> +#+end_src + +#+results: +: £2653.53 assets:bank +: £1100.00 chequing +: £1553.53 savings +: £650.00 expenses +: £150.00 food +: £500.00 rent +: £-3303.53 income +: £-3.53 interest +: £-2000.00 salary +: £-1300.00 starting balances +@end smallexample +@unnumberedsubsubsec Generating a monthly register + +You can also generate a monthly register (the reg command) by executing +the following src block. This presents a summary of transactions for +each monthly period (the -M argument) with a running total in the final +column (which should be 0 at the end if all the entries are correct). + +@smallexample +#+srcname: monthlyregister +#+begin_src ledger :cmdline -M reg :noweb yes +<<income>> +<<expenses>> +#+end_src + +#+results: monthlyregister +:2010/01/01 - 2010/01/31 assets:bank:savings £1300.00 £1300.00 +: in:starting balances £-1300.00 0 +:2010/07/01 - 2010/07/31 assets:bank:chequing £100.00 £100.00 +: assets:bank:savings £253.53 £353.53 +: expenses:food £150.00 £503.53 +: expenses:rent £500.00 £1003.53 +: income:interest £-3.53 £1000.00 +: income:salary £-1000.00 0 +:2010/08/01 - 2010/08/01 assets:bank:chequing £1000.00 £1000.00 +: income:salary £-1000.00 0 +@end smallexample + +We could also generate a monthly report on our assets showing how these +are increasing (or decreasing!). In this case, the final column will be +the running total of the assets in our ledger. + +@smallexample +#+srcname: monthlyassetsregister +#+begin_src ledger :cmdline -M reg assets :noweb yes +<<income>> +<<expenses>> +#+end_src + +#+results: monthlyassetsregister +: 2010/01/01 - 2010/01/31 assets:bank:savings £1300.00 £1300.00 +: 2010/07/01 - 2010/07/31 assets:bank:chequing £100.00 £1400.00 +: assets:bank:savings £253.53 £1653.53 +: 2010/08/01 - 2010/08/01 assets:bank:chequing £1000.00 £2653.53 +@end smallexample + +@unnumberedsubsubsec Summary + +This short tutorial shows how Ledger entries can be embedded in a org +file and manipulated using Babel. However, only simple Ledger features +have been illustrated; please refer to the Ledger documentation for +examples of more complex integrations with a ledger. + @node pricemap, xml, org, Reports in other formats @subsection pricemap |