summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKunht Kun <kunhtkun@gmail.com>2022-03-12 00:04:10 -0500
committerMartin Michlmayr <tbm@cyrius.com>2022-03-12 17:11:55 +0800
commitddc8fcf66fd04dd3685a7788d62c2a00ce2a27ee (patch)
tree7c7ec18e1f0bf59bb4faf87151d259c87ed4b12d
parentba8ec32435313b4749a3733071b3184ca6bd8e14 (diff)
downloadfork-ledger-ddc8fcf66fd04dd3685a7788d62c2a00ce2a27ee.tar.gz
fork-ledger-ddc8fcf66fd04dd3685a7788d62c2a00ce2a27ee.tar.bz2
fork-ledger-ddc8fcf66fd04dd3685a7788d62c2a00ce2a27ee.zip
Avoid dereferencing null pointer
Here `comm` could be a null pointer (the new test regress/2057 shows such a case). So test it before dereferencing to avoid segfault. Re: #2057
-rw-r--r--src/amount.cc3
-rw-r--r--test/regress/2057.test12
2 files changed, 14 insertions, 1 deletions
diff --git a/src/amount.cc b/src/amount.cc
index 0527c979..079ce777 100644
--- a/src/amount.cc
+++ b/src/amount.cc
@@ -732,7 +732,8 @@ void amount_t::in_place_unreduce()
}
if (shifted) {
- if (("h" == comm->symbol() || "m" == comm->symbol()) && commodity_t::time_colon_by_default) {
+ if (comm && ("h" == comm->symbol() || "m" == comm->symbol())
+ && commodity_t::time_colon_by_default) {
double truncated = trunc(tmp.to_double());
double precision = tmp.to_double() - truncated;
tmp = truncated + (precision * (comm->smaller()->number() / 100.0));
diff --git a/test/regress/2057.test b/test/regress/2057.test
new file mode 100644
index 00000000..f691b350
--- /dev/null
+++ b/test/regress/2057.test
@@ -0,0 +1,12 @@
+C 1 "" = 1 $
+
+2021-01-01 Test
+ A $10
+ B
+
+test bal
+ 10 A
+ -10 B
+--------------------
+ 0
+end test