Prevent NPE when checking for battery level
This is a simple caller-side fix to prevent NullPointerException when checking battery level. The NPE happened when the BT stack returned an empty array in the response with a `RESULT_SUCCESS` result code. We now check for empty array, and log that as a seperate error is such a response is received.
This commit is contained in:
parent
d300a95e39
commit
edd34622fd
1 changed files with 10 additions and 4 deletions
|
@ -2,6 +2,8 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble;
|
||||||
|
|
||||||
import android.os.SystemClock;
|
import android.os.SystemClock;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@ -111,13 +113,17 @@ public class RFSpy {
|
||||||
public Integer retrieveBatteryLevel() {
|
public Integer retrieveBatteryLevel() {
|
||||||
BLECommOperationResult result = rileyLinkBle.readCharacteristic_blocking(batteryServiceUUID, batteryLevelUUID);
|
BLECommOperationResult result = rileyLinkBle.readCharacteristic_blocking(batteryServiceUUID, batteryLevelUUID);
|
||||||
if (result.resultCode == BLECommOperationResult.RESULT_SUCCESS) {
|
if (result.resultCode == BLECommOperationResult.RESULT_SUCCESS) {
|
||||||
|
if (ArrayUtils.isNotEmpty(result.value)) {
|
||||||
int value = result.value[0];
|
int value = result.value[0];
|
||||||
aapsLogger.debug(LTag.PUMPBTCOMM, "BLE battery level: {}", value);
|
aapsLogger.debug(LTag.PUMPBTCOMM, "BLE battery level: {}", value);
|
||||||
return value;
|
return value;
|
||||||
} else {
|
} else {
|
||||||
aapsLogger.error(LTag.PUMPBTCOMM, "getBatteryLevel failed with code: " + result.resultCode);
|
aapsLogger.error(LTag.PUMPBTCOMM, "getBatteryLevel received an empty result. Value: " + result.value);
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
aapsLogger.error(LTag.PUMPBTCOMM, "getBatteryLevel failed with code: " + result.resultCode);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
// This gets the version from the BLE113, not from the CC1110.
|
// This gets the version from the BLE113, not from the CC1110.
|
||||||
|
|
Loading…
Reference in a new issue