summaryrefslogtreecommitdiffstats
path: root/stats/pieseries.cpp
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2021-03-05 09:35:13 +0100
committerGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2021-03-05 09:35:13 +0100
commit7446e8cddddcf02b704bdc1a8bfe74609acbb0d9 (patch)
treed2a6bc591ff4f2e6e13b5aab25ed77c19f5867c3 /stats/pieseries.cpp
parent3fcac9022cca520209352c498320809bfb66e2c9 (diff)
downloadsubsurface-7446e8cddddcf02b704bdc1a8bfe74609acbb0d9.tar.gz
statistics: don't divide by totalCount = 0 in pie charts
This silences a Coverity warning. In principle, this should never happen, since there are no slices if totalCount is 0. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'stats/pieseries.cpp')
-rw-r--r--stats/pieseries.cpp5
1 files changed, 5 insertions, 0 deletions
diff --git a/stats/pieseries.cpp b/stats/pieseries.cpp
index c425fffd2..84f80b01d 100644
--- a/stats/pieseries.cpp
+++ b/stats/pieseries.cpp
@@ -27,6 +27,11 @@ PieSeries::Item::Item(StatsView &view, const QString &name, int from, std::vecto
QLocale loc;
int count = (int)dives.size();
+
+ // totalCount = 0 shouldn't happen, but for robustness' sake, let's not divide by zero.
+ if (totalCount <= 0)
+ totalCount = count = 1;
+
angleFrom = static_cast<double>(from) / totalCount;
angleTo = static_cast<double>(from + count) / totalCount;
double meanAngle = M_PI / 2.0 - (from + count / 2.0) / totalCount * M_PI * 2.0; // Note: "-" because we go CW.