WIP: Changes section.

This commit is contained in:
David Keegan 2013-11-10 13:37:29 +00:00
parent 1381fe5623
commit 4c9d02058c

View file

@ -148,7 +148,8 @@ affects the positions of all transactions.
Finally as the recurring transactions configuration file is Finally as the recurring transactions configuration file is
a valid ledger file you may wish to edit it in a valid ledger file you may wish to edit it in
@code{ledger-mode}. If so add this to your emacs profile (optional): @code{ledger-mode}. If so add this to your emacs profile
(optional):
@lisp @lisp
@ -175,6 +176,29 @@ Problems can be expected if --input-date-format has been
configured with a non-ISO format in the ledger init file configured with a non-ISO format in the ledger init file
(.ledgerrc) or on the ledger command line. (.ledgerrc) or on the ledger command line.
@item
The handling if repetition intervals specified in the
configuration file with unit @code{m} (month) or @code{y}
(year) is not ideal when their application results in an
invalid calendar day or a potentially invalid day. In these
situations, the configured day is adjusted back to @code{28}
to ensure validity, and remains at @code{28} for all future
recurrences.
For example, a monthly recurring transaction initially
configured as @emph{Jan 31} in the configuration file
produces recurrences in the ledger file of @emph{Jan 31},
@emph{Feb 28}, @emph{Mar 28}, @emph{Apr 28}, and so on.
Ideally day 31 should be preserved in the configuration file
(perhaps in a comment), and the days emitted to the ledger
file should be as close as possible to 31 as the calendar
permits.
Note that the current implementation does ensure that only
valid calendar dates occur in both the configuration and
ledger files.
@vindex @code{dklrt-PythonProgram} @vindex @code{dklrt-PythonProgram}
@item @item
The emacs code depends on some python code which is included The emacs code depends on some python code which is included
@ -268,19 +292,37 @@ in the following format:
@verbatim @verbatim
(<Count><Unit>) (<Count><Unit>)
@end verbatim
Where: Where:
@end verbatim
@table @code @table @code
@item Count @item Count
An unsigned decimal integer. An unsigned decimal integer.
@item Unit @item Unit
A single character from the following: y (year), m (month) w A single character specifying a unit and following
(week), d (day), specifying the period unit and following immediately after @code{Count} without intervening space.
immediately after the Count integer without intervening The following values are accepted for @code{Unit}:
space.
@table @code
@item d
A fixed interval of @code{Count} days.
@item w
A fixed interval @code{Count} weeks.
@item m
The interval to the same day @code{Count} months later, but
if this results in an invalid calendar day (eg Feb 31), the
day is shifted back until valid (eg to Feb 28).
@item y
The interval to the same day and month @code{Count} years
later, but if this results in an invalid calendar day (eg
Feb29), the day is shifted back until valid (eg to Feb 28).
@end table
@end table @end table
@node Restrictions @node Restrictions