aboutsummaryrefslogtreecommitdiff
path: root/src/org/traccar/reports/ReportUtils.java
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2018-05-31 18:48:39 +1200
committerGitHub <noreply@github.com>2018-05-31 18:48:39 +1200
commit2a34f67542221e27e64ee48928fe8fd7d59f7714 (patch)
tree89c06091207e99ae73ff62ecff377847b7960ade /src/org/traccar/reports/ReportUtils.java
parent607123610018cdc1f0e391fec43e54e769d40a06 (diff)
parent786f101fab6a81007f67e868d381302f4a502d77 (diff)
downloadtrackermap-server-2a34f67542221e27e64ee48928fe8fd7d59f7714.tar.gz
trackermap-server-2a34f67542221e27e64ee48928fe8fd7d59f7714.tar.bz2
trackermap-server-2a34f67542221e27e64ee48928fe8fd7d59f7714.zip
Merge pull request #3901 from Abyss777/engineHours_handler
Implement engine hours accumulation
Diffstat (limited to 'src/org/traccar/reports/ReportUtils.java')
-rw-r--r--src/org/traccar/reports/ReportUtils.java15
1 files changed, 11 insertions, 4 deletions
diff --git a/src/org/traccar/reports/ReportUtils.java b/src/org/traccar/reports/ReportUtils.java
index 010c88b22..ea383d598 100644
--- a/src/org/traccar/reports/ReportUtils.java
+++ b/src/org/traccar/reports/ReportUtils.java
@@ -263,10 +263,17 @@ public final class ReportUtils {
stop.setSpentFuel(calculateFuel(startStop, endStop));
long engineHours = 0;
- for (int i = startIndex + 1; i <= endIndex; i++) {
- if (positions.get(i).getBoolean(Position.KEY_IGNITION)
- && positions.get(i - 1).getBoolean(Position.KEY_IGNITION)) {
- engineHours += positions.get(i).getFixTime().getTime() - positions.get(i - 1).getFixTime().getTime();
+ if (startStop.getAttributes().containsKey(Position.KEY_HOURS)
+ && endStop.getAttributes().containsKey(Position.KEY_HOURS)) {
+ engineHours = endStop.getLong(Position.KEY_HOURS) - startStop.getLong(Position.KEY_HOURS);
+ } else if (Context.getConfig().getBoolean("processing.engineHours.enable")) {
+ // Temporary fallback for old data, to be removed in May 2019
+ for (int i = startIndex + 1; i <= endIndex; i++) {
+ if (positions.get(i).getBoolean(Position.KEY_IGNITION)
+ && positions.get(i - 1).getBoolean(Position.KEY_IGNITION)) {
+ engineHours += positions.get(i).getFixTime().getTime()
+ - positions.get(i - 1).getFixTime().getTime();
+ }
}
}
stop.setEngineHours(engineHours);