Fix NPE and some lints

This commit is contained in:
Milos Kozak 2021-10-18 10:54:48 +02:00
parent 48a521e51b
commit 90159e9e15
2 changed files with 22 additions and 21 deletions

View file

@ -1,7 +1,6 @@
package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.device package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.device
import android.bluetooth.BluetoothAdapter import android.bluetooth.BluetoothAdapter
import android.bluetooth.BluetoothAdapter.LeScanCallback
import android.bluetooth.BluetoothGattCharacteristic import android.bluetooth.BluetoothGattCharacteristic
import android.bluetooth.le.BluetoothLeScanner import android.bluetooth.le.BluetoothLeScanner
import android.bluetooth.le.ScanCallback import android.bluetooth.le.ScanCallback
@ -9,6 +8,7 @@ import android.bluetooth.le.ScanFilter
import android.bluetooth.le.ScanResult import android.bluetooth.le.ScanResult
import android.bluetooth.le.ScanSettings import android.bluetooth.le.ScanSettings
import android.os.Handler import android.os.Handler
import android.os.HandlerThread
import android.os.Message import android.os.Message
import info.nightscout.androidaps.logging.AAPSLogger import info.nightscout.androidaps.logging.AAPSLogger
import info.nightscout.androidaps.logging.LTag import info.nightscout.androidaps.logging.LTag
@ -19,7 +19,6 @@ import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.ble.operation
import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData import info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service.RileyLinkServiceData
import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil import info.nightscout.androidaps.plugins.pump.common.utils.ByteUtil
import info.nightscout.androidaps.utils.sharedPreferences.SP import info.nightscout.androidaps.utils.sharedPreferences.SP
import java.lang.Exception
import java.util.* import java.util.*
import javax.inject.Inject import javax.inject.Inject
import javax.inject.Singleton import javax.inject.Singleton
@ -34,7 +33,7 @@ class OrangeLinkImpl @Inject constructor(
lateinit var rileyLinkBLE: RileyLinkBLE lateinit var rileyLinkBLE: RileyLinkBLE
fun onCharacteristicChanged(characteristic: BluetoothGattCharacteristic) { fun onCharacteristicChanged(characteristic: BluetoothGattCharacteristic) {
if (characteristic.uuid.toString().equals(GattAttributes.CHARA_NOTIFICATION_ORANGE)) { if (characteristic.uuid.toString() == GattAttributes.CHARA_NOTIFICATION_ORANGE) {
val data = characteristic.value val data = characteristic.value
val first = 0xff and data[0].toInt() val first = 0xff and data[0].toInt()
aapsLogger.info(LTag.PUMPBTCOMM, aapsLogger.info(LTag.PUMPBTCOMM,
@ -44,7 +43,7 @@ class OrangeLinkImpl @Inject constructor(
rileyLinkServiceData.versionOrangeFirmware = fv rileyLinkServiceData.versionOrangeFirmware = fv
rileyLinkServiceData.versionOrangeHardware = hv rileyLinkServiceData.versionOrangeHardware = hv
aapsLogger.info(LTag.PUMPBTCOMM, "OrangeLink: Firmware: ${fv}, Hardware: ${hv}") aapsLogger.info(LTag.PUMPBTCOMM, "OrangeLink: Firmware: ${fv}, Hardware: $hv")
} }
} }
@ -56,7 +55,7 @@ class OrangeLinkImpl @Inject constructor(
} }
/** /**
* We are checking if this is special Orange (with ORANGE_NOTIFICTION_SERVICE) * We are checking if this is special Orange (with ORANGE_NOTIFICATION_SERVICE)
*/ */
fun checkIsOrange(uuidService: UUID) { fun checkIsOrange(uuidService: UUID) {
if (GattAttributes.isOrange(uuidService)) { if (GattAttributes.isOrange(uuidService)) {
@ -99,7 +98,7 @@ class OrangeLinkImpl @Inject constructor(
fun startScan() { fun startScan() {
try { try {
stopScan() stopScan()
val bluetoothAdapter = rileyLinkBLE.getBluetoothAdapter() val bluetoothAdapter = rileyLinkBLE.bluetoothAdapter
aapsLogger.debug(LTag.PUMPBTCOMM, "startScan") aapsLogger.debug(LTag.PUMPBTCOMM, "startScan")
handler.sendEmptyMessageDelayed(TIME_OUT_WHAT, TIME_OUT.toLong()) handler.sendEmptyMessageDelayed(TIME_OUT_WHAT, TIME_OUT.toLong())
val bluetoothLeScanner: BluetoothLeScanner = bluetoothAdapter.bluetoothLeScanner val bluetoothLeScanner: BluetoothLeScanner = bluetoothAdapter.bluetoothLeScanner
@ -114,7 +113,7 @@ class OrangeLinkImpl @Inject constructor(
} }
} }
var scanCallback: ScanCallback = object : ScanCallback() { private val scanCallback: ScanCallback = object : ScanCallback() {
override fun onScanResult(callbackType: Int, result: ScanResult) { override fun onScanResult(callbackType: Int, result: ScanResult) {
super.onScanResult(callbackType, result) super.onScanResult(callbackType, result)
//val name = result.device.name //val name = result.device.name
@ -136,7 +135,7 @@ class OrangeLinkImpl @Inject constructor(
} }
} }
/*
private val mLeScanCallback = LeScanCallback { device, _, _ -> private val mLeScanCallback = LeScanCallback { device, _, _ ->
if (rileyLinkServiceData.rileyLinkAddress.equals(device.address)) { if (rileyLinkServiceData.rileyLinkAddress.equals(device.address)) {
stopScan() stopScan()
@ -144,11 +143,8 @@ class OrangeLinkImpl @Inject constructor(
rileyLinkBLE.connectGattInternal() rileyLinkBLE.connectGattInternal()
} }
} }
*/
val TIME_OUT = 90 * 1000 private val handler: Handler = object : Handler(HandlerThread(OrangeLinkImpl::class.java.simpleName + "Handler").also { it.start() }.looper) {
val TIME_OUT_WHAT = 0x12
var handler: Handler = object : Handler() {
override fun handleMessage(msg: Message) { override fun handleMessage(msg: Message) {
super.handleMessage(msg) super.handleMessage(msg)
when (msg.what) { when (msg.what) {
@ -160,10 +156,10 @@ class OrangeLinkImpl @Inject constructor(
fun stopScan() { fun stopScan() {
handler.removeMessages(TIME_OUT_WHAT) handler.removeMessages(TIME_OUT_WHAT)
val bluetoothAdapter = rileyLinkBLE.getBluetoothAdapter() ?: return val bluetoothAdapter = rileyLinkBLE.bluetoothAdapter ?: return
try { try {
val bluetoothLeScanner: BluetoothLeScanner = bluetoothAdapter.getBluetoothLeScanner() val bluetoothLeScanner: BluetoothLeScanner = bluetoothAdapter.bluetoothLeScanner
if (isBluetoothAvailable()) { if (isBluetoothAvailable()) {
bluetoothLeScanner.stopScan(scanCallback) bluetoothLeScanner.stopScan(scanCallback)
@ -185,11 +181,15 @@ class OrangeLinkImpl @Inject constructor(
} }
} }
fun isBluetoothAvailable(): Boolean { private fun isBluetoothAvailable(): Boolean {
val bluetoothAdapter = rileyLinkBLE.getBluetoothAdapter() val bluetoothAdapter = rileyLinkBLE.bluetoothAdapter
return bluetoothAdapter != null && return bluetoothAdapter != null &&
bluetoothAdapter.isEnabled() && bluetoothAdapter.isEnabled &&
bluetoothAdapter.getState() == BluetoothAdapter.STATE_ON bluetoothAdapter.state == BluetoothAdapter.STATE_ON
} }
companion object {
const val TIME_OUT = 90 * 1000
const val TIME_OUT_WHAT = 0x12
}
} }

View file

@ -2,6 +2,7 @@ package info.nightscout.androidaps.plugins.pump.common.hw.rileylink.service;
import java.util.Locale; import java.util.Locale;
import javax.annotation.Nullable;
import javax.inject.Inject; import javax.inject.Inject;
import javax.inject.Singleton; import javax.inject.Singleton;
@ -37,8 +38,8 @@ public class RileyLinkServiceData {
private long lastServiceStateChange = 0L; private long lastServiceStateChange = 0L;
public RileyLinkFirmwareVersion firmwareVersion; // here we have "compatibility level" version public RileyLinkFirmwareVersion firmwareVersion; // here we have "compatibility level" version
public RileyLinkTargetFrequency rileyLinkTargetFrequency; public RileyLinkTargetFrequency rileyLinkTargetFrequency;
public String rileyLinkAddress; @Nullable public String rileyLinkAddress;
public String rileyLinkName; @Nullable public String rileyLinkName;
public Integer batteryLevel; public Integer batteryLevel;
public boolean showBatteryLevel = false; public boolean showBatteryLevel = false;
long lastTuneUpTime = 0L; long lastTuneUpTime = 0L;