diff options
author | thdox <thdox@free.fr> | 2013-04-16 22:49:32 +0200 |
---|---|---|
committer | thdox <thdox@free.fr> | 2013-04-16 22:49:32 +0200 |
commit | d669cc43b5c935192de5d1ede1cc51820d821894 (patch) | |
tree | bafbcd9663d4304c9f1c7a643709a63c5545c564 /doc/ledger3.texi | |
parent | e69129a2464a0b536714e7a751585d1b12367adc (diff) | |
download | fork-ledger-d669cc43b5c935192de5d1ede1cc51820d821894.tar.gz fork-ledger-d669cc43b5c935192de5d1ede1cc51820d821894.tar.bz2 fork-ledger-d669cc43b5c935192de5d1ede1cc51820d821894.zip |
delete trailing whitespaces
Diffstat (limited to 'doc/ledger3.texi')
-rw-r--r-- | doc/ledger3.texi | 306 |
1 files changed, 153 insertions, 153 deletions
diff --git a/doc/ledger3.texi b/doc/ledger3.texi index 5ff99450..c95330d4 100644 --- a/doc/ledger3.texi +++ b/doc/ledger3.texi @@ -115,7 +115,7 @@ fat. Think of it as the Bran Muffin of accounting tools. To use it, you need to start keeping a journal. This is the basis of all accounting, and if you haven't started yet, now is the time to learn. The little booklet that comes with your checkbook is a journal, -so we'll describe double-entry accounting in terms of that. +so we'll describe double-entry accounting in terms of that. @c If you use @c another GUI accounting program like GNUCash, the vast majority of its @@ -433,7 +433,7 @@ $ ledger -f drewr3.dat register Groceries @noindent Which matches the balance reported for the @code{Groceries} account: @smallexample -$ ledger -f drewr3.dat balance Groceries +$ ledger -f drewr3.dat balance Groceries $ 334.00 Expenses:Food:Groceries @end smallexample @@ -460,7 +460,7 @@ a check to clear, but you should treat it as money spent. The not format correctly for accounts that contain multiple commodities): @smallexample -$ ledger -f drewr3.dat cleared +$ ledger -f drewr3.dat cleared $ -3,804.00 $ 775.00 Assets $ 1,396.00 $ 775.00 10-Dec-20 Checking $ 30.00 0 Business @@ -515,7 +515,7 @@ Accounting is simply tracking your money. It can range from nothing, and just waiting for automatic overdraft protection to kick in, or not, to a full blown double entry accounting system. Ledger accomplishes the latter. With ledger you can handle your personal finances or your -businesses. Double-entry accounting scales. +businesses. Double-entry accounting scales. @cindex double-entry accounting @node Stating where money goes, Assets and Liabilities, Accounting with Ledger, Principles of Accounting @@ -929,7 +929,7 @@ will indicate that fifty minutes remain: 2005/10/01 Work done for company Billable:Client 1h Project:XYZ - + 2005/10/02 Return ten minutes to the project Project:XYZ 10m Billable:Client @@ -1333,7 +1333,7 @@ your opening balance entry could look like this: There is nothing special about the name ``Opening Balances'' as the payee of the account name, anything convenient that you understand will -work. +work. @node Structuring Your Accounts, Commenting on your journal, Starting up, Keeping a Journal @section Structuring your Accounts @@ -1346,16 +1346,16 @@ system. At the highest level you have five sorts of accounts: @enumerate -@item +@item Expenses: where money goes -@item +@item Assets: where money sits @item Income: where money comes from @item Liabilities: money you owe -@item -Equity: the real value of your property. +@item +Equity: the real value of your property. @end enumerate Starting the structure off this way will make it simpler for you to get @@ -1398,7 +1398,7 @@ There are several forms of comments within a transaction, for example: @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 +; it can start with any of the five characters but is not included in the ; output from 'print' or 'output' 2011/12/11 Something Sweet @@ -1410,7 +1410,7 @@ There are several forms of comments within a transaction, for example: @noindent The first comment is global and Ledger will not attach it to any specific transactions. The comments within the transaction must all start with `;'s and are -preserved as part of the transaction. The `:'s indicate meta-data and tags +preserved as part of the transaction. The `:'s indicate meta-data and tags (@pxref{Metadata}). @node Currency and Commodities, Keeping it Consistent, Commenting on your journal, Keeping a Journal @@ -1458,7 +1458,7 @@ in Munich. Running a ledger balance report shows: @smallexample -$ ledger -f example.dat bal +$ ledger -f example.dat bal $-66.00 E15.00 Assets E15.00 Cash @@ -1494,7 +1494,7 @@ be enclosed in double quotes: 2000/12/08 ! Achat Actif:SG PEE STK 215.796 "Arcancia Equilibre 455" - Actif:SG PEE STK $-10742.54 + Actif:SG PEE STK $-10742.54 @end smallexample @@ -1514,7 +1514,7 @@ you made the purchase in ($ for AAPL). Yes, the typical 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 +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 @@ -1554,8 +1554,8 @@ This is supported as follows: Assets:Checking @end smallexample -This transaction actually introduces a new commodity, ``GAL @{=$2.29@}'', -whose market value disregards any future changes in the price of +This transaction actually introduces a new commodity, ``GAL @{=$2.29@}'', +whose market value disregards any future changes in the price of gasoline. If you do not want price fixing, you can specify this same transaction @@ -1571,7 +1571,7 @@ 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 +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 @@ -1579,11 +1579,11 @@ both exist, you ask? To support things like this: Assets:Checking @end smallexample -This transaction says that you bought 11 gallons priced at $2.299 per -gallon at a @strong{cost to you} of $2.30 per gallon. Ledger auto-generates -a balance posting in this case to Equity:Capital Losses to reflect the -1.1 cent difference, which is then balanced by Assets:Checking because -its amount is null. +This transaction says that you bought 11 gallons priced at $2.299 per +gallon at a @strong{cost to you} of $2.30 per gallon. Ledger auto-generates +a balance posting in this case to Equity:Capital Losses to reflect the +1.1 cent difference, which is then balanced by Assets:Checking because +its amount is null. @node Complete control over commodity pricing, , Fixing Lot Prices, Currency and Commodities @subsection Complete control over commodity pricing @@ -1614,7 +1614,7 @@ A valuation function receives three arguments: (example: "EUR") @item date The reference date the price should be relative. -@item target +@item target A string identifying the ``target'' commodity, or the commodity the returned price should be in. This argument is null if @code{--market} was used instead of @code{--exchange}. @@ -1836,7 +1836,7 @@ postings, just as if it were normal transaction. A line beginning with a colon, pound, percent, bar or asterisk indicates a comment, and is ignored. Comments will not be returned in a ``print'' response. -@item indented ; +@item indented ; If the semi colon is indented and occurs inside a transaction, it is parsed as a persistent note for its preceding category. These notes or tags can be used to augment the reporting and filtering capabilities of @@ -1928,7 +1928,7 @@ of accounts, it may be convenient to define an alias, for example: alias Dining=Expenses:Entertainment:Dining alias Checking=Assets:Credit Union:Joint Checking Account -2011/11/28 YummyPalace +2011/11/28 YummyPalace Dining $10.00 Checking @@ -1939,7 +1939,7 @@ is defined and are effected by @code{account} directives that precede them. @item assert @c instance_t::assert_directive -An assertion can throw an error if a condition is not met during Ledger's run. +An assertion can throw an error if a condition is not met during Ledger's run. @smallexample @@ -1990,7 +1990,7 @@ Ledger will display the mapped payees in @code{print} and @item check @c instance_t::check_directive in textual.cc -A check can issue a warning if a condition is not met during Ledger's run. +A check can issue a warning if a condition is not met during Ledger's run. @smallexample @@ -2206,7 +2206,7 @@ alone, for backwards compatibility with older Ledger versions. @table @code @item A See @code{bucket} -@item Y +@item Y See @code{year} @@ -3117,18 +3117,18 @@ using a lambda expression taking three arguments: The arguments passed to these functions have the following meaning: @itemize -@item source +@item source The source commodity string, or an amount object. If it is a string, the return value must be an amount representing the price of the commodity identified by that string (example: ``$''). If it is an amount, return the value of that amount as a new amount (usually calculated as commodity price times source amount). -@item date +@item date The date to use for determining the value. If null, it means no date was specified, which can mean whatever you want it to mean. -@item target +@item target If not null, a string representing the desired target commodity that the commodity price, or repriced amount, should be valued in. Note that this string can be a comma-separated list, and @@ -3399,7 +3399,7 @@ even though you've already paid for them. Expenses:Food:Groceries $ 37.50 ; [=2009/01/01] Expenses:Food:Groceries $ 37.50 ; [=2009/02/01] Expenses:Food:Groceries $ 37.50 ; [=2009/03/01] - Assets:Checking + Assets:Checking @end smallexample This entry accomplishes this. Every month until you'll start with an @@ -3531,7 +3531,7 @@ The balance report is the most commonly used report. The simplest invocation is @smallexample ledger balance -f drewr3.dat @end smallexample -@noindent which will print the balances of every account in your journal. +@noindent which will print the balances of every account in your journal. @smallexample $ -3,804.00 Assets @@ -3599,7 +3599,7 @@ account on a particular payee, the following are equivalent: > ledger balance Auto:Fuel and Chevron > ledger balance --limit "(account=~/Fuel/) & (payee=~/Chev/)" @end smallexample -@noindent will show you the amount expended on gasoline at Chevron. +@noindent will show you the amount expended on gasoline at Chevron. The second example is the first example of the very power expression language available to shape reports. The first example may be easier to remember, but learning to use the second will open up far more @@ -3736,7 +3736,7 @@ would look like: @smallexample ; ; automatic calculations for asset allocation tracking -; +; = expr ( commodity == 'VIFSX' ) (Allocation:Equities:Domestic) 1.000 @@ -3767,7 +3767,7 @@ current allocation? Using the balance command and some tricky formatting! ledger bal Allocation --current --format "\ %-17((depth_spacer)+(partial_account))\ %10(percent(market(display_total), market(parent.total)))\ - %16(market(display_total))\n%/" + %16(market(display_total))\n%/" @end smallexample @noindent Which yields: @@ -4131,22 +4131,22 @@ include Ledger entries within an org file. There are three ways (at least) in which these can be included: @enumerate -@item +@item place all Ledger entries within one source block and execute this block with different arguments to generate the appropriate reports; -@item +@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 +@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. +The first two are described in more detail in this short tutorial. @subsubheading Embedded Ledger example with single source block @@ -4639,7 +4639,7 @@ El Dorade Restaurant My Big Fat Greek Restaurant Target macbook-2:$ -@end smallexample +@end smallexample @@ -4737,7 +4737,7 @@ commands. @item @code{-i FILE} @tab @code{--init-file FILE} @tab specify options file @item @code{-a NAME} @tab @code{--account NAME} @tab specify default account name for QIF file postings @end multitable - + @node Report Filtering Quick Reference, Error Checking and Calculation Options, Basic Options Quick Reference, Command Line Quick Reference @subsection Report Filtering @multitable @columnfractions .1 .25 .65 @@ -4862,7 +4862,7 @@ instance of Ledger running in the background and running multiple sessions with multiple reports per session. @table @code -@item --args-only +@item --args-only Ignore all environment and init-file settings and use only command-line arguments to control Ledger. Useful for debugs or testing small Journal files not associated with you main financial @@ -4878,7 +4878,7 @@ Specifies the location of the init file. The default is @file{~/.ledgerrc} 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 +14:15:02 > ledger --options bal --cleared -f ~/ledger/test/input/drewr3.dat =============================================================================== [Global scope options] @@ -4938,7 +4938,7 @@ Direct Ledger to download prices using the script defined in Specify the input file path for this invocation. @cindex getquote -@cindex download prices +@cindex download prices @item --getquote <PATH> Tells ledger where to find the user defined script to download prices information. @@ -5266,7 +5266,7 @@ group transactions by the day of the week. @smallexample ledger reg Expenses --dow --collapse @end smallexample -@noindent will print all Expenses totaled for each day of the week. +@noindent will print all Expenses totaled for each day of the week. @item --effective @@ -5314,7 +5314,7 @@ Forecast at most @code{N} years in the future. @item --format <FORMAT STRING> -use the given format string to print output. +use the given format string to print output. @item --gain @@ -5638,30 +5638,30 @@ want to set them using environment variables (see @ref{Environment Variables}), instead of using actual command-line options: @table @code -@item --help +@item --help @item -h Prints a summary of all the options, and what they are used for. This can be a handy way to remember which options do what. This help screen is also printed if ledger is run without a command. -@item --version +@item --version @item -v prints the current version of ledger and exits. This is useful for sending bug reports, to let the author know which version of ledger you are using. -@item --file FILE +@item --file FILE @item -f FILE reads FILE as a ledger file. This command may be used multiple times. Typically, the environment variable @env{LEDGER_FILE} is set, rather than using this command-line option. -@item --output FILE +@item --output FILE @item -o FILE redirects output from any command to @var{FILE}. By default, all output goes to standard output. -@item --init-file FILE +@item --init-file FILE @item -i FILE causes @code{FILE} to be read by ledger before any other ledger file. This file may not contain any postings, but it may contain option settings. @@ -5679,7 +5679,7 @@ Option settings on the command-line or in the environment always take precedence over settings in the init file. -@item --account NAME +@item --account NAME @item -a NAME specifies the default account which QIF file postings are assumed to relate to. @@ -5697,7 +5697,7 @@ report, in ways other than just using regular expressions: displays only transactions occurring on or before the current date. @item --begin DATE -@item -b DATE +@item -b DATE constrains the report to transactions on or after @var{DATE}. Only transactions after that date will be calculated, which means that the running total in the balance report will always start at zero with the @@ -5710,7 +5710,7 @@ constrains the report so that transactions on or after @var{DATE} are not considered. The ending date is inclusive. @item --period STR -@item -p STR +@item -p STR sets the reporting period to @var{STR}. This will subtotal all matching transactions within each period separately, making it easy to see weekly, monthly, quarterly, etc., posting totals. A period string can @@ -5919,7 +5919,7 @@ tells Ledger to pass its output to the given pager program; very useful when the output is especially long. This behavior can be made the default by setting the @env{LEDGER_PAGER} environment variable. -@item --average +@item --average @item -A reports the average posting value. @@ -6006,8 +6006,8 @@ Define the output format for the @code{balance} report. The default (defined in @item --cleared-format Defines 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, + "%(justify(scrub(get_at(display_total, 0)), 16, 16 + int(prepend_width), + true, color)) %(justify(scrub(get_at(display_total, 1)), 18, 36 + int(prepend_width), true, color)) %(latest_cleared ? format_date(latest_cleared) : \" \") %(!options.flat ? depth_spacer : \"\") @@ -6024,29 +6024,29 @@ Define the output format for the @code{register} report. The default (defined i green if color and date > today), bold if should_bold)) %(ansify_if( - ansify_if(justify(truncated(payee, int(payee_width)), int(payee_width)), + ansify_if(justify(truncated(payee, int(payee_width)), int(payee_width)), bold if color and !cleared and actual), bold if should_bold)) %(ansify_if( - ansify_if(justify(truncated(display_account, int(account_width), + ansify_if(justify(truncated(display_account, int(account_width), int(abbrev_len)), int(account_width)), blue if color), bold if should_bold)) %(ansify_if( - justify(scrub(display_amount), int(amount_width), + justify(scrub(display_amount), int(amount_width), 3 + int(meta_width) + int(date_width) + int(payee_width) + int(account_width) + int(amount_width) + int(prepend_width), true, color), bold if should_bold)) %(ansify_if( - justify(scrub(display_total), int(total_width), + justify(scrub(display_total), int(total_width), 4 + int(meta_width) + int(date_width) + int(payee_width) + int(account_width) + int(amount_width) + int(total_width) + int(prepend_width), true, color), bold if should_bold))\n%/ %(justify(\" \", int(date_width))) %(ansify_if( - justify(truncated(has_tag(\"Payee\") ? payee : \" \", + justify(truncated(has_tag(\"Payee\") ? payee : \" \", int(payee_width)), int(payee_width)), bold if should_bold)) %$3 %$4 %$5\n" @@ -6068,7 +6068,7 @@ Sets 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 -@item --plot-total-format STR +@item --plot-total-format STR Sets 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" @@ -6082,7 +6082,7 @@ Sets the format expected for the historical price file. The default is @item --prices-format STR Sets the format for the @command{prices} report. The default is: @smallexample -"%(date) %-8(display_account) %(justify(scrub(display_amount), 12, +"%(date) %-8(display_account) %(justify(scrub(display_amount), 12, 2 + 9 + 8 + 12, true, color))\n" @end smallexample @item --wide-register-format STR @@ -6246,8 +6246,8 @@ another currency. For example: @smallexample = /^Assets:Brokerage:CAD$/ - ; Always report the value of commodities in this account in - ; terms of present day dollars, despite what was asked for + ; Always report the value of commodities in this account in + ; terms of present day dollars, despite what was asked for ; on the command-line VALUE:: market(amount, date, '$') @end smallexample @@ -6535,7 +6535,7 @@ In the matching criteria used by automated postings. @end enumerate Value expressions support most simple math and logic operators, in -addition to a set of functions and variables. +addition to a set of functions and variables. @c A function's @c argument is whatever follows it. The following is a display predicate @@ -6738,7 +6738,7 @@ The binary and ternary operators, in order of precedence, are: @code{LOOKUP} @code{LAMBDA} @code{CALL} -@code{MATCH} +@code{MATCH} @node Complex Expressions, , Operators, Value Expressions @section Complex expressions @@ -6795,51 +6795,51 @@ Useful specifying a date in plain terms. For example, you could say @subsection Miscellaneous @multitable @columnfractions .3 .2 .5 @item @strong{Function} @tab @strong{Abbrev.} @tab @strong{Description} -@item @code{amount_expr } @tab @code{} @tab +@item @code{amount_expr } @tab @code{} @tab @item @code{abs } @tab @code{} @tab --> U @item @code{ceiling } @tab @code{} @tab Returns the next integer toward +infty @item @code{code} @tab @code{} @tab returns the transaction code, the string between the parenthesis after the date. -@item @code{commodity } @tab @code{} @tab +@item @code{commodity } @tab @code{} @tab @item @code{display_amount } @tab @code{} @tab --> t @item @code{display_total } @tab @code{} @tab --> T -@item @code{date } @tab @code{} @tab -@item @code{format_date } @tab @code{} @tab -@item @code{format } @tab @code{} @tab +@item @code{date } @tab @code{} @tab +@item @code{format_date } @tab @code{} @tab +@item @code{format } @tab @code{} @tab @item @code{floor } @tab @code{} @tab Returns the next integer toward -infty -@item @code{get_at } @tab @code{} @tab -@item @code{is_seq } @tab @code{} @tab -@item @code{justify } @tab @code{} @tab -@item @code{join } @tab @code{} @tab -@item @code{market --> P } @tab @code{} @tab -@item @code{null } @tab @code{} @tab -@item @code{now --> d m } @tab @code{} @tab -@item @code{options } @tab @code{} @tab -@item @code{post } @tab @code{} @tab -@item @code{percent } @tab @code{} @tab -@item @code{price } @tab @code{} @tab -@item @code{print } @tab @code{} @tab -@item @code{quoted } @tab @code{} @tab -@item @code{quantity } @tab @code{} @tab -@item @code{rounded } @tab @code{} @tab +@item @code{get_at } @tab @code{} @tab +@item @code{is_seq } @tab @code{} @tab +@item @code{justify } @tab @code{} @tab +@item @code{join } @tab @code{} @tab +@item @code{market --> P } @tab @code{} @tab +@item @code{null } @tab @code{} @tab +@item @code{now --> d m } @tab @code{} @tab +@item @code{options } @tab @code{} @tab +@item @code{post } @tab @code{} @tab +@item @code{percent } @tab @code{} @tab +@item @code{price } @tab @code{} @tab +@item @code{print } @tab @code{} @tab +@item @code{quoted } @tab @code{} @tab +@item @code{quantity } @tab @code{} @tab +@item @code{rounded } @tab @code{} @tab @item @code{roundto } @tab @code{} @tab Returns value rounded to n digits. Does not affect formatting. -@item @code{scrub } @tab @code{} @tab -@item @code{strip --> S } @tab @code{} @tab -@item @code{should_bold } @tab @code{} @tab -@item @code{truncated } @tab @code{} @tab -@item @code{total_expr } @tab @code{} @tab -@item @code{today } @tab @code{} @tab -@item @code{top_amount } @tab @code{} @tab -@item @code{to_boolean } @tab @code{} @tab -@item @code{to_int } @tab @code{} @tab -@item @code{to_datetime } @tab @code{} @tab -@item @code{to_date } @tab @code{} @tab -@item @code{to_amount } @tab @code{} @tab -@item @code{to_balance } @tab @code{} @tab -@item @code{to_spring } @tab @code{} @tab -@item @code{to_mask } @tab @code{} @tab -@item @code{to_sequence } @tab @code{} @tab -@item @code{unrounded } @tab @code{} @tab -@item @code{value_date } @tab @code{} @tab +@item @code{scrub } @tab @code{} @tab +@item @code{strip --> S } @tab @code{} @tab +@item @code{should_bold } @tab @code{} @tab +@item @code{truncated } @tab @code{} @tab +@item @code{total_expr } @tab @code{} @tab +@item @code{today } @tab @code{} @tab +@item @code{top_amount } @tab @code{} @tab +@item @code{to_boolean } @tab @code{} @tab +@item @code{to_int } @tab @code{} @tab +@item @code{to_datetime } @tab @code{} @tab +@item @code{to_date } @tab @code{} @tab +@item @code{to_amount } @tab @code{} @tab +@item @code{to_balance } @tab @code{} @tab +@item @code{to_spring } @tab @code{} @tab +@item @code{to_mask } @tab @code{} @tab +@item @code{to_sequence } @tab @code{} @tab +@item @code{unrounded } @tab @code{} @tab +@item @code{value_date } @tab @code{} @tab @end multitable @node Format Strings, Extending with Python, Value Expressions, Top @@ -6895,11 +6895,11 @@ is given, the substituted text will never be wider than this, and will be truncated to fit. Here are some examples: @table @code -@item %-20P +@item %-20P a transaction's payee, left justified and padded to 20 characters wide. -@item %20P +@item %20P The same, right justified, at least 20 chars wide -@item %.20P +@item %.20P The same, no more than 20 chars wide @end table @@ -7059,7 +7059,7 @@ terminal character colors and font highlights in a normal TTY session. @item @code{red} @tab @code{magenta} @tab @code{bold} @item @code{green } @tab @code{cyan} @tab @code{underline} @item @code{yellow } @tab @code{white} @tab @code{blink} -@item @code{blue } +@item @code{blue } @end multitable @@ -7092,7 +7092,7 @@ terminal character colors and font highlights in a normal TTY session. @item to_balance @item unrounded @end table - + @node Dates, Date and Time Format Codes, Quantities and Calculations, Formatting codes @subsection Date Functions The following functions allow you to manipulate and format dates. @@ -7128,7 +7128,7 @@ Dates are formed from a combination of day, month and year codes, in whatever order you prefer: @table @code -@item %Y +@item %Y Four digit year @item %y @@ -7228,7 +7228,7 @@ The following format functions allow you limited formatting of text: @item ansify_if(value, color) Surrounds the string representing value with ANSI codes to give it @code{color} on an TTY display. Has no effect if directed to a file. -@item justify(value, first_width, latter_width, right_justify, colorize) +@item justify(value, first_width, latter_width, right_justify, colorize) Right or left justify the string representing @code{value}. The width of the field in the first line is given by @code{first_width}. For subsequent lines the width is given by @code{latterwidth}. If @@ -7254,15 +7254,15 @@ regarding the coordinates of entries in the source data file(s) that generated the posting. @table @code -@item filename +@item filename name of ledger data file from whence posting came, abbreviated @code{S} -@item beg_pos +@item beg_pos character position in @code{filename} where entry for posting begins, abbreviated @code{B} -@item end_pos +@item end_pos character position in @code{filename} where entry for posting ends, abbreviated @code{E} -@item beg_line +@item beg_line line number in @code{filename} where entry for posting begins, abbreviated @code{b} -@item end_line +@item end_line line number in @code{filename} where posting's entry for posting ends, abbreviated @code{e} @end table @@ -7975,34 +7975,34 @@ If Ledger has been built with debug options this will provide extra data during the run. The following are the available arguments to debug: @multitable @columnfractions .32 .43 .27 -@item @code{account.display} @tab @code{expr.calc.when} @tab @code{org.next_amount} -@item @code{accounts.sorted} @tab @code{expr.compile} @tab @code{org.next_total} -@item @code{amount.convert} @tab @code{filters.changed_value} @tab @code{parser.error} -@item @code{amount.is_zero} @tab @code{filters.changed_value.rounding} @tab @code{pool.commodities} -@item @code{amount.parse} @tab @code{filters.collapse} @tab @code{post.assign} -@item @code{amount.price} @tab @code{filters.forecast} @tab @code{python.init} -@item @code{amount.truncate} @tab @code{filters.revalued} @tab @code{python.interp} -@item @code{amount.unround} @tab @code{format.abbrev} @tab @code{query.mask} -@item @code{amounts.commodities} @tab @code{format.expr} @tab @code{report.predicate} -@item @code{amounts.refs} @tab @code{generate.post} @tab @code{scope.symbols} -@item @code{archive.journal} @tab @code{generate.post.string} @tab @code{textual.include} -@item @code{auto.columns} @tab @code{item.meta} @tab @code{textual.parse} -@item @code{budget.generate} @tab @code{ledger.read} @tab @code{timelog} -@item @code{commodity.annotated.strip} @tab @code{ledger.validate} @tab @code{times.epoch} -@item @code{commodity.annotations} @tab @code{lookup} @tab @code{times.interval} -@item @code{commodity.compare} @tab @code{lookup.account} @tab @code{times.parse} -@item @code{commodity.download} @tab @code{mask.match} @tab @code{value.sort} -@item @code{commodity.prices.add} @tab @code{memory.counts} @tab @code{value.storage.refcount} -@item @code{commodity.prices.find} @tab @code{memory.counts.live} @tab @code{xact.extend} -@item @code{convert.csv} @tab @code{memory.debug} @tab @code{xact.extend.cleared} -@item @code{csv.mappings} @tab @code{op.cons} @tab @code{xact.extend.fail} -@item @code{csv.parse} @tab @code{op.memory} @tab @code{xact.finalize} -@item @code{draft.xact} @tab @code{option.args} -@item @code{expr.calc} @tab @code{option.names} -@end multitable +@item @code{account.display} @tab @code{expr.calc.when} @tab @code{org.next_amount} +@item @code{accounts.sorted} @tab @code{expr.compile} @tab @code{org.next_total} +@item @code{amount.convert} @tab @code{filters.changed_value} @tab @code{parser.error} +@item @code{amount.is_zero} @tab @code{filters.changed_value.rounding} @tab @code{pool.commodities} +@item @code{amount.parse} @tab @code{filters.collapse} @tab @code{post.assign} +@item @code{amount.price} @tab @code{filters.forecast} @tab @code{python.init} +@item @code{amount.truncate} @tab @code{filters.revalued} @tab @code{python.interp} +@item @code{amount.unround} @tab @code{format.abbrev} @tab @code{query.mask} +@item @code{amounts.commodities} @tab @code{format.expr} @tab @code{report.predicate} +@item @code{amounts.refs} @tab @code{generate.post} @tab @code{scope.symbols} +@item @code{archive.journal} @tab @code{generate.post.string} @tab @code{textual.include} +@item @code{auto.columns} @tab @code{item.meta} @tab @code{textual.parse} +@item @code{budget.generate} @tab @code{ledger.read} @tab @code{timelog} +@item @code{commodity.annotated.strip} @tab @code{ledger.validate} @tab @code{times.epoch} +@item @code{commodity.annotations} @tab @code{lookup} @tab @code{times.interval} +@item @code{commodity.compare} @tab @code{lookup.account} @tab @code{times.parse} +@item @code{commodity.download} @tab @code{mask.match} @tab @code{value.sort} +@item @code{commodity.prices.add} @tab @code{memory.counts} @tab @code{value.storage.refcount} +@item @code{commodity.prices.find} @tab @code{memory.counts.live} @tab @code{xact.extend} +@item @code{convert.csv} @tab @code{memory.debug} @tab @code{xact.extend.cleared} +@item @code{csv.mappings} @tab @code{op.cons} @tab @code{xact.extend.fail} +@item @code{csv.parse} @tab @code{op.memory} @tab @code{xact.finalize} +@item @code{draft.xact} @tab @code{option.args} +@item @code{expr.calc} @tab @code{option.names} +@end multitable @item --trace INTEGER_TRACE_LEVEL -Enable tracing. The integer specifies the level of trace desired: +Enable tracing. The integer specifies the level of trace desired: @multitable @columnfractions .3 .7 @item @code{LOG_OFF} @tab 0 @item @code{LOG_CRIT} @tab 1 @@ -8027,7 +8027,7 @@ Print version information and exit. @node Pre-commands, , Debug Options, Developer Commands @subsection Pre-Commands -Pre-commands are useful when you aren't sure how a command or option +Pre-commands are useful when you aren't sure how a command or option will work. @table @code @item args @@ -8141,7 +8141,7 @@ check} or @code{ninja check} depending on which build tool you prefer. Once built, the ledger executable resides under the @file{build} subdirectory in the source tree. Tests are built and stored in the test subdirectory for the build. For example, -@file{~/ledger/build/ledger/opt/test}. +@file{~/ledger/build/ledger/opt/test}. @menu * Running Tests:: @@ -8160,12 +8160,12 @@ debugging, running individual tests can save a great deal of time. Individual tests can be run fron the @file{test} subdirectory of the build location. To execute a single test use @code{ctest -V -R regex}, -where the regex mathes the name of the test you want to build. +where the regex mathes the name of the test you want to build. There are nearly 300 tests stored under the @file{test} sudirectoro tmain source distribution. They are broken into two broad categories, baseline and regression. To run the @file{5FBF2ED8} test, for example, -issue @code{ctest -V -R "5FB"}. +issue @code{ctest -V -R "5FB"}. @node Writing Tests, , Running Tests, Testing Framework @subsubsection Writing Tests @@ -8274,11 +8274,11 @@ ledger register Checking --sort d -d 'd>[2011/04/01]' until 2011/05/25 @subsection Ledger Files @smallexample -= /^Income:Taxable/ += /^Income:Taxable/ (Liabilities:Tithe Owed) -0.1 -= /Noah/ += /Noah/ (Liabilities:Tithe Owed) -0.1 -= /Jonah/ += /Jonah/ (Liabilities:Tithe Owed) -0.1 = /Tithe/ (Liabilities:Tithe Owed) -1.0 |