summaryrefslogtreecommitdiff
path: root/doc/Ledger.scriv/165.rtfd/TXT.rtf
blob: 9b5b393f422cbe2b475c6ffab10d6edc77273013 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
{\rtf1\ansi\ansicpg1252\cocoartf949\cocoasubrtf460
{\fonttbl\f0\fmodern\fcharset0 Courier;}
{\colortbl;\red255\green255\blue255;}
\pard\tx560\tx1120\tx1680\tx2240\tx2800\tx3360\tx3920\tx4480\tx5040\tx5600\tx6160\tx6720\sl264\slmult1\ql\qnatural\pardirnatural

\f0\fs28 \cf0 @c      --budget           generate budget transactions based on FILE\
\
There is more information about budgeting and forecasting in\
@ref\{Budgeting and forecasting\}.  Basically, if you have any period\
transactions in your ledger file, you can use these options.  A period\
transaction looks like:\
\
@example\
~ Monthly\
  Assets:Bank:Checking         $500.00\
  Income:Salary\
@end example\
\
The difference from a regular transaction is that the first line begins with\
a tilde (~), and instead of a payee there's a period expression\
(@ref\{Period expressions\}).  Otherwise, a period transaction is in every\
other way the same as a regular transaction.\
\
With such a transaction in your ledger file, the @option\{--budget\} option\
will report only postings that match a budgeted account.  Using\
@file\{sample.dat\} from above:\
\
@example\
ledger --budget reg ^income\
@end example\
\
Reports:\
\
@smallexample\
2004/05/01 Budget transaction         Income:Salary               $500.00      $500.00\
2004/05/14 Pay day              Income:Salary              $-500.00            0\
@end smallexample\
\
The final total is zero, indicating that the budget matched epostly\
for the reported period.  Budgeting is most often helpful with period\
reporting; for example, to show monthly budget results use\
@option\{--budget -p monthly\}.\
\
@c      --add-budget       show all postings plus the budget\
@c      --unbudgeted       show only unbudgeted postings\
\
The @option\{--add-budget\} option reports all matching postings in\
addition to budget postings; while @option\{--unbudgeted\} shows\
only those that don't match a budgeted account.  To summarize:\
\
@table @option\
@item --budget\
Show postings matching budgeted accounts.\
@item --unbudgeted\
Show postings matching unbudgeted accounts.\
@item --add-budget\
Show both budgeted and unbudgeted postings together (i.e., add the\
generated budget postings to the regular report).\
@end table\
\
@c      --forecast EXPR    generate forecast transactions while EXPR is true\
\
A report with the @option\{--forecast\} option will add budgeted\
postings while the specified value expression is true.  For\
example:\
\
@example\
ledger --forecast 'd<[2005] reg ^income\
@end example\
\
Reports:\
\
@smallexample\
2004/05/14 Pay day              Income:Salary              $-500.00     $-500.00\
2004/12/01 Forecast transaction       Income:Salary              $-500.00   $-1,000.00\
2005/01/01 Forecast transaction       Income:Salary              $-500.00   $-1,500.00\
@end smallexample\
\
The date this report was made was November 5, 2004; the reason the\
first forecast transaction is in december is that forecast transactions are only\
added for the future, and they only stop after the value expression\
has matched at least once, which is why the January transaction appears.  A\
forecast report can be very useful for determining when money will run\
out in an account, or for projecting future cash flow:\
\
@example\
ledger --forecast 'd<[2008]' -p yearly reg ^inc ^exp\
@end example\
\
This reports balances projected income against projected expenses,\
showing the resulting total in yearly intervals until 2008.  For the\
case of @file\{sample.dat\}, which has no budgeted expenses, the result\
of the above command (in November 2004) is:\
\
@smallexample\
2004/01/01 - 2004/12/31         Income:Salary            $-1,000.00   $-1,000.00\
                                Expenses:Books               $20.00     $-980.00\
2005/01/01 - 2005/12/31         Income:Salary            $-6,000.00   $-6,980.00\
2006/01/01 - 2006/12/31         Income:Salary            $-6,000.00  $-12,980.00\
2007/01/01 - 2007/12/31         Income:Salary            $-6,000.00  $-18,980.00\
2008/01/01 - 2008/01/01         Income:Salary              $-500.00  $-19,480.00\
@end smallexample}