diff options
author | Abyss777 <abyss@fox5.ru> | 2018-08-23 10:10:44 +0500 |
---|---|---|
committer | Abyss777 <abyss@fox5.ru> | 2018-08-23 10:10:44 +0500 |
commit | e7d5dae5af7214f7f8dac39e8d081ad6c4533d20 (patch) | |
tree | b9b7780bcbccf9c79f1ac610779f8175b69451f0 | |
parent | 12bb168b88fc3dbcdf59c2fec1a919e20ab57838 (diff) | |
download | traccar-server-e7d5dae5af7214f7f8dac39e8d081ad6c4533d20.tar.gz traccar-server-e7d5dae5af7214f7f8dac39e8d081ad6c4533d20.tar.bz2 traccar-server-e7d5dae5af7214f7f8dac39e8d081ad6c4533d20.zip |
Make accumulators nullable
-rw-r--r-- | src/org/traccar/api/resource/DeviceResource.java | 2 | ||||
-rw-r--r-- | src/org/traccar/database/DeviceManager.java | 10 | ||||
-rw-r--r-- | src/org/traccar/model/DeviceAccumulators.java | 16 |
3 files changed, 16 insertions, 12 deletions
diff --git a/src/org/traccar/api/resource/DeviceResource.java b/src/org/traccar/api/resource/DeviceResource.java index 4f0d7ab3b..f9c9a139d 100644 --- a/src/org/traccar/api/resource/DeviceResource.java +++ b/src/org/traccar/api/resource/DeviceResource.java @@ -1,5 +1,5 @@ /* - * Copyright 2015 - 2017 Anton Tananaev (anton@traccar.org) + * Copyright 2015 - 2018 Anton Tananaev (anton@traccar.org) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. diff --git a/src/org/traccar/database/DeviceManager.java b/src/org/traccar/database/DeviceManager.java index c32aca6f9..bc8894743 100644 --- a/src/org/traccar/database/DeviceManager.java +++ b/src/org/traccar/database/DeviceManager.java @@ -1,5 +1,5 @@ /* - * Copyright 2016 - 2017 Anton Tananaev (anton@traccar.org) + * Copyright 2016 - 2018 Anton Tananaev (anton@traccar.org) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -354,8 +354,12 @@ public class DeviceManager extends BaseObjectManager<Device> implements Identity public void resetDeviceAccumulators(DeviceAccumulators deviceAccumulators) throws SQLException { Position last = positions.get(deviceAccumulators.getDeviceId()); if (last != null) { - last.getAttributes().put(Position.KEY_TOTAL_DISTANCE, deviceAccumulators.getTotalDistance()); - last.getAttributes().put(Position.KEY_HOURS, deviceAccumulators.getHours()); + if (deviceAccumulators.getTotalDistance() != null) { + last.getAttributes().put(Position.KEY_TOTAL_DISTANCE, deviceAccumulators.getTotalDistance()); + } + if (deviceAccumulators.getHours() != null) { + last.getAttributes().put(Position.KEY_HOURS, deviceAccumulators.getHours()); + } getDataManager().addObject(last); updateLatestPosition(last); } else { diff --git a/src/org/traccar/model/DeviceAccumulators.java b/src/org/traccar/model/DeviceAccumulators.java index fe0535ef8..8a90826c4 100644 --- a/src/org/traccar/model/DeviceAccumulators.java +++ b/src/org/traccar/model/DeviceAccumulators.java @@ -1,6 +1,6 @@ /* - * Copyright 2016 Anton Tananaev (anton@traccar.org) - * Copyright 2016 Andrey Kunitsyn (andrey@traccar.org) + * Copyright 2016 - 2018 Anton Tananaev (anton@traccar.org) + * Copyright 2016 - 2018 Andrey Kunitsyn (andrey@traccar.org) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -28,23 +28,23 @@ public class DeviceAccumulators { this.deviceId = deviceId; } - private double totalDistance; + private Double totalDistance; - public double getTotalDistance() { + public Double getTotalDistance() { return totalDistance; } - public void setTotalDistance(double totalDistance) { + public void setTotalDistance(Double totalDistance) { this.totalDistance = totalDistance; } - private long hours; + private Long hours; - public long getHours() { + public Long getHours() { return hours; } - public void setHours(long hours) { + public void setHours(Long hours) { this.hours = hours; } |