diff options
Diffstat (limited to 'doc')
-rw-r--r-- | doc/ledger3.texi | 87 |
1 files changed, 71 insertions, 16 deletions
diff --git a/doc/ledger3.texi b/doc/ledger3.texi index c4a73200..aa4d736a 100644 --- a/doc/ledger3.texi +++ b/doc/ledger3.texi @@ -97,6 +97,7 @@ twinkling in their father's CRT. @node Copying, Introduction to Ledger, Top, Top @chapter Copying + @insertcopying This license can also be obtained from the command-line by executing @@ -104,6 +105,7 @@ This license can also be obtained from the command-line by executing @node Introduction to Ledger, Ledger Tutorial, Copying, Top @chapter Introduction to Ledger + @menu * Fat-free Accounting:: * Building the Program:: @@ -112,6 +114,7 @@ This license can also be obtained from the command-line by executing @node Fat-free Accounting, Building the Program, Introduction to Ledger, Introduction to Ledger @section Fat-free Accounting + Ledger is an accounting tool with the moxie to exist. It provides no bells or whistles, and returns the user to the days before user interfaces were even a twinkling in their father's CRT. @@ -267,6 +270,7 @@ enter these commands: @findex help @node Getting Help, , Building the Program, Introduction to Ledger @section Getting help + Ledger has a complete online help system based on GNU Info. This manual can be searched directly from the command line using the following options: @@ -290,6 +294,7 @@ You can also find help at the @code{#ledger} channel on the IRC server @node Start a Journal, Run Some Reports, Ledger Tutorial, Ledger Tutorial @section Start a Journal File @cindex journals + A journal is a record of your financial transactions and will be central to using Ledger. For now we just want to get a taste of what Ledger can do. An example journal is included with the source code distribution, @@ -323,6 +328,7 @@ shells to give concrete examples for each. @subsection Balance Report @cindex balance report @findex balance (bal) + To find the balances of all of your accounts, run this command: @smallexample @@ -378,6 +384,7 @@ $ ledger -f drewr3.dat balance Assets Liabilities @subsection Register Report @cindex register report @findex register (reg) + To show all transactions and a running total: @smallexample ledger -f drewr3.dat register @@ -457,6 +464,7 @@ $ ledger -f drewr3.dat register payee "Organic" @subsection Cleared Report @cindex cleared report @findex cleared + A very useful report is to show what your obligations are versus what expenditures have actually been recorded. It can take several days for a check to clear, but you should treat it as money spent. The @@ -492,6 +500,7 @@ $ ledger -f drewr3.dat cleared @subsection Using the Windows Command Line @cindex windows cmd.exe @cindex currency symbol display on windows + Using ledger under the windows command shell has one significant limitation. CMD.exe is limited to standard ASCII characters and as such cannot display any currency symbols other than dollar signs ($). @@ -524,8 +533,8 @@ businesses. Double-entry accounting scales. @node Stating where money goes, Assets and Liabilities, Accounting with Ledger, Principles of Accounting @section Stating where money goes - @cindex credits and debits + Accountants will talk of ``credits'' and ``debits'', but the meaning is often different from the layman's understanding. To avoid confusion, Ledger uses only subtractions and additions, although the @@ -580,6 +589,7 @@ money now than when you started your ledger. Make sense? @section Assets and Liabilities @cindex assets and liabilities @cindex debts are liabilities + Assets are money that you have, and Liabilities are money that you owe. ``Liabilities'' is just a more inclusive name for Debts. @@ -646,9 +656,10 @@ This assumes, of course, that you use account names like @menu * Tracking reimbursable expenses:: @end menu -@cindex reimbursable expense tracking + @node Tracking reimbursable expenses, , Assets and Liabilities, Assets and Liabilities @subsection Tracking reimbursable expenses +@cindex reimbursable expense tracking Sometimes you will want to spend money on behalf of someone else, which will eventually get repaid. Since the money is still ``yours'', @@ -1306,7 +1317,6 @@ give an error and stop calculating.} @node Starting up, Structuring Your Accounts, Most Basic Entry, Keeping a Journal @section Starting up - @cindex initial equity @cindex beginning ledger @@ -1341,9 +1351,9 @@ work. @node Structuring Your Accounts, Commenting on your journal, Starting up, Keeping a Journal @section Structuring your Accounts - @cindex accounts, naming @cindex naming accounts + There really are no requirements for how you do this, but to preserve your sanity we suggest some very basic structure to your accounting system. @@ -1376,6 +1386,7 @@ Expenses:Food:Hamburgers and Fries @node Commenting on your journal, Currency and Commodities, Structuring Your Accounts, Keeping a Journal @section Commenting on your Journal @cindex comments, characters + Comments are generally started using a ';'. However, in order to increase compatibility with other text manipulation programs and methods four additional comment characters are valid if used at the beginning @@ -1419,9 +1430,9 @@ preserved as part of the transaction. The `:'s indicate meta-data and tags @node Currency and Commodities, Keeping it Consistent, Commenting on your journal, Keeping a Journal @section Currency and Commodities - @cindex currency @cindex commodity + Ledger is agnostic when it comes to how you value your accounts. Dollars, Euros, Pounds, Francs, Shares etc. are just ``commodities''. Holdings in stocks, bonds, mutual funds and other financial instruments @@ -1488,6 +1499,7 @@ since we haven't told ledger to convert commodities. @node Naming Commodities, Buying and Selling Stock, Currency and Commodities, Currency and Commodities @subsection Naming Commodities + Commodity names can have any character, including white-space. However, if you include white-space or numeric characters the commodity name must be enclosed in double quotes: @@ -1539,6 +1551,7 @@ price/date and your taxation model is based on longest-held-first. @subsection Fixing Lot Prices @cindex fixing lot prices @cindex consumable commodity pricing + Commodities that you keep in order to sell them at a later time have a variable value that fluctuates with the market prices. Commodities that you consume should not fluctuate in value, but stay at the lot price @@ -1776,6 +1789,7 @@ them. They are summarized below. @node Transaction and Comments, Command Directives, Journal Format, Journal Format @subsection Transactions and Comments + The initial character of each line determines what the line means, and how it should be interpreted. Allowable initial characters are: @@ -2252,6 +2266,7 @@ syntax of its timelog files. @node Converting from other formats, Archiving Previous Years, Journal Format, Keeping a Journal @section Converting from other formats + There are numerous tools to help convert various formats to a Ledger file. Most banks will generate a commas separated value file that can easily be parsed into Ledger format using one of those tools. Some of the more popular tools are: @@ -2325,6 +2340,7 @@ doing it. @node Transactions, Building Reports, Keeping a Journal, Top @chapter Transactions + @menu * Basic format:: * Eliding amounts:: @@ -2353,7 +2369,6 @@ doing it. @node Basic format, Eliding amounts, Transactions, Transactions @section Basic format - The most basic form of transaction is: @smallexample @@ -2668,6 +2683,7 @@ expression with parentheses: @node Balance verification, Posting cost, Expression amounts, Transactions @section Balance verification + @menu * Balance assertions:: * Balance assignments:: @@ -3424,7 +3440,6 @@ See @ref{Budgeting and Forecasting} for examples and details. @node Concrete Example of Automated Transactions, , Periodic Transactions, Automated Transactions @subsection Concrete Example of Automated Transactions - As a Bahá'í, I need to compute Huqúqu'lláh whenever I acquire assets. It is similar to tithing for Jews and Christians, or to Zakát for Muslims. The exact details of computing Huqúqu'lláh are somewhat @@ -3513,6 +3528,7 @@ which may be excluded from reports by using @option{--real}. @node Introduction, Balance Reports, Building Reports, Building Reports @section Introduction + The power of Ledger comes from the incredible flexibility in its reporting commands, combined with formatting commands. Some options control what is included in the calculations, and formatting controls @@ -3523,6 +3539,7 @@ options. @node Balance Reports, Typical queries, Introduction, Building Reports @section Balance Reports + @menu * Controlling the Accounts and Payees:: * Controlling formatting:: @@ -3617,9 +3634,11 @@ ledger -s bal Expenses and not \(Expenses:Drinks or Expenses:Candy or Expenses:G @node Controlling formatting, , Controlling the Accounts and Payees, Balance Reports @subsection Controlling Formatting + These examples all use the default formatting for the balance report. Customizing the formatting can easily allowing to see only what you want, or interface Ledger with other programs. + @node Typical queries, Advanced Reports, Balance Reports, Building Reports @section Typical queries @@ -3682,7 +3701,6 @@ subtotaled by the month. The running total in both cases is off, however, since a display expression is being used. - @node Advanced Reports, , Typical queries, Building Reports @section Advanced Reports @@ -3693,6 +3711,7 @@ however, since a display expression is being used. @node Asset Allocation, Visualizing with Gnuplot, Advanced Reports, Advanced Reports @subsection Asset Allocation + A very popular method of managing portfolios is to control the percent allocation of assets by certain categories. The mix of categories and the weights applied to them vary by investing @@ -3803,11 +3822,12 @@ ratio as a percentage. The fourth line tells ledger to display the current market value of the line. The last two characters ``%/'' tell Ledger what to do for the last line, in this case, nothing. -@cindex plotting -@cindex Gnuplot @node Visualizing with Gnuplot, , Asset Allocation, Advanced Reports @subsection Visualizing with Gnuplot @cindex Gnuplot script +@cindex plotting +@cindex Gnuplot + If you have @command{Gnuplot} installed, you can graph any of the above register reports. The script to do this is included in the ledger distribution, and is named @file{contrib/report}. Install @file{report} @@ -3859,6 +3879,7 @@ of the balance. @node Reporting Commands, Command-line Syntax, Building Reports, Top @chapter Reporting Commands + @menu * Primary Financial Reports:: Reports in other formats:: Reports about * Reports in other Formats:: @@ -3883,6 +3904,7 @@ accounts. It accepts a list of optional regexps, which confine the balance report to the matching accounts. If an account contains multiple types of commodities, each commodity's total is reported separately. + @node The equity Command, The register Command, The balance Command, Primary Financial Reports @subsection The @code{equity} Command @@ -3926,6 +3948,7 @@ file whose formatting has gotten out of hand. @node Reports in other Formats, Reports about your Journals, Primary Financial Reports, Reporting Commands @section Reports in other Formats + @menu * Comma Separated Variable files:: * The lisp command:: @@ -3937,6 +3960,7 @@ file whose formatting has gotten out of hand. @node Comma Separated Variable files, The lisp command, Reports in other Formats, Reports in other Formats @subsection Comma Separated Variable files + @menu * The csv command:: * The convert command:: @@ -3944,15 +3968,18 @@ file whose formatting has gotten out of hand. @node The csv command, The convert command, Comma Separated Variable files, Comma Separated Variable files @subsubsection The @code{csv} command + The @command{csv} command will output print out the desired ledger transactions in a csv format suitable for import into other programs. You can specify the transactions to print using all the normal limiting and searching functions. + +@node The convert command, , The csv command, Comma Separated Variable files +@subsubsection The @code{convert} command @cindex csv conversion @cindex reading csv @cindex comma separated variable file reading -@node The convert command, , The csv command, Comma Separated Variable files -@subsubsection The @code{convert} command + The @code{convert} command parses a comma separated value (csv) file and outputs Ledger transactions. Many banks offer csv file downloads. Unfortunately, the file formats, aside the from commas, are @@ -4059,6 +4086,7 @@ directly by Emacs Lisp. The format of the @code{sexp} is: @node Emacs Org mode, The pricemap Command, The lisp command, Reports in other Formats @subsection Emacs @code{org} Mode + 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}. @@ -4221,6 +4249,7 @@ of transactions together to generate reports. Using the same transactions used above, we could consider splitting these into expenses and income, as follows: + @subsubheading Income Entries The first set of entries relates to income, either monthly pay or @@ -4248,6 +4277,7 @@ have the :noweb yes babel header argument specified. income:salary #+end_src @end smallexample + @subsubheading Expenses The following entries relate to personal expenses, such as rent and @@ -4273,6 +4303,7 @@ blocks, we can now refer to these using the noweb expansion directives, reports for those transactions. Below are two examples, one to generate a balance report and one to generate a register report of all transactions. + @subsubheading An overall balance summary The overall balance of your account and expenditure with a breakdown @@ -4315,6 +4346,7 @@ tell Ledger to include sub-accounts in the report. : £-2000.00 salary : £-1300.00 starting balances @end smallexample + @subsubheading Generating a monthly register You can also generate a monthly register (the reg command) by executing @@ -5007,6 +5039,7 @@ will issue a warning giving you the file and line number of the problem. @node Report Options, Report Filtering, Session Options, Detailed Options Description @subsection Report Options + Options for Ledger report affect three separate scopes of operation: Global, Session, and Report. In practice there is very little difference between these scopes. Ledger 3.0 contains provisions for @@ -6240,6 +6273,7 @@ relative to the date that amount was encountered. You can also now use @code{-X} (and @code{-H}) in conjunction with @code{-B} and @code{-I}, to see valuation reports of just your basis costs or lot prices. + @node Environment Variables, , Commodity Reporting, Detailed Options Description @subsection Environment variables @@ -6812,6 +6846,7 @@ Useful specifying a date in plain terms. For example, you could say @node Basics, Format String Structure, Format Strings, Format Strings @section Format String Basics + Format strings may be used to change the output format of reports. They are specified by passing a formatting string to the @code{--format} (@code{-F}) option. Within that string, constructs are allowed which @@ -6837,6 +6872,7 @@ having to enter a new format for each command. @node Format String Structure, Format Expressions, Basics, Format Strings @section Format String Structure + Within a format string, a substitution is specified using a percent character (@code{%}). The basic format of all substitutions is: @@ -6866,7 +6902,7 @@ or an expression enclosed in parentheses or brackets. @node Format Expressions, --balance-format, Format String Structure, Format Strings @section Format Expressions - The allowable expressions are: +The allowable expressions are: @table @code @item % @@ -6996,6 +7032,7 @@ balance format looks like this (the various functions are described later): @node Field Widths, Colors, Formatting codes, Formatting codes @subsection Field Widths + The following codes return the width allocated for the specific fields. The defaults can be changed using the corresponding command line options: @@ -7053,6 +7090,7 @@ terminal character colors and font highlights in a normal TTY session. @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. @table @code @@ -7079,10 +7117,13 @@ Convert a string to date value @node Date and Time Format Codes, Text Formatting, Dates, Formatting codes @subsection Date and Time Format Codes + Date and time format are specified as strings of single letter codes preceded by percent signs. Any separator, or no separator can be specified. + @subsubsection Days + Dates are formed from a combination of day, month and year codes, in whatever order you prefer: @@ -7160,6 +7201,7 @@ Locale’s full month, variable length February @end table @subsubsection Miscellaneous Date Codes + Additional date format parameters which can be used: @table @code @@ -7187,6 +7229,7 @@ yields @code{%Y-%m-%d 2010-02-10} @node Text Formatting, Data File Parsing Information, Date and Time Format Codes, Formatting codes @subsection Text Formatting + The following format functions allow you limited formatting of text: @table @code @@ -7235,6 +7278,7 @@ line number in @code{filename} where posting's entry for posting ends, abbreviat @node Extending with Python, Ledger for Developers, Format Strings, Top @chapter Extending with Python + Python can be used to extend your Ledger experience. But first, a word must be said about Ledger's data model, so that other things make sense later. @@ -7403,6 +7447,7 @@ need to create sums of multiple commodities, use a Balance. For example: @node Internal Design, Journal File Format, Ledger for Developers, Ledger for Developers @section Internal Design + Ledger is developed as a tiered set of functionality, where lower tiers know nothing about the higher tiers. In fact, multiple libraries are built during the development the process, and link unit tests to these @@ -7691,6 +7736,7 @@ of a line: @code{#}, @code{|}, and @code{*}. @node Specifying Amounts, Posting costs, Comments and meta-data, Journal File Format @subsection Specifying Amounts @cindex amounts + The heart of a journal is the amounts it records, and this fact is reflected in the diversity of amount expressions allowed. All of them are covered here, though it must be said that sometimes, there are @@ -7893,6 +7939,7 @@ commodities. @node Developer Commands, Ledger Development Environment, Journal File Format, Ledger for Developers @section Developer Commands + @menu * echo:: * reload:: @@ -7903,17 +7950,20 @@ commodities. @node echo, reload, Developer Commands, Developer Commands @subsection @command{echo} + This command simply echoes its argument back to the output. @node reload, source, echo, Developer Commands @subsection @command{reload} + Forces ledger to reload any journal files. This function exists to support external programs controlling a running ledger process and does nothing for a command line user. @node source, Debug Options, reload, Developer Commands @subsection @command{source} + The @code{source} command take a journal file as an argument and parses it checking for errors, no other reports are generated, and no other arguments are necessary. Ledger will return success if no errors are @@ -7993,6 +8043,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 will work. @@ -8100,6 +8151,7 @@ This is a debugging command. @node Testing Framework, , acprep build configuration tool, Ledger Development Environment @subsection Testing Framework + Ledger source ships with a fairly complete set of tests to verify that all is well, and no old errors have been resurfaced. Tests are run individually with @code{ctest}. All tests can be run using @code{make @@ -8146,9 +8198,11 @@ issue @code{ctest -V -R "5FB"}. @node Example Data File, Miscellaneous Notes, Major Changes from version 2.6, Top @appendix Example Journal File: drewr.dat - The following journal file is included with the source distribution of - ledger. It is called @file{drewr.dat} and exhibits many ledger - features, include automatic and virtual transactions, + +The following journal file is included with the source distribution of +ledger. It is called @file{drewr.dat} and exhibits many ledger +features, include automatic and virtual transactions, + @smallexample ; -*- ledger -*- @@ -8238,6 +8292,7 @@ ledger cleared VWCU NFCU Tithe Misentry ledger register Joint --uncleared ledger register Checking --sort d -d 'd>[2011/04/01]' until 2011/05/25 @end smallexample + @subsection Ledger Files @smallexample |