diff options
Diffstat (limited to 'doc')
-rw-r--r-- | doc/ledger3.texi | 67 |
1 files changed, 60 insertions, 7 deletions
diff --git a/doc/ledger3.texi b/doc/ledger3.texi index 5436f189..ff5428ed 100644 --- a/doc/ledger3.texi +++ b/doc/ledger3.texi @@ -392,6 +392,7 @@ $ ledger -f drewr3.dat balance Assets Liabilities @findex register (reg) To show all transactions and a running total: + @smallexample ledger -f drewr3.dat register @end smallexample @@ -1335,6 +1336,7 @@ will give an error and stop calculating.} @section Starting up @cindex initial equity @cindex beginning ledger +@cindex opening balance Unless you have recently arrived from another planet, you already have a financial state. You need to capture that financial state so that @@ -1346,7 +1348,6 @@ basis of the opening entry for ledger. For example if you chose the beginning of 2011 as the date to start tracking finances with ledger, your opening balance entry could look like this: -@cindex opening balance @smallexample 2011/01/01 * Opening Balance Assets:Joint Checking $800.14 @@ -1427,8 +1428,8 @@ comment} @end smallexample There are several forms of comments within a transaction, for example: -@smallexample +@smallexample ; this is a global comment that is not applied to a specific transaction ; it can start with any of the five characters but is not included in the ; output from 'print' or 'output' @@ -1491,6 +1492,7 @@ Euros. The implied exchange rate was $1.32. Then 35.00 Euros was spent on Dinner in Munich. Running a ledger balance report shows: + @smallexample $ ledger -f example.dat bal $-66.00 @@ -1549,8 +1551,10 @@ convention is as follows: Expenses:Broker:Commissions $19.95 Assets:Broker $-1,500.00 @end smallexample + This assumes you have a brokerage account that is capable of managed both liquid and commodity assets. Now, on the day of the sale: + @smallexample 2005/08/01 Stock sale Assets:Broker -50 APPL @{$30.00@} @@ $50.00 @@ -1585,6 +1589,7 @@ time, you also want other kinds of commodities --- like stocks --- reported in terms of today's price. This is supported as follows: + @smallexample 2009/01/01 Shell Expenses:Gasoline 11 GAL @{=$2.299@} @@ -1608,8 +1613,10 @@ from the transaction above): Expenses:Gasoline 11 GAL @@ $2.299 Assets:Checking @end smallexample + There is no difference in meaning between these two forms. Why do both exist, you ask? To support things like this: + @smallexample 2009/01/01 Shell Expenses:Gasoline 11 GAL @{=$2.299@} @@ $2.30 @@ -1752,7 +1759,6 @@ amount using the @code{(( ))} commodity annotation. Assets:Cash9 @end smallexample - @smallexample ledger reg -V food 12-Mar-02 KFC Expenses:Food2 2 EUR 2 EUR @@ -1864,6 +1870,7 @@ the syntax @code{[ACTUAL_DATE]} or @code{[=EFFECTIVE_DATE]} or Specifies a historical price for a commodity. These are usually found in a pricing history file (see the @code{-Q} option). The syntax is: + @smallexample P DATE SYMBOL PRICE @end smallexample @@ -1979,8 +1986,8 @@ until and @code{end apply account} directive was found. @c instance_t::alias_directive Define an alias for an account name. If you have a deeply nested tree of accounts, it may be convenient to define an alias, for example: -@smallexample +@smallexample alias Dining=Expenses:Entertainment:Dining alias Checking=Assets:Credit Union:Joint Checking Account @@ -2048,10 +2055,9 @@ A check can issue a warning if a condition is not met during Ledger's run. @smallexample - check <VALUE EXPRESSION BOOLEAN RESULT> - @end smallexample + @item comment @c instance_t::comment_directive in textual.cc Start a block comment, closed by @code{end comment}. @@ -2091,6 +2097,7 @@ The @code{default} directive marks this as the ``default'' commodity. @item define @c instance_t::define_directive in textual.cc Allows you to define value expression for future use. For example: + @smallexample define var_name=$100 @@ -2114,6 +2121,7 @@ for a series of transactions. It's purely a typing saver, for use when entering many transactions with fixated prices. Thus, the following: + @smallexample fixed CAD $0.90 2012-04-10 Lunch in Canada @@ -2125,7 +2133,9 @@ fixed CAD $0.90 Expenses:Food 25.75 CAD endfixed @end smallexample + is equivalent to this: + @smallexample 2012-04-10 Lunch in Canada Assets:Wallet -15.50 CAD @{=$0.90@} @@ -2174,6 +2184,7 @@ Ledger will display the mapped payees in @code{print} and @c instance_t::tag_directive in textual.cc Allows you to designate a block of transactions and assign the same tag to all. Tags can have values and may be nested. + @smallexample apply tag hastag apply tag nestedtag: true @@ -2279,6 +2290,7 @@ symbol, nor will quotes ever be downloaded for that symbol. Useful with a home currency, such as the dollar ($). It is recommended that these pricing options be set in the price database file, which defaults to @file{~/.pricedb}. The syntax for this command is: + @smallexample N SYMBOL @end smallexample @@ -2292,6 +2304,7 @@ different commodities; whichever is seen last is used as the default commodity. For example, to set US dollars as the default commodity, while also setting the thousands flag and decimal flag for that commodity, use: + @smallexample D $1,000.00 @end smallexample @@ -2300,6 +2313,7 @@ D $1,000.00 Specifies a commodity conversion, where the first amount is given to be equivalent to the second amount. The first amount should use the decimal precision desired during reporting: + @smallexample C 1.00 Kb = 1024 bytes @end smallexample @@ -3866,6 +3880,7 @@ actual balances. For the three instruments listed above, those automatic transactions would look like: + @smallexample ; ; automatic calculations for asset allocation tracking @@ -4149,7 +4164,6 @@ transaction as meta data if it doesn't recognize the field name. For example, if you want to capture the bank transaction number and it occurs in the first column of the data use: - @smallexample transid,date,payee,note,amount,,,code, @end smallexample @@ -4303,6 +4317,7 @@ The first two are described in more detail in this short tutorial. 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 #+name: allinone #+begin_src ledger @@ -4329,6 +4344,7 @@ entries. The following is an example source block: 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 @@ -4337,18 +4353,22 @@ specific arguments. The arguments are passed to Ledger using the 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 @@ -4375,6 +4395,7 @@ 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 #+name: income #+begin_src ledger :noweb yes @@ -4401,6 +4422,7 @@ have the :noweb yes babel header argument specified. 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 #+name: expenses #+begin_src ledger :noweb yes @@ -5036,6 +5058,7 @@ Specify the location of the init file. The default is @file{~/.ledgerrc} @item --options Display the options in effect for this Ledger invocation, along with their values and the source of those values, for example: + @smallexample 14:15:02 > ledger --options bal --cleared -f ~/ledger/test/input/drewr3.dat =============================================================================== @@ -5106,6 +5129,7 @@ information. @item --input-date-format <DATE-FORMAT> Specify the input date format for journal entries. For example, + @smallexample ledger convert Export.csv --input-date-format "%m/%d/%Y" @end smallexample @@ -5117,6 +5141,7 @@ Format Codes}). @item --master-account <STRING> Prepend all account names with the argument. + @smallexample 21:51:39 ~/ledger (next)> ledger -f test/input/drewr3.dat bal --master-account HUMBUG 0 HUMBUG @@ -5225,6 +5250,7 @@ instead of running totals. @item --balance-format <STR> Specify the format to use for the @code{balance} report (@pxref{Format Strings}). The default is: + @smallexample "%(justify(scrub(display_total), 20, -1, true, color))" " %(!options.flat ? depth_spacer : \"\")" @@ -5258,6 +5284,7 @@ posting greater than $100 @item --budget-format <FORMAT_STRING> Specify the format to use for the @code{budget} report (@pxref{Format Strings}). The default is: + @smallexample "%(justify(scrub(display_total), 20, -1, true, color))" " %(!options.flat ? depth_spacer : \"\")" @@ -5317,6 +5344,7 @@ appended to the commodities, accounts or payees command. @item --csv-format Specify the format to use for the @code{csv} report (@pxref{Format Strings}). The default is: + @smallexample "%(quoted(date))," "%(quoted(code))," @@ -5353,6 +5381,7 @@ ASK JOHN Display register or balance in debit/credit format If you use @code{--dc} with either the register (reg) or balance (bal) commands, you will now get extra columns. The register goes from this: + @smallexample 12-Mar-10 Employer Assets:Cash $100 $100 Income:Employer $-100 0 @@ -5431,6 +5460,7 @@ Apply a transform to the @item --dow group transactions by the day of the week. + @smallexample ledger reg Expenses --dow --collapse @end smallexample @@ -5498,6 +5528,7 @@ also useful here. Set the format for the headers that separate reports section of a grouped report. Only has effect with a @code{--group-by} register report. + @smallexample ledger reg Expenses --group-by "payee" --group-title-format "------------------------ %-20(value) ---------------------\n" ------------------------ 7-Eleven --------------------- @@ -5519,6 +5550,7 @@ Print the first @code{INT} entries. Opposite of @code{--tail}. Use @code{Expected} amounts in calculations. In the case that you know that amount a transaction should be, but the actual transaction has the wrong value you can use metadata to put in the expected amount: + @smallexample 2012-03-12 Paycheck Income $-990; Expected:: $-1000.00 @@ -5624,6 +5656,7 @@ if you have multiple cars and track each fuel purchase in @code{Expenses:Auto:Fuel} and tag each fuel purchase with a tag identifying which car the purchase was for @code{; Car: Prius}, then the command: + @smallexample ledger bal Fuel --pivot "Car" --period "this year" $ 3491.26 Car @@ -6127,6 +6160,7 @@ each report type: @item --balance-format STR Define the output format for the @code{balance} report. The default (defined in @code{report.h} is: + @smallexample "%(ansify_if( justify(scrub(display_total), 20, @@ -6143,6 +6177,7 @@ Define the output format for the @code{balance} report. The default @item --cleared-format Define the format for the cleared report. The default is: + @smallexample "%(justify(scrub(get_at(display_total, 0)), 16, 16 + int(prepend_width), true, color)) %(justify(scrub(get_at(display_total, 1)), 18, @@ -6158,6 +6193,7 @@ Define the format for the cleared report. The default is: @item --register-format STR Define the output format for the @code{register} report. The default (defined in @code{report.h} is: + @smallexample "%(ansify_if( ansify_if(justify(format_date(date), int(date_width)), @@ -6191,8 +6227,10 @@ Define the output format for the @code{register} report. The default bold if should_bold)) %$3 %$4 %$5\n" @end smallexample + @item --csv-format Set the format for @code{csv} reports. The default is: + @smallexample "%(quoted(date)), %(quoted(code)), @@ -6207,6 +6245,7 @@ Set the format for @code{csv} reports. The default is: @item --plot-amount-format STR Set the format for amount plots, using the @code{-j} option. The default is: + @smallexample "%(format_date(date, \"%Y-%m-%d\")) %(quantity(scrub(display_amount)))\n" @end smallexample @@ -6214,18 +6253,21 @@ default is: @item --plot-total-format STR Set the format for total plots, using the @code{-J} option. The default is: + @smallexample "%(format_date(date, \"%Y-%m-%d\")) %(quantity(scrub(display_total)))\n" @end smallexample @item --pricedb-format STR Set the format expected for the historical price file. The default is + @smallexample "P %(datetime) %(display_account) %(scrub(display_amount))\n" @end smallexample @item --prices-format STR Set the format for the @command{prices} report. The default is: + @smallexample "%(date) %-8(display_account) %(justify(scrub(display_amount), 12, 2 + 9 + 8 + 12, true, color))\n" @@ -6325,6 +6367,7 @@ follows: = expr true ; VALUE:: market(amount, date, exchange) @end smallexample + This definition emulates the present day behavior of @code{-V} and @code{-X} (in the case of @code{-X}, the requested commodity is passed via the string 'exchange' above). @@ -7938,6 +7981,7 @@ In the simplest form, bare decimal numbers are accepted: Assets:Checking 1000.00 Income:Salary @end smallexample + @cindex uncommoditized amounts Such amounts may only use an optional period for a decimal point. These are referred to as @dfn{integer amounts} or @dfn{uncommoditized @@ -8228,6 +8272,7 @@ will work. @table @code @item args Evaluate the given arguments against the following model transaction: + @smallexample 2004/05/27 Book Store ; This note applies to all postings. :SecondTag: @@ -8238,22 +8283,29 @@ Evaluate the given arguments against the following model transaction: ; Here follows a note describing the posting. Liabilities:MasterCard $-200.00 @end smallexample + @item eval Evaluate the given value expression against the model transaction + @item expr "LIMIT EXPRESSION" Print details of how ledger parses the given limit expression and apply it against a model transaction. + @item format "FORMATTING" Print details of how ledger uses the given formatting description and apply it against a model transaction. + @item generate Randomly generates syntactically valid Ledger data from a seed. Used by the GenerateTests harness for development testing + @item parse <VALUE EXPR> Print details of how ledger uses the given value expression description and apply it against a model transaction. + @item period Evaluate the given period and report how Ledger interprets it: + @smallexample 20:22:21 ~/ledger (next)> ledger period "this year" --- Period expression tokens --- @@ -8312,6 +8364,7 @@ the model transaction: --- Calculated value --- true @end smallexample + @item template Shows the insertion template that a @code{draft} or @code{xact} sub-command generates. This is a debugging command. |