diff options
author | Christoph Dittmann <github@christoph-d.de> | 2021-01-30 14:32:17 +0100 |
---|---|---|
committer | Martin Michlmayr <tbm@cyrius.com> | 2021-01-30 23:44:58 +0800 |
commit | b155f8928c6a33af42f859b27c83639b72517f5e (patch) | |
tree | 4b5d19cda86c2fc5b3786541c02326dea68f986c /src/times.cc | |
parent | 2dae3bbedcdf55983d23fc90bb36111c7eb68fc7 (diff) | |
download | fork-ledger-b155f8928c6a33af42f859b27c83639b72517f5e.tar.gz fork-ledger-b155f8928c6a33af42f859b27c83639b72517f5e.tar.bz2 fork-ledger-b155f8928c6a33af42f859b27c83639b72517f5e.zip |
compare_by_commodity: Always return the result of the recursive call
Commit 501fbc08ae5493db77bb34f4c4fbe1f3a3bc14e3 changed the behavior
of this function to not return the "equal" result (==0) from the
recursive call. Previously, the function returned the result of the
recursive call unconditionally.
The current behavior causes an assertion error for certain
postings. The regression test added in this commit shows such a
posting.
I found through Travis CI that the old behavior was incomplete and
caused unstable orderings, so reverting to the old behavior doesn't
work. Instead, this change adds a fallback: If the recursive call that
compares the prices numerically returns "equal", then compare the
prices with their original commodity as a tie breaker.
This commit does not change any existing ordering, it only adds
deterministic ordering in a case that currently triggers an assertion
error.
This fixes issue #1998.
Diffstat (limited to 'src/times.cc')
0 files changed, 0 insertions, 0 deletions