| Commit message (Collapse) | Author | Age | Files | Lines |
| |
|
| |
|
| |
|
| |
|
| |
|
| |
|
|
|
|
|
| |
You now call session_t::close_journal_files() followed by
session_t::read_journal_files().
|
| |
|
| |
|
| |
|
|
|
|
| |
This way the value shown follows the current reporting options.
|
| |
|
| |
|
| |
|
|
|
|
|
| |
Since cost reports are now calculated by setting the amount_ expression,
there is no need to track a separate "total cost" entity.
|
| |
|
|
|
|
|
|
|
|
|
|
|
| |
Now one does:
parent->HANDLER(display_total_).set_expr("total");
Rather than what was required previously:
parent->HANDLER(display_total_).on("total");
parent->HANDLER(display_total_).expr = "total";
|
|
|
|
|
| |
xact_t::add_to_value, in cases where the xact had a "compound" total,
was adding transaction values to the running total twice.
|
| |
|
|
|
|
|
|
| |
This allows reports to access the "whicheth" index of the reported
transaction. It's used mainly by the --average report, which divides
the running total by this count to get the arithmetic mean.
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
For example, if one uses -M to generate a monthly report for an entire
year, and there are no transaction in the month of February, ordinarily
Ledger would report nothing for that month, even if -E were used. Now
"null transactions" are generated for periods without any activity, in
order to make certain reports -- such as running monthly averages --
more accurate.
For example, instead of -MA being just a monthly running average of
months with activity, it is now a true average among all months during
the reported period.
|
|
|
|
|
|
| |
That is, if a metadata tag cannot be found in a transaction, look in the
parent entry to see if it was set there. Transactions "inherit"
notational details from their entries.
|
| |
|
| |
|
| |
|
| |
|
|
|
|
| |
The previous behavior was to trigger a confusing assertion.
|
| |
|
| |
|
| |
|
|
|
|
|
| |
Note that the --uncleared flag includes --pending, since it specifically
means "not yet cleared".
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
The prices report now uses the following scheme:
PAYEE -> name of commodity of price
ACCOUNT -> name of commodity of item
AMOUNT -> price
DATE -> date of pricing
However, the report does not show the payee. The only reason the payee
is set is to enable clever querying. For example:
ledger prices gold # show all known prices for GOLD
ledger prices @gold # show all known prices *in* GOLD
|
|
|
|
|
| |
This is done in the value code, which knows -- based on the value's type
-- how best to apply the justification.
|
|
|
|
|
| |
It now shows the formatted result against a sample entry, similar to
what "parse" now does.
|
|
|
|
|
| |
That is, if the user didn't enter an amount for that transaction in
their ledger journal, don't print one out either.
|
| |
|
|
|
|
| |
However, the budget reports themselves still need to be tested.
|
| |
|
| |
|
|
|
|
|
|
|
| |
These files are used to creat ea Git pre-commit hook which verifies each
proposed change by running "make check". Otherwise, I only know if my
working tree is sane, and not if each commit is sane before it goes into
the repository.
|
|
|
|
|
|
|
| |
Created a new function, session_t::reread_journal_files, which throws
away all previous state data and reads in the same files again. This is
needed to allow Emacs to communicate with Ledger via the REPL, so that
it tell Ledger when it has made changes to the user's data file.
|
|
|
|
|
|
| |
Otherwise, calling out to Ledger uses whatever the user's default
happens to be, such as iso-latin-1. This caused problems for one user
who had euro symbols encoding in utf-8 in his data file.
|
|
|
|
| |
Otherwise, Ledger was unable to parse what it had printed.
|
|
|
|
|
|
|
|
|
| |
This can be used to format dates with a specific pattern, such as:
format_date(entry.date, "%Y/%m/%d")
This is used by the print command to ensure that Ledger is able to parse
back what it prints.
|
| |
|
|
|
|
|
| |
This library is a dependency for running "make check", but it's not
built as part of a Ledger build, and so doesn't belong as a submodule.
|
|
|
|
|
| |
Now it takes --warn and --debug flags, and I use tools/myacprep to
collect together all the flags I normally use in development.
|
|
|
|
|
| |
The purpose was to provided a clearer relationship between the function
name and its expected arguments.
|
| |
|