[velux] eliminate mvn compiler warnings (#8606)

* [velux] remove redundant NonNullByDefault annotations

Signed-off-by: Andrew Fiddian-Green <software@whitebear.ch>
This commit is contained in:
Andrew Fiddian-Green 2020-09-29 18:21:44 +01:00 committed by GitHub
parent 78c81ab93d
commit 4e72980c6c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
30 changed files with 20 additions and 63 deletions

View File

@ -197,7 +197,7 @@ The bridge Thing provides the following properties.
| products | List of all recognized products | | products | List of all recognized products |
| scenes | List of all defined scenes | | scenes | List of all defined scenes |
| subnetMask | IP subnetmask of the Bridge | | subnetMask | IP subnetmask of the Bridge |
| vendor | Vendow name | | vendor | Vendor name |
| WLANSSID | Name of the wireless network (not suported any more) | | WLANSSID | Name of the wireless network (not suported any more) |
| WLANPassword | WLAN Authentication Password (not suported any more) | | WLANPassword | WLAN Authentication Password (not suported any more) |

View File

@ -16,7 +16,6 @@ import static org.apache.commons.lang.StringUtils.isNotBlank;
import java.lang.reflect.Field; import java.lang.reflect.Field;
import org.apache.commons.lang.StringUtils;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable; import org.eclipse.jdt.annotation.Nullable;
import org.openhab.binding.velux.internal.config.VeluxBridgeConfiguration; import org.openhab.binding.velux.internal.config.VeluxBridgeConfiguration;
@ -56,8 +55,9 @@ public class VeluxBinding extends VeluxBridgeConfiguration {
logger.trace("VeluxBinding(constructor) called."); logger.trace("VeluxBinding(constructor) called.");
if (logger.isTraceEnabled()) { if (logger.isTraceEnabled()) {
for (Field field : VeluxBridgeConfiguration.class.getFields()) { for (Field field : VeluxBridgeConfiguration.class.getFields()) {
if (!StringUtils.capitalize(field.getName()).contentEquals(field.getName())) { String fName = field.getName();
logger.trace("VeluxBinding(): FYI: a potential configuration string is '{}'.", field.getName()); if ((fName.length() > 0) && Character.isUpperCase(fName.charAt(0))) {
logger.trace("VeluxBinding(): FYI: a potential configuration string is '{}'.", fName);
} }
} }
} }

View File

@ -64,7 +64,6 @@ public class VeluxBridgeActuators {
* <li>existingProducts ({@link VeluxExistingProducts}). * <li>existingProducts ({@link VeluxExistingProducts}).
* </ul> * </ul>
*/ */
@NonNullByDefault
public class Channel { public class Channel {
public VeluxExistingProducts existingProducts = new VeluxExistingProducts(); public VeluxExistingProducts existingProducts = new VeluxExistingProducts();
} }

View File

@ -48,7 +48,6 @@ public class VeluxBridgeDeviceStatus {
* <li>{@link #gwStateDescription} containing the verbose gateway state. * <li>{@link #gwStateDescription} containing the verbose gateway state.
* </ul> * </ul>
*/ */
@NonNullByDefault
public class Channel { public class Channel {
public boolean isRetrieved = false; public boolean isRetrieved = false;
public StringType gwState = new StringType(VeluxBindingConstants.UNKNOWN); public StringType gwState = new StringType(VeluxBindingConstants.UNKNOWN);

View File

@ -46,7 +46,6 @@ public class VeluxBridgeGetFirmware {
* <li>firmwareVersion (human readable String). * <li>firmwareVersion (human readable String).
* </ul> * </ul>
*/ */
@NonNullByDefault
public class Channel { public class Channel {
public boolean isRetrieved = false; public boolean isRetrieved = false;
public StringType firmwareVersion = new StringType(VeluxBindingConstants.UNKNOWN); public StringType firmwareVersion = new StringType(VeluxBindingConstants.UNKNOWN);

View File

@ -50,7 +50,6 @@ public class VeluxBridgeLANConfig {
* <li>enabledDHCP. * <li>enabledDHCP.
* </ul> * </ul>
*/ */
@NonNullByDefault
public class Channel { public class Channel {
public boolean isRetrieved = false; public boolean isRetrieved = false;
public StringType openHABipAddress = new StringType(VeluxBindingConstants.UNKNOWN); public StringType openHABipAddress = new StringType(VeluxBindingConstants.UNKNOWN);

View File

@ -49,7 +49,6 @@ public class VeluxBridgeScenes {
* <li>existingScenes ({@link VeluxExistingScenes}). * <li>existingScenes ({@link VeluxExistingScenes}).
* </ul> * </ul>
*/ */
@NonNullByDefault
public class Channel { public class Channel {
public VeluxExistingScenes existingScenes = new VeluxExistingScenes(); public VeluxExistingScenes existingScenes = new VeluxExistingScenes();
} }

View File

@ -48,7 +48,6 @@ public class VeluxBridgeWLANConfig {
* <li>wlanPassword. * <li>wlanPassword.
* </ul> * </ul>
*/ */
@NonNullByDefault
public class Channel { public class Channel {
public boolean isRetrieved = false; public boolean isRetrieved = false;
public StringType openHABwlanSSID = new StringType(VeluxBindingConstants.UNKNOWN); public StringType openHABwlanSSID = new StringType(VeluxBindingConstants.UNKNOWN);

View File

@ -62,7 +62,6 @@ class JCgetDeviceStatus extends GetDeviceStatus implements JsonBridgeCommunicati
* NOTE: the gateway software is extremely sensitive to this exact JSON structure. * NOTE: the gateway software is extremely sensitive to this exact JSON structure.
* Any modifications (like omitting empty params) will lead to an gateway error. * Any modifications (like omitting empty params) will lead to an gateway error.
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -93,7 +92,6 @@ class JCgetDeviceStatus extends GetDeviceStatus implements JsonBridgeCommunicati
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -56,7 +56,6 @@ class JCgetFirmware extends GetFirmware implements JsonBridgeCommunicationProtoc
* {"action":"getFirmware","params":{}} * {"action":"getFirmware","params":{}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -76,7 +75,6 @@ class JCgetFirmware extends GetFirmware implements JsonBridgeCommunicationProtoc
* <P> * <P>
* Used within structure {@link JCgetFirmware} to describe the software of the Bridge. * Used within structure {@link JCgetFirmware} to describe the software of the Bridge.
*/ */
@NonNullByDefault
private static class BCfirmwareVersion { private static class BCfirmwareVersion {
/* /*
* "version": "0.1.1.0.41.0" * "version": "0.1.1.0.41.0"
@ -100,7 +98,6 @@ class JCgetFirmware extends GetFirmware implements JsonBridgeCommunicationProtoc
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -57,7 +57,6 @@ class JCgetLANConfig extends GetLANConfig implements BridgeCommunicationProtocol
* {"action":"get","params":{}} * {"action":"get","params":{}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -81,7 +80,6 @@ class JCgetLANConfig extends GetLANConfig implements BridgeCommunicationProtocol
* {"ipAddress":"192.168.45.9","subnetMask":"255.255.255.0","defaultGateway":"192.168.45.129","dhcp":false} * {"ipAddress":"192.168.45.9","subnetMask":"255.255.255.0","defaultGateway":"192.168.45.129","dhcp":false}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class BCLANConfig { private static class BCLANConfig {
private String ipAddress = VeluxBindingConstants.UNKNOWN; private String ipAddress = VeluxBindingConstants.UNKNOWN;
private String subnetMask = VeluxBindingConstants.UNKNOWN; private String subnetMask = VeluxBindingConstants.UNKNOWN;
@ -111,7 +109,6 @@ class JCgetLANConfig extends GetLANConfig implements BridgeCommunicationProtocol
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -61,7 +61,6 @@ class JCgetProducts extends GetProducts implements JsonBridgeCommunicationProtoc
* ] * ]
* </PRE> * </PRE>
*/ */
@NonNullByDefault
private class BCproduct { private class BCproduct {
private String name = VeluxBindingConstants.UNKNOWN; private String name = VeluxBindingConstants.UNKNOWN;
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -84,7 +83,6 @@ class JCgetProducts extends GetProducts implements JsonBridgeCommunicationProtoc
* {"action":"get","params":{}} * {"action":"get","params":{}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -126,7 +124,6 @@ class JCgetProducts extends GetProducts implements JsonBridgeCommunicationProtoc
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -59,7 +59,6 @@ class JCgetScenes extends GetScenes implements JsonBridgeCommunicationProtocol {
* "status": 0 * "status": 0
* </PRE> * </PRE>
*/ */
@NonNullByDefault
private static class BCproductState { private static class BCproductState {
private int typeId; private int typeId;
private String name = VeluxBindingConstants.UNKNOWN; private String name = VeluxBindingConstants.UNKNOWN;
@ -91,7 +90,6 @@ class JCgetScenes extends GetScenes implements JsonBridgeCommunicationProtocol {
* }, * },
* </PRE> * </PRE>
*/ */
@NonNullByDefault
private static class BCscene { private static class BCscene {
private String name = VeluxBindingConstants.UNKNOWN; private String name = VeluxBindingConstants.UNKNOWN;
private int id; private int id;
@ -110,7 +108,6 @@ class JCgetScenes extends GetScenes implements JsonBridgeCommunicationProtocol {
* {"action":"get","params":{}} * {"action":"get","params":{}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -150,7 +147,6 @@ class JCgetScenes extends GetScenes implements JsonBridgeCommunicationProtocol {
* } * }
* </PRE> * </PRE>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -57,7 +57,6 @@ class JCgetWLANConfig extends GetWLANConfig implements JsonBridgeCommunicationPr
* {"action":"wifi","params":{}} * {"action":"wifi","params":{}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -81,7 +80,6 @@ class JCgetWLANConfig extends GetWLANConfig implements JsonBridgeCommunicationPr
* {"password":"Esf56mxqFY","name":"VELUX_KLF_847C"} * {"password":"Esf56mxqFY","name":"VELUX_KLF_847C"}
* </PRE> * </PRE>
*/ */
@NonNullByDefault
private static class BCWLANConfig { private static class BCWLANConfig {
private String password = VeluxBindingConstants.UNKNOWN; private String password = VeluxBindingConstants.UNKNOWN;
@ -110,7 +108,6 @@ class JCgetWLANConfig extends GetWLANConfig implements JsonBridgeCommunicationPr
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -45,7 +45,6 @@ class JClogin extends Login implements JsonBridgeCommunicationProtocol {
/* /*
* Message Objects * Message Objects
*/ */
@NonNullByDefault
private static class ParamsLogin { private static class ParamsLogin {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String password = VeluxBindingConstants.UNKNOWN; private String password = VeluxBindingConstants.UNKNOWN;
@ -61,7 +60,6 @@ class JClogin extends Login implements JsonBridgeCommunicationProtocol {
* {"action":"login","params":{"password":"PASSWORD"}} * {"action":"login","params":{"password":"PASSWORD"}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -83,7 +81,6 @@ class JClogin extends Login implements JsonBridgeCommunicationProtocol {
* '{"token": "PHPnfLda71xfGlxoYEOTGQ==", "result": true, "deviceStatus": "IDLE", "data": {}, "errors": [] }' * '{"token": "PHPnfLda71xfGlxoYEOTGQ==", "result": true, "deviceStatus": "IDLE", "data": {}, "errors": [] }'
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;
private boolean result; private boolean result;

View File

@ -51,7 +51,6 @@ class JClogout extends Logout implements JsonBridgeCommunicationProtocol {
* {"action":"logout","params":{}} * {"action":"logout","params":{}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -75,7 +74,6 @@ class JClogout extends Logout implements JsonBridgeCommunicationProtocol {
* '{"token": "PHPnfLda71xfGlxoYEOTGQ==", "result": true, "deviceStatus": "IDLE", "data": {}, "errors": [] }' * '{"token": "PHPnfLda71xfGlxoYEOTGQ==", "result": true, "deviceStatus": "IDLE", "data": {}, "errors": [] }'
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -58,7 +58,6 @@ class JCrunProductDiscovery extends RunProductDiscovery implements JsonBridgeCom
* NOTE: the gateway software is extremely sensitive to this exact JSON structure. * NOTE: the gateway software is extremely sensitive to this exact JSON structure.
* Any modifications (like omitting empty params) will lead to an gateway error. * Any modifications (like omitting empty params) will lead to an gateway error.
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -89,7 +88,6 @@ class JCrunProductDiscovery extends RunProductDiscovery implements JsonBridgeCom
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -46,7 +46,6 @@ class JCrunProductIdentification extends RunProductIdentification implements Jso
/* /*
* Message Objects * Message Objects
*/ */
@NonNullByDefault
private static class ParamsIdentifyProduct { private static class ParamsIdentifyProduct {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private int id; private int id;
@ -68,7 +67,6 @@ class JCrunProductIdentification extends RunProductIdentification implements Jso
* {"action":"identify","params":{"id":23,"time":254}} * {"action":"identify","params":{"id":23,"time":254}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String action; private String action;
@ -98,7 +96,6 @@ class JCrunProductIdentification extends RunProductIdentification implements Jso
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -60,7 +60,6 @@ class JCrunProductSearch extends RunProductSearch implements JsonBridgeCommunica
* NOTE: the gateway software is extremely sensitive to this exact JSON structure. * NOTE: the gateway software is extremely sensitive to this exact JSON structure.
* Any modifications (like omitting empty params) will lead to an gateway error. * Any modifications (like omitting empty params) will lead to an gateway error.
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -91,7 +90,6 @@ class JCrunProductSearch extends RunProductSearch implements JsonBridgeCommunica
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -42,7 +42,6 @@ class JCrunScene extends RunScene implements JsonBridgeCommunicationProtocol {
/* /*
* Message Objects * Message Objects
*/ */
@NonNullByDefault
private static class ParamsRunScene { private static class ParamsRunScene {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private int id; private int id;
@ -58,7 +57,6 @@ class JCrunScene extends RunScene implements JsonBridgeCommunicationProtocol {
* {"action":"run","params":{"id":9}} * {"action":"run","params":{"id":9}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String action; private String action;
@ -86,7 +84,6 @@ class JCrunScene extends RunScene implements JsonBridgeCommunicationProtocol {
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -45,7 +45,6 @@ class JCsetSceneVelocity extends SetSceneVelocity implements JsonBridgeCommunica
/* /*
* Message Objects * Message Objects
*/ */
@NonNullByDefault
private static class ParamsRunScene { private static class ParamsRunScene {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private int id; private int id;
@ -68,7 +67,6 @@ class JCsetSceneVelocity extends SetSceneVelocity implements JsonBridgeCommunica
* {"action":"setSilentMode","params":{"id":9,"silent":false}}} * {"action":"setSilentMode","params":{"id":9,"silent":false}}}
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Request { private static class Request {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String action; private String action;
@ -97,7 +95,6 @@ class JCsetSceneVelocity extends SetSceneVelocity implements JsonBridgeCommunica
* } * }
* </pre> * </pre>
*/ */
@NonNullByDefault
private static class Response { private static class Response {
@SuppressWarnings("unused") @SuppressWarnings("unused")
private String token = VeluxBindingConstants.UNKNOWN; private String token = VeluxBindingConstants.UNKNOWN;

View File

@ -12,13 +12,13 @@
*/ */
package org.openhab.binding.velux.internal.bridge.json; package org.openhab.binding.velux.internal.bridge.json;
import java.io.ByteArrayInputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.Properties; import java.util.Properties;
import java.util.TreeSet; import java.util.TreeSet;
import org.apache.commons.io.IOUtils;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.openhab.binding.velux.internal.bridge.VeluxBridge; import org.openhab.binding.velux.internal.bridge.VeluxBridge;
import org.openhab.binding.velux.internal.bridge.VeluxBridgeInstance; import org.openhab.binding.velux.internal.bridge.VeluxBridgeInstance;
@ -185,6 +185,9 @@ public class JsonVeluxBridge extends VeluxBridge {
} else { } else {
response = ioUnauthenticated(sapURL, getRequest, classOfResponse); response = ioUnauthenticated(sapURL, getRequest, classOfResponse);
} }
if (response == null) {
throw new IOException("Failed to create 'response' object");
}
communication.setResponse(response); communication.setResponse(response);
logger.trace("bridgeCommunicate(): communication result is {}, returning details.", logger.trace("bridgeCommunicate(): communication result is {}, returning details.",
communication.isCommunicationSuccessful()); communication.isCommunicationSuccessful());
@ -233,7 +236,7 @@ public class JsonVeluxBridge extends VeluxBridge {
if (authentication.length() > 0) { if (authentication.length() > 0) {
headerItems.setProperty("Authorization", String.format("Bearer %s", authentication)); headerItems.setProperty("Authorization", String.format("Bearer %s", authentication));
} }
InputStream content = IOUtils.toInputStream(jsonRequest, StandardCharsets.UTF_8.name()); InputStream content = new ByteArrayInputStream(jsonRequest.getBytes(StandardCharsets.UTF_8));
String jsonResponse = HttpUtil.executeUrl("PUT", url, headerItems, content, "application/json", String jsonResponse = HttpUtil.executeUrl("PUT", url, headerItems, content, "application/json",
this.bridgeInstance.veluxBridgeConfiguration().timeoutMsecs); this.bridgeInstance.veluxBridgeConfiguration().timeoutMsecs);
@ -253,7 +256,6 @@ public class JsonVeluxBridge extends VeluxBridge {
T response = gson.fromJson(jsonResponse, classOfResponse); T response = gson.fromJson(jsonResponse, classOfResponse);
lastCommunicationInMSecs = lastSuccessfulCommunicationInMSecs = System.currentTimeMillis(); lastCommunicationInMSecs = lastSuccessfulCommunicationInMSecs = System.currentTimeMillis();
return response; return response;
} catch (IOException ioe) { } catch (IOException ioe) {
logger.trace("io(): Exception occurred during I/O: {}.", ioe.getMessage()); logger.trace("io(): Exception occurred during I/O: {}.", ioe.getMessage());
// Error Retries with Exponential Backoff // Error Retries with Exponential Backoff
@ -269,7 +271,6 @@ public class JsonVeluxBridge extends VeluxBridge {
logger.info("io(): Exception occurred on deserialization: {}, aborting.", jse.getMessage()); logger.info("io(): Exception occurred on deserialization: {}, aborting.", jse.getMessage());
throw jse; throw jse;
} }
} while (retryCount++ < this.bridgeInstance.veluxBridgeConfiguration().retries); } while (retryCount++ < this.bridgeInstance.veluxBridgeConfiguration().retries);
throw new IOException(String.format("io(): socket I/O failed (%d times).", throw new IOException(String.format("io(): socket I/O failed (%d times).",
this.bridgeInstance.veluxBridgeConfiguration().retries)); this.bridgeInstance.veluxBridgeConfiguration().retries));

View File

@ -58,7 +58,7 @@ public class SlipEncoding {
*/ */
public SlipEncoding(short command, byte[] data) { public SlipEncoding(short command, byte[] data) {
logger.trace("SlipEncoding(constructor) for command 0x{} with data size {} called.", logger.trace("SlipEncoding(constructor) for command 0x{} with data size {} called.",
Integer.toHexString(new Short(command).intValue()), data.length); Integer.toHexString(Short.valueOf(command).intValue()), data.length);
if (data.length > 250) { if (data.length > 250) {
logger.warn("SlipEncoding(constructor) called with data size {}: too big, aborting.", data.length); logger.warn("SlipEncoding(constructor) called with data size {}: too big, aborting.", data.length);
encodingValid = false; encodingValid = false;

View File

@ -68,9 +68,11 @@ public class VeluxHandlerFactory extends BaseThingHandlerFactory {
private void registerDeviceDiscoveryService(VeluxBridgeHandler bridgeHandler) { private void registerDeviceDiscoveryService(VeluxBridgeHandler bridgeHandler) {
logger.trace("registerDeviceDiscoveryService({}) called.", bridgeHandler); logger.trace("registerDeviceDiscoveryService({}) called.", bridgeHandler);
boolean createNew = (discoveryService == null); boolean createNew = false;
if (createNew) { VeluxDiscoveryService discoveryService = this.discoveryService;
if (discoveryService == null) {
discoveryService = new VeluxDiscoveryService(localization); discoveryService = new VeluxDiscoveryService(localization);
createNew = true;
} }
discoveryService.addBridge(bridgeHandler); discoveryService.addBridge(bridgeHandler);
if (createNew) { if (createNew) {
@ -81,10 +83,14 @@ public class VeluxHandlerFactory extends BaseThingHandlerFactory {
private synchronized void unregisterDeviceDiscoveryService(VeluxBridgeHandler bridgeHandler) { private synchronized void unregisterDeviceDiscoveryService(VeluxBridgeHandler bridgeHandler) {
logger.trace("unregisterDeviceDiscoveryService({}) called.", bridgeHandler); logger.trace("unregisterDeviceDiscoveryService({}) called.", bridgeHandler);
VeluxDiscoveryService discoveryService = this.discoveryService;
if (discoveryService != null) { if (discoveryService != null) {
discoveryService.removeBridge(bridgeHandler); discoveryService.removeBridge(bridgeHandler);
if (discoveryService.isEmpty()) { if (discoveryService.isEmpty()) {
discoveryServiceRegistration.unregister(); ServiceRegistration<?> discoveryServiceRegistration = this.discoveryServiceRegistration;
if (discoveryServiceRegistration != null) {
discoveryServiceRegistration.unregister();
}
} }
} }
} }

View File

@ -156,7 +156,6 @@ public class VeluxBridgeHandler extends ExtendedBaseBridgeHandler implements Vel
* <LI>{@link #wlanConfig} - Information about the gateway configuration.</LI> * <LI>{@link #wlanConfig} - Information about the gateway configuration.</LI>
* </UL> * </UL>
*/ */
@NonNullByDefault
public class BridgeParameters { public class BridgeParameters {
/** Information retrieved by {@link VeluxBridgeActuators#getProducts} */ /** Information retrieved by {@link VeluxBridgeActuators#getProducts} */
public VeluxBridgeActuators actuators = new VeluxBridgeActuators(); public VeluxBridgeActuators actuators = new VeluxBridgeActuators();

View File

@ -66,7 +66,6 @@ public class VeluxKLFAPI {
* <LI>Method {@link toString} to return a String.</LI> * <LI>Method {@link toString} to return a String.</LI>
* </UL> * </UL>
*/ */
@NonNullByDefault
public static class CommandName { public static class CommandName {
private String name; private String name;
@ -90,7 +89,6 @@ public class VeluxKLFAPI {
* <LI>Method {@link toString} to return a well-formatted String.</LI> * <LI>Method {@link toString} to return a well-formatted String.</LI>
* </UL> * </UL>
*/ */
@NonNullByDefault
public static class CommandNumber { public static class CommandNumber {
private short commandNumber; private short commandNumber;
@ -104,7 +102,7 @@ public class VeluxKLFAPI {
@Override @Override
public String toString() { public String toString() {
return "0x" + Integer.toHexString(new Short(commandNumber).intValue()); return "0x" + Integer.toHexString(Short.valueOf(commandNumber).intValue());
} }
} }

View File

@ -33,7 +33,6 @@ public class VeluxProduct {
// Type definitions // Type definitions
@NonNullByDefault
public static class ProductBridgeIndex { public static class ProductBridgeIndex {
// Public definition // Public definition

View File

@ -37,7 +37,6 @@ public class VeluxProductState {
// Type definitions // Type definitions
@NonNullByDefault
private class ProductState { private class ProductState {
private int state; private int state;

View File

@ -45,7 +45,6 @@ public class VeluxScene {
// Type definitions // Type definitions
@NonNullByDefault
public static class SceneName { public static class SceneName {
private static final SceneName UNKNOWN = new SceneName(VeluxBindingConstants.UNKNOWN); private static final SceneName UNKNOWN = new SceneName(VeluxBindingConstants.UNKNOWN);
@ -66,7 +65,6 @@ public class VeluxScene {
} }
} }
@NonNullByDefault
public static class SceneBridgeIndex { public static class SceneBridgeIndex {
private static final SceneBridgeIndex UNKNOWN = new SceneBridgeIndex(0); private static final SceneBridgeIndex UNKNOWN = new SceneBridgeIndex(0);

View File

@ -53,7 +53,6 @@ public class Localization {
/** /**
* Class, which is needed to maintain a @NonNullByDefault for class {@link Localization}. * Class, which is needed to maintain a @NonNullByDefault for class {@link Localization}.
*/ */
@NonNullByDefault
private class UnknownLocale implements LocaleProvider { private class UnknownLocale implements LocaleProvider {
@Override @Override
public Locale getLocale() { public Locale getLocale() {