Rename classes with "SmartHome" in their name (#1896)
* Rename SmartHomeUnits to Units * Rename SmartHome Servlets and HTTP Context Signed-off-by: Wouter Born <github@maindrain.net>pull/1897/head
parent
f99135ae3d
commit
13c2d7bf2b
|
@ -34,7 +34,7 @@ import org.openhab.core.audio.AudioFormat;
|
||||||
import org.openhab.core.audio.AudioHTTPServer;
|
import org.openhab.core.audio.AudioHTTPServer;
|
||||||
import org.openhab.core.audio.AudioStream;
|
import org.openhab.core.audio.AudioStream;
|
||||||
import org.openhab.core.audio.FixedLengthAudioStream;
|
import org.openhab.core.audio.FixedLengthAudioStream;
|
||||||
import org.openhab.core.io.http.servlet.SmartHomeServlet;
|
import org.openhab.core.io.http.servlet.OpenHABServlet;
|
||||||
import org.osgi.service.component.annotations.Activate;
|
import org.osgi.service.component.annotations.Activate;
|
||||||
import org.osgi.service.component.annotations.Component;
|
import org.osgi.service.component.annotations.Component;
|
||||||
import org.osgi.service.component.annotations.Deactivate;
|
import org.osgi.service.component.annotations.Deactivate;
|
||||||
|
@ -49,7 +49,7 @@ import org.osgi.service.http.HttpService;
|
||||||
*/
|
*/
|
||||||
@NonNullByDefault
|
@NonNullByDefault
|
||||||
@Component
|
@Component
|
||||||
public class AudioServlet extends SmartHomeServlet implements AudioHTTPServer {
|
public class AudioServlet extends OpenHABServlet implements AudioHTTPServer {
|
||||||
|
|
||||||
private static final long serialVersionUID = -3364664035854567854L;
|
private static final long serialVersionUID = -3364664035854567854L;
|
||||||
|
|
||||||
|
|
|
@ -50,7 +50,7 @@ import org.openhab.core.library.unit.BinaryPrefix;
|
||||||
import org.openhab.core.library.unit.ImperialUnits;
|
import org.openhab.core.library.unit.ImperialUnits;
|
||||||
import org.openhab.core.library.unit.MetricPrefix;
|
import org.openhab.core.library.unit.MetricPrefix;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.thing.ThingRegistry;
|
import org.openhab.core.thing.ThingRegistry;
|
||||||
import org.openhab.core.thing.binding.ThingActions;
|
import org.openhab.core.thing.binding.ThingActions;
|
||||||
import org.openhab.core.types.Command;
|
import org.openhab.core.types.Command;
|
||||||
|
@ -150,7 +150,7 @@ public class DefaultScriptScopeProvider implements ScriptExtensionProvider {
|
||||||
elements.put("SIUnits", SIUnits.class);
|
elements.put("SIUnits", SIUnits.class);
|
||||||
elements.put("ImperialUnits", ImperialUnits.class);
|
elements.put("ImperialUnits", ImperialUnits.class);
|
||||||
elements.put("MetricPrefix", MetricPrefix.class);
|
elements.put("MetricPrefix", MetricPrefix.class);
|
||||||
elements.put("SmartHomeUnits", SmartHomeUnits.class);
|
elements.put("Units", Units.class);
|
||||||
elements.put("BinaryPrefix", BinaryPrefix.class);
|
elements.put("BinaryPrefix", BinaryPrefix.class);
|
||||||
|
|
||||||
// services
|
// services
|
||||||
|
|
|
@ -33,17 +33,17 @@ import org.osgi.service.component.annotations.ReferencePolicy;
|
||||||
import org.osgi.service.http.HttpContext;
|
import org.osgi.service.http.HttpContext;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default http context implementation which groups all Smart Home related http elements into one logical application.
|
* Default HTTP context implementation which groups all openHAB related HTTP elements into one logical application.
|
||||||
*
|
*
|
||||||
* Additionally to standard http context, this one provides its own implementation of
|
* Additionally to the standard HTTP context, this class provides its own implementation of the
|
||||||
* {@link #handleSecurity(HttpServletRequest, HttpServletResponse)} method which is based on injected list of generic
|
* {@link #handleSecurity(HttpServletRequest, HttpServletResponse)} method which is based on the injected list of
|
||||||
* handlers.
|
* {@link Handler}s.
|
||||||
*
|
*
|
||||||
* @author Łukasz Dywicki - Initial contribution
|
* @author Łukasz Dywicki - Initial contribution
|
||||||
*/
|
*/
|
||||||
@Component(service = { HttpContext.class, WrappingHttpContext.class }, property = {
|
@Component(service = { HttpContext.class, WrappingHttpContext.class }, property = {
|
||||||
"httpContext.id:String=oh-dfl-http-ctx" })
|
"httpContext.id:String=oh-dfl-http-ctx" })
|
||||||
public class SmartHomeHttpContext implements WrappingHttpContext {
|
public class OpenHABHttpContext implements WrappingHttpContext {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sorted list of handlers, where handler with priority 0 is first.
|
* Sorted list of handlers, where handler with priority 0 is first.
|
|
@ -30,21 +30,21 @@ import org.slf4j.LoggerFactory;
|
||||||
* @author Łukasz Dywicki - Initial contribution
|
* @author Łukasz Dywicki - Initial contribution
|
||||||
*/
|
*/
|
||||||
@NonNullByDefault
|
@NonNullByDefault
|
||||||
public abstract class BaseSmartHomeServlet extends HttpServlet {
|
public abstract class BaseOpenHABServlet extends HttpServlet {
|
||||||
|
|
||||||
private static final long serialVersionUID = 6020752826735599455L;
|
private static final long serialVersionUID = 6020752826735599455L;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Logger bound to child class.
|
* Logger bound to child class.
|
||||||
*/
|
*/
|
||||||
protected final Logger logger = LoggerFactory.getLogger(BaseSmartHomeServlet.class);
|
protected final Logger logger = LoggerFactory.getLogger(BaseOpenHABServlet.class);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Http service.
|
* Http service.
|
||||||
*/
|
*/
|
||||||
protected final HttpService httpService;
|
protected final HttpService httpService;
|
||||||
|
|
||||||
public BaseSmartHomeServlet(HttpService httpService) {
|
public BaseOpenHABServlet(HttpService httpService) {
|
||||||
this.httpService = httpService;
|
this.httpService = httpService;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,11 +25,11 @@ import org.osgi.service.http.HttpService;
|
||||||
* @author Łukasz Dywicki - Initial contribution
|
* @author Łukasz Dywicki - Initial contribution
|
||||||
*/
|
*/
|
||||||
@NonNullByDefault
|
@NonNullByDefault
|
||||||
public abstract class SmartHomeBundleServlet extends BaseSmartHomeServlet {
|
public abstract class OpenHABBundleServlet extends BaseOpenHABServlet {
|
||||||
|
|
||||||
protected final HttpContextFactoryService httpContextFactoryService;
|
protected final HttpContextFactoryService httpContextFactoryService;
|
||||||
|
|
||||||
public SmartHomeBundleServlet(HttpService httpService, HttpContextFactoryService httpContextFactoryService) {
|
public OpenHABBundleServlet(HttpService httpService, HttpContextFactoryService httpContextFactoryService) {
|
||||||
super(httpService);
|
super(httpService);
|
||||||
this.httpContextFactoryService = httpContextFactoryService;
|
this.httpContextFactoryService = httpContextFactoryService;
|
||||||
}
|
}
|
|
@ -22,7 +22,7 @@ import org.osgi.service.http.HttpService;
|
||||||
* @author Łukasz Dywicki - Initial contribution
|
* @author Łukasz Dywicki - Initial contribution
|
||||||
*/
|
*/
|
||||||
@NonNullByDefault
|
@NonNullByDefault
|
||||||
public abstract class SmartHomeServlet extends BaseSmartHomeServlet {
|
public abstract class OpenHABServlet extends BaseOpenHABServlet {
|
||||||
|
|
||||||
private static final long serialVersionUID = 6854521240046714164L;
|
private static final long serialVersionUID = 6854521240046714164L;
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ public abstract class SmartHomeServlet extends BaseSmartHomeServlet {
|
||||||
*/
|
*/
|
||||||
protected final HttpContext httpContext;
|
protected final HttpContext httpContext;
|
||||||
|
|
||||||
public SmartHomeServlet(HttpService httpService, HttpContext httpContext) {
|
public OpenHABServlet(HttpService httpService, HttpContext httpContext) {
|
||||||
super(httpService);
|
super(httpService);
|
||||||
this.httpContext = httpContext;
|
this.httpContext = httpContext;
|
||||||
}
|
}
|
|
@ -19,7 +19,7 @@ import javax.measure.quantity.Dimensionless;
|
||||||
|
|
||||||
import org.openhab.core.library.types.DecimalType;
|
import org.openhab.core.library.types.DecimalType;
|
||||||
import org.openhab.core.library.types.QuantityType;
|
import org.openhab.core.library.types.QuantityType;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.types.Type;
|
import org.openhab.core.types.Type;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -95,7 +95,7 @@ public class NumberExtensions {
|
||||||
|
|
||||||
public static boolean operator_equals(Number left, Number right) {
|
public static boolean operator_equals(Number left, Number right) {
|
||||||
// in case one of the Number instances is of type QuantityType they are never equal (except for
|
// in case one of the Number instances is of type QuantityType they are never equal (except for
|
||||||
// SmartHomeUnit.ONE).
|
// Units.ONE).
|
||||||
// for both instances being QuantityTypes the specific method
|
// for both instances being QuantityTypes the specific method
|
||||||
// operator_equals(QuantityType<?> left, QuantityType<?> right) is called by the script engine.
|
// operator_equals(QuantityType<?> left, QuantityType<?> right) is called by the script engine.
|
||||||
if (oneIsQuantity(left, right)) {
|
if (oneIsQuantity(left, right)) {
|
||||||
|
@ -282,7 +282,7 @@ public class NumberExtensions {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static QuantityType<?> operator_divide(Number x, QuantityType<?> y) {
|
public static QuantityType<?> operator_divide(Number x, QuantityType<?> y) {
|
||||||
QuantityType<Dimensionless> xQuantity = new QuantityType<>(x, SmartHomeUnits.ONE);
|
QuantityType<Dimensionless> xQuantity = new QuantityType<>(x, Units.ONE);
|
||||||
return operator_divide(xQuantity, y);
|
return operator_divide(xQuantity, y);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -294,7 +294,7 @@ public class NumberExtensions {
|
||||||
return left.equals(right);
|
return left.equals(right);
|
||||||
}
|
}
|
||||||
|
|
||||||
// support SmartHomeUnit.ONE as Number representation
|
// support Units.ONE as Number representation
|
||||||
public static boolean operator_equals(QuantityType<?> left, Number right) {
|
public static boolean operator_equals(QuantityType<?> left, Number right) {
|
||||||
return operator_equals((Number) left, right);
|
return operator_equals((Number) left, right);
|
||||||
}
|
}
|
||||||
|
@ -303,7 +303,7 @@ public class NumberExtensions {
|
||||||
return !operator_equals(left, right);
|
return !operator_equals(left, right);
|
||||||
}
|
}
|
||||||
|
|
||||||
// support SmartHomeUnit.ONE as Number representation
|
// support Units.ONE as Number representation
|
||||||
public static boolean operator_notEquals(QuantityType<?> left, Number right) {
|
public static boolean operator_notEquals(QuantityType<?> left, Number right) {
|
||||||
return operator_notEquals((Number) left, right);
|
return operator_notEquals((Number) left, right);
|
||||||
}
|
}
|
||||||
|
@ -317,7 +317,7 @@ public class NumberExtensions {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// support SmartHomeUnit.ONE as Number representation
|
// support Units.ONE as Number representation
|
||||||
public static boolean operator_lessThan(QuantityType<?> x, Number y) {
|
public static boolean operator_lessThan(QuantityType<?> x, Number y) {
|
||||||
return operator_lessThan((Number) x, y);
|
return operator_lessThan((Number) x, y);
|
||||||
}
|
}
|
||||||
|
@ -331,7 +331,7 @@ public class NumberExtensions {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// support SmartHomeUnit.ONE as Number representation
|
// support Units.ONE as Number representation
|
||||||
public static boolean operator_lessEqualsThan(QuantityType<?> x, Number y) {
|
public static boolean operator_lessEqualsThan(QuantityType<?> x, Number y) {
|
||||||
return operator_lessEqualsThan((Number) x, y);
|
return operator_lessEqualsThan((Number) x, y);
|
||||||
}
|
}
|
||||||
|
@ -345,7 +345,7 @@ public class NumberExtensions {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// support SmartHomeUnit.ONE as Number representation
|
// support Units.ONE as Number representation
|
||||||
public static boolean operator_greaterThan(QuantityType<?> x, Number y) {
|
public static boolean operator_greaterThan(QuantityType<?> x, Number y) {
|
||||||
return operator_greaterThan((Number) x, y);
|
return operator_greaterThan((Number) x, y);
|
||||||
}
|
}
|
||||||
|
@ -359,7 +359,7 @@ public class NumberExtensions {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// support SmartHomeUnit.ONE as Number representation
|
// support Units.ONE as Number representation
|
||||||
public static boolean operator_greaterEqualsThan(QuantityType<?> x, Number y) {
|
public static boolean operator_greaterEqualsThan(QuantityType<?> x, Number y) {
|
||||||
return operator_greaterEqualsThan((Number) x, y);
|
return operator_greaterEqualsThan((Number) x, y);
|
||||||
}
|
}
|
||||||
|
@ -393,7 +393,7 @@ public class NumberExtensions {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean isAbstractUnitOne(QuantityType<?> left) {
|
private static boolean isAbstractUnitOne(QuantityType<?> left) {
|
||||||
return SmartHomeUnits.ONE.equals(left.getUnit());
|
return Units.ONE.equals(left.getUnit());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@ import org.openhab.core.library.unit.BinaryPrefix;
|
||||||
import org.openhab.core.library.unit.ImperialUnits;
|
import org.openhab.core.library.unit.ImperialUnits;
|
||||||
import org.openhab.core.library.unit.MetricPrefix;
|
import org.openhab.core.library.unit.MetricPrefix;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.model.script.actions.BusEvent;
|
import org.openhab.core.model.script.actions.BusEvent;
|
||||||
import org.openhab.core.model.script.actions.Exec;
|
import org.openhab.core.model.script.actions.Exec;
|
||||||
import org.openhab.core.model.script.actions.HTTP;
|
import org.openhab.core.model.script.actions.HTTP;
|
||||||
|
@ -96,7 +96,7 @@ public class ScriptImplicitlyImportedTypes extends ImplicitlyImportedFeatures {
|
||||||
result.add(ImperialUnits.class);
|
result.add(ImperialUnits.class);
|
||||||
result.add(MetricPrefix.class);
|
result.add(MetricPrefix.class);
|
||||||
result.add(SIUnits.class);
|
result.add(SIUnits.class);
|
||||||
result.add(SmartHomeUnits.class);
|
result.add(Units.class);
|
||||||
result.add(BinaryPrefix.class);
|
result.add(BinaryPrefix.class);
|
||||||
|
|
||||||
// date time static functions
|
// date time static functions
|
||||||
|
|
|
@ -19,7 +19,7 @@ import org.eclipse.jdt.annotation.Nullable;
|
||||||
import org.openhab.core.library.types.DecimalType;
|
import org.openhab.core.library.types.DecimalType;
|
||||||
import org.openhab.core.library.types.OnOffType;
|
import org.openhab.core.library.types.OnOffType;
|
||||||
import org.openhab.core.library.types.QuantityType;
|
import org.openhab.core.library.types.QuantityType;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.thing.profiles.ProfileCallback;
|
import org.openhab.core.thing.profiles.ProfileCallback;
|
||||||
import org.openhab.core.thing.profiles.ProfileContext;
|
import org.openhab.core.thing.profiles.ProfileContext;
|
||||||
import org.openhab.core.thing.profiles.ProfileTypeUID;
|
import org.openhab.core.thing.profiles.ProfileTypeUID;
|
||||||
|
@ -134,7 +134,7 @@ public class SystemHysteresisStateProfile implements StateProfile {
|
||||||
final QuantityType<?> qtState = (QuantityType<?>) value;
|
final QuantityType<?> qtState = (QuantityType<?>) value;
|
||||||
final QuantityType<?> finalLower;
|
final QuantityType<?> finalLower;
|
||||||
final QuantityType<?> finalUpper;
|
final QuantityType<?> finalUpper;
|
||||||
if (lower.getUnit() == SmartHomeUnits.ONE && upper.getUnit() == SmartHomeUnits.ONE) {
|
if (lower.getUnit() == Units.ONE && upper.getUnit() == Units.ONE) {
|
||||||
// allow bounds without unit -> implicitly assume its the same as the one from the state, but warn
|
// allow bounds without unit -> implicitly assume its the same as the one from the state, but warn
|
||||||
// the user
|
// the user
|
||||||
finalLower = new QuantityType<>(lower.toBigDecimal(), qtState.getUnit());
|
finalLower = new QuantityType<>(lower.toBigDecimal(), qtState.getUnit());
|
||||||
|
|
|
@ -23,7 +23,7 @@ import org.openhab.core.library.types.DecimalType;
|
||||||
import org.openhab.core.library.types.QuantityType;
|
import org.openhab.core.library.types.QuantityType;
|
||||||
import org.openhab.core.library.unit.ImperialUnits;
|
import org.openhab.core.library.unit.ImperialUnits;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.thing.profiles.ProfileCallback;
|
import org.openhab.core.thing.profiles.ProfileCallback;
|
||||||
import org.openhab.core.thing.profiles.ProfileContext;
|
import org.openhab.core.thing.profiles.ProfileContext;
|
||||||
import org.openhab.core.thing.profiles.ProfileTypeUID;
|
import org.openhab.core.thing.profiles.ProfileTypeUID;
|
||||||
|
@ -45,9 +45,9 @@ import org.slf4j.LoggerFactory;
|
||||||
public class SystemOffsetProfile implements StateProfile {
|
public class SystemOffsetProfile implements StateProfile {
|
||||||
|
|
||||||
private static final @Nullable QuantityType<Temperature> ZERO_CELSIUS_IN_KELVIN = new QuantityType<>(0,
|
private static final @Nullable QuantityType<Temperature> ZERO_CELSIUS_IN_KELVIN = new QuantityType<>(0,
|
||||||
SIUnits.CELSIUS).toUnit(SmartHomeUnits.KELVIN);
|
SIUnits.CELSIUS).toUnit(Units.KELVIN);
|
||||||
private static final @Nullable QuantityType<Temperature> ZERO_FAHRENHEIT_IN_KELVIN = new QuantityType<>(0,
|
private static final @Nullable QuantityType<Temperature> ZERO_FAHRENHEIT_IN_KELVIN = new QuantityType<>(0,
|
||||||
ImperialUnits.FAHRENHEIT).toUnit(SmartHomeUnits.KELVIN);
|
ImperialUnits.FAHRENHEIT).toUnit(Units.KELVIN);
|
||||||
static final String OFFSET_PARAM = "offset";
|
static final String OFFSET_PARAM = "offset";
|
||||||
|
|
||||||
private final Logger logger = LoggerFactory.getLogger(SystemOffsetProfile.class);
|
private final Logger logger = LoggerFactory.getLogger(SystemOffsetProfile.class);
|
||||||
|
@ -115,7 +115,7 @@ public class SystemOffsetProfile implements StateProfile {
|
||||||
if (state instanceof QuantityType) {
|
if (state instanceof QuantityType) {
|
||||||
QuantityType qtState = (QuantityType) state;
|
QuantityType qtState = (QuantityType) state;
|
||||||
try {
|
try {
|
||||||
if (finalOffset.getUnit() == SmartHomeUnits.ONE) {
|
if (finalOffset.getUnit() == Units.ONE) {
|
||||||
// allow offsets without unit -> implicitly assume its the same as the one from the state, but warn
|
// allow offsets without unit -> implicitly assume its the same as the one from the state, but warn
|
||||||
// the user
|
// the user
|
||||||
finalOffset = new QuantityType<>(finalOffset.toBigDecimal(), qtState.getUnit());
|
finalOffset = new QuantityType<>(finalOffset.toBigDecimal(), qtState.getUnit());
|
||||||
|
@ -124,7 +124,7 @@ public class SystemOffsetProfile implements StateProfile {
|
||||||
state, offset);
|
state, offset);
|
||||||
}
|
}
|
||||||
// take care of temperatures because they start at offset -273°C = 0K
|
// take care of temperatures because they start at offset -273°C = 0K
|
||||||
if (SmartHomeUnits.KELVIN.equals(qtState.getUnit().getSystemUnit())) {
|
if (Units.KELVIN.equals(qtState.getUnit().getSystemUnit())) {
|
||||||
QuantityType<Temperature> tmp = handleTemperature(qtState, finalOffset);
|
QuantityType<Temperature> tmp = handleTemperature(qtState, finalOffset);
|
||||||
if (tmp != null) {
|
if (tmp != null) {
|
||||||
result = tmp;
|
result = tmp;
|
||||||
|
@ -135,7 +135,7 @@ public class SystemOffsetProfile implements StateProfile {
|
||||||
} catch (UnconvertibleException e) {
|
} catch (UnconvertibleException e) {
|
||||||
logger.warn("Cannot apply offset '{}' to state '{}' because types do not match.", finalOffset, qtState);
|
logger.warn("Cannot apply offset '{}' to state '{}' because types do not match.", finalOffset, qtState);
|
||||||
}
|
}
|
||||||
} else if (state instanceof DecimalType && finalOffset.getUnit() == SmartHomeUnits.ONE) {
|
} else if (state instanceof DecimalType && finalOffset.getUnit() == Units.ONE) {
|
||||||
DecimalType decState = (DecimalType) state;
|
DecimalType decState = (DecimalType) state;
|
||||||
result = new DecimalType(decState.toBigDecimal().add(finalOffset.toBigDecimal()));
|
result = new DecimalType(decState.toBigDecimal().add(finalOffset.toBigDecimal()));
|
||||||
} else {
|
} else {
|
||||||
|
@ -150,8 +150,8 @@ public class SystemOffsetProfile implements StateProfile {
|
||||||
private @Nullable QuantityType<Temperature> handleTemperature(QuantityType<Temperature> qtState,
|
private @Nullable QuantityType<Temperature> handleTemperature(QuantityType<Temperature> qtState,
|
||||||
QuantityType<Temperature> offset) {
|
QuantityType<Temperature> offset) {
|
||||||
// do the math in Kelvin and afterwards convert it back to the unit of the state
|
// do the math in Kelvin and afterwards convert it back to the unit of the state
|
||||||
final QuantityType<Temperature> kelvinState = qtState.toUnit(SmartHomeUnits.KELVIN);
|
final QuantityType<Temperature> kelvinState = qtState.toUnit(Units.KELVIN);
|
||||||
final QuantityType<Temperature> kelvinOffset = offset.toUnit(SmartHomeUnits.KELVIN);
|
final QuantityType<Temperature> kelvinOffset = offset.toUnit(Units.KELVIN);
|
||||||
if (kelvinState == null || kelvinOffset == null) {
|
if (kelvinState == null || kelvinOffset == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@ import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
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.core.io.http.servlet.SmartHomeServlet;
|
import org.openhab.core.io.http.servlet.OpenHABServlet;
|
||||||
import org.openhab.core.ui.icon.IconProvider;
|
import org.openhab.core.ui.icon.IconProvider;
|
||||||
import org.openhab.core.ui.icon.IconSet.Format;
|
import org.openhab.core.ui.icon.IconSet.Format;
|
||||||
import org.osgi.service.component.annotations.Activate;
|
import org.osgi.service.component.annotations.Activate;
|
||||||
|
@ -48,7 +48,7 @@ import org.slf4j.LoggerFactory;
|
||||||
*/
|
*/
|
||||||
@Component
|
@Component
|
||||||
@NonNullByDefault
|
@NonNullByDefault
|
||||||
public class IconServlet extends SmartHomeServlet {
|
public class IconServlet extends OpenHABServlet {
|
||||||
|
|
||||||
private static final long serialVersionUID = 2880642275858634578L;
|
private static final long serialVersionUID = 2880642275858634578L;
|
||||||
|
|
||||||
|
|
|
@ -33,7 +33,7 @@ import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
import org.openhab.core.config.core.ConfigurableService;
|
import org.openhab.core.config.core.ConfigurableService;
|
||||||
import org.openhab.core.io.http.servlet.SmartHomeServlet;
|
import org.openhab.core.io.http.servlet.OpenHABServlet;
|
||||||
import org.openhab.core.items.ItemNotFoundException;
|
import org.openhab.core.items.ItemNotFoundException;
|
||||||
import org.openhab.core.ui.chart.ChartProvider;
|
import org.openhab.core.ui.chart.ChartProvider;
|
||||||
import org.osgi.framework.Constants;
|
import org.osgi.framework.Constants;
|
||||||
|
@ -68,7 +68,7 @@ import org.osgi.service.http.HttpService;
|
||||||
@Component(immediate = true, service = ChartServlet.class, configurationPid = "org.openhab.chart", //
|
@Component(immediate = true, service = ChartServlet.class, configurationPid = "org.openhab.chart", //
|
||||||
property = Constants.SERVICE_PID + "=org.openhab.chart")
|
property = Constants.SERVICE_PID + "=org.openhab.chart")
|
||||||
@ConfigurableService(category = "system", label = "Charts", description_uri = ChartServlet.CONFIG_URI)
|
@ConfigurableService(category = "system", label = "Charts", description_uri = ChartServlet.CONFIG_URI)
|
||||||
public class ChartServlet extends SmartHomeServlet {
|
public class ChartServlet extends OpenHABServlet {
|
||||||
|
|
||||||
private static final long serialVersionUID = 7700873790924746422L;
|
private static final long serialVersionUID = 7700873790924746422L;
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ import org.openhab.core.library.dimension.Intensity;
|
||||||
import org.openhab.core.library.types.PointType;
|
import org.openhab.core.library.types.PointType;
|
||||||
import org.openhab.core.library.unit.ImperialUnits;
|
import org.openhab.core.library.unit.ImperialUnits;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.osgi.framework.Bundle;
|
import org.osgi.framework.Bundle;
|
||||||
import org.osgi.framework.Constants;
|
import org.osgi.framework.Constants;
|
||||||
import org.osgi.service.component.ComponentContext;
|
import org.osgi.service.component.ComponentContext;
|
||||||
|
@ -364,18 +364,18 @@ public class I18nProviderImpl
|
||||||
dimensionMap.put(Length.class, lengthMap);
|
dimensionMap.put(Length.class, lengthMap);
|
||||||
|
|
||||||
Map<SystemOfUnits, Unit<? extends Quantity<?>>> intensityMap = new HashMap<>();
|
Map<SystemOfUnits, Unit<? extends Quantity<?>>> intensityMap = new HashMap<>();
|
||||||
intensityMap.put(SIUnits.getInstance(), SmartHomeUnits.IRRADIANCE);
|
intensityMap.put(SIUnits.getInstance(), Units.IRRADIANCE);
|
||||||
intensityMap.put(ImperialUnits.getInstance(), SmartHomeUnits.IRRADIANCE);
|
intensityMap.put(ImperialUnits.getInstance(), Units.IRRADIANCE);
|
||||||
dimensionMap.put(Intensity.class, intensityMap);
|
dimensionMap.put(Intensity.class, intensityMap);
|
||||||
|
|
||||||
Map<SystemOfUnits, Unit<? extends Quantity<?>>> percentMap = new HashMap<>();
|
Map<SystemOfUnits, Unit<? extends Quantity<?>>> percentMap = new HashMap<>();
|
||||||
percentMap.put(SIUnits.getInstance(), SmartHomeUnits.ONE);
|
percentMap.put(SIUnits.getInstance(), Units.ONE);
|
||||||
percentMap.put(ImperialUnits.getInstance(), SmartHomeUnits.ONE);
|
percentMap.put(ImperialUnits.getInstance(), Units.ONE);
|
||||||
dimensionMap.put(Dimensionless.class, percentMap);
|
dimensionMap.put(Dimensionless.class, percentMap);
|
||||||
|
|
||||||
Map<SystemOfUnits, Unit<? extends Quantity<?>>> angleMap = new HashMap<>();
|
Map<SystemOfUnits, Unit<? extends Quantity<?>>> angleMap = new HashMap<>();
|
||||||
angleMap.put(SIUnits.getInstance(), SmartHomeUnits.DEGREE_ANGLE);
|
angleMap.put(SIUnits.getInstance(), Units.DEGREE_ANGLE);
|
||||||
angleMap.put(ImperialUnits.getInstance(), SmartHomeUnits.DEGREE_ANGLE);
|
angleMap.put(ImperialUnits.getInstance(), Units.DEGREE_ANGLE);
|
||||||
dimensionMap.put(Angle.class, angleMap);
|
dimensionMap.put(Angle.class, angleMap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ package org.openhab.core.internal.library.unit;
|
||||||
|
|
||||||
import org.openhab.core.library.unit.ImperialUnits;
|
import org.openhab.core.library.unit.ImperialUnits;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Make sure static blocks from {@link SIUnits} & {@link ImperialUnits} are executed to initialize the unit parser.
|
* Make sure static blocks from {@link SIUnits} & {@link ImperialUnits} are executed to initialize the unit parser.
|
||||||
|
@ -24,7 +24,7 @@ import org.openhab.core.library.unit.SmartHomeUnits;
|
||||||
public class UnitInitializer {
|
public class UnitInitializer {
|
||||||
|
|
||||||
static {
|
static {
|
||||||
SmartHomeUnits.getInstance();
|
Units.getInstance();
|
||||||
SIUnits.getInstance();
|
SIUnits.getInstance();
|
||||||
ImperialUnits.getInstance();
|
ImperialUnits.getInstance();
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,7 @@ import java.math.RoundingMode;
|
||||||
|
|
||||||
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.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.types.State;
|
import org.openhab.core.types.State;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -87,7 +87,7 @@ public class PercentType extends DecimalType {
|
||||||
} else if (target == HSBType.class) {
|
} else if (target == HSBType.class) {
|
||||||
return target.cast(new HSBType(DecimalType.ZERO, PercentType.ZERO, this));
|
return target.cast(new HSBType(DecimalType.ZERO, PercentType.ZERO, this));
|
||||||
} else if (target == QuantityType.class) {
|
} else if (target == QuantityType.class) {
|
||||||
return target.cast(new QuantityType<>(toBigDecimal().doubleValue(), SmartHomeUnits.PERCENT));
|
return target.cast(new QuantityType<>(toBigDecimal().doubleValue(), Units.PERCENT));
|
||||||
} else {
|
} else {
|
||||||
return defaultConversion(target);
|
return defaultConversion(target);
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,7 +33,7 @@ import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||||
import org.eclipse.jdt.annotation.Nullable;
|
import org.eclipse.jdt.annotation.Nullable;
|
||||||
import org.openhab.core.internal.library.unit.UnitInitializer;
|
import org.openhab.core.internal.library.unit.UnitInitializer;
|
||||||
import org.openhab.core.library.unit.MetricPrefix;
|
import org.openhab.core.library.unit.MetricPrefix;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.types.Command;
|
import org.openhab.core.types.Command;
|
||||||
import org.openhab.core.types.PrimitiveType;
|
import org.openhab.core.types.PrimitiveType;
|
||||||
import org.openhab.core.types.State;
|
import org.openhab.core.types.State;
|
||||||
|
@ -238,15 +238,15 @@ public class QuantityType<T extends Quantity<T>> extends Number
|
||||||
final String formatPattern;
|
final String formatPattern;
|
||||||
|
|
||||||
if (unitPlaceholder) {
|
if (unitPlaceholder) {
|
||||||
String unitSymbol = getUnit().equals(SmartHomeUnits.PERCENT) ? "%%" : getUnit().toString();
|
String unitSymbol = getUnit().equals(Units.PERCENT) ? "%%" : getUnit().toString();
|
||||||
formatPattern = pattern.replace(UnitUtils.UNIT_PLACEHOLDER, unitSymbol);
|
formatPattern = pattern.replace(UnitUtils.UNIT_PLACEHOLDER, unitSymbol);
|
||||||
} else {
|
} else {
|
||||||
formatPattern = pattern;
|
formatPattern = pattern;
|
||||||
}
|
}
|
||||||
|
|
||||||
// The dimension could be a time value thus we want to support patterns to format datetime
|
// The dimension could be a time value thus we want to support patterns to format datetime
|
||||||
if (quantity.getUnit().isCompatible(SmartHomeUnits.SECOND) && !unitPlaceholder) {
|
if (quantity.getUnit().isCompatible(Units.SECOND) && !unitPlaceholder) {
|
||||||
QuantityType<T> millis = toUnit(MetricPrefix.MILLI(SmartHomeUnits.SECOND));
|
QuantityType<T> millis = toUnit(MetricPrefix.MILLI(Units.SECOND));
|
||||||
if (millis != null) {
|
if (millis != null) {
|
||||||
try {
|
try {
|
||||||
return String.format(formatPattern,
|
return String.format(formatPattern,
|
||||||
|
@ -309,7 +309,7 @@ public class QuantityType<T extends Quantity<T>> extends Number
|
||||||
if (target == OnOffType.class) {
|
if (target == OnOffType.class) {
|
||||||
if (intValue() == 0) {
|
if (intValue() == 0) {
|
||||||
return target.cast(OnOffType.OFF);
|
return target.cast(OnOffType.OFF);
|
||||||
} else if (SmartHomeUnits.PERCENT.equals(getUnit())) {
|
} else if (Units.PERCENT.equals(getUnit())) {
|
||||||
return target.cast(toBigDecimal().compareTo(BigDecimal.ZERO) > 0 ? OnOffType.ON : OnOffType.OFF);
|
return target.cast(toBigDecimal().compareTo(BigDecimal.ZERO) > 0 ? OnOffType.ON : OnOffType.OFF);
|
||||||
} else if (toBigDecimal().compareTo(BigDecimal.ONE) == 0) {
|
} else if (toBigDecimal().compareTo(BigDecimal.ONE) == 0) {
|
||||||
return target.cast(OnOffType.ON);
|
return target.cast(OnOffType.ON);
|
||||||
|
@ -336,7 +336,7 @@ public class QuantityType<T extends Quantity<T>> extends Number
|
||||||
return target.cast(
|
return target.cast(
|
||||||
new HSBType(DecimalType.ZERO, PercentType.ZERO, new PercentType(toBigDecimal().multiply(HUNDRED))));
|
new HSBType(DecimalType.ZERO, PercentType.ZERO, new PercentType(toBigDecimal().multiply(HUNDRED))));
|
||||||
} else if (target == PercentType.class) {
|
} else if (target == PercentType.class) {
|
||||||
if (SmartHomeUnits.PERCENT.equals(getUnit())) {
|
if (Units.PERCENT.equals(getUnit())) {
|
||||||
return target.cast(new PercentType(toBigDecimal()));
|
return target.cast(new PercentType(toBigDecimal()));
|
||||||
}
|
}
|
||||||
return target.cast(new PercentType(toBigDecimal().multiply(HUNDRED)));
|
return target.cast(new PercentType(toBigDecimal().multiply(HUNDRED)));
|
||||||
|
|
|
@ -67,7 +67,6 @@ import tec.uom.se.function.RationalConverter;
|
||||||
import tec.uom.se.unit.AlternateUnit;
|
import tec.uom.se.unit.AlternateUnit;
|
||||||
import tec.uom.se.unit.ProductUnit;
|
import tec.uom.se.unit.ProductUnit;
|
||||||
import tec.uom.se.unit.TransformedUnit;
|
import tec.uom.se.unit.TransformedUnit;
|
||||||
import tec.uom.se.unit.Units;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Delegate common units to {@link Units} to hide this dependency from the rest of openHAB.
|
* Delegate common units to {@link Units} to hide this dependency from the rest of openHAB.
|
||||||
|
@ -77,108 +76,115 @@ import tec.uom.se.unit.Units;
|
||||||
* @author Henning Treu - Initial contribution
|
* @author Henning Treu - Initial contribution
|
||||||
*/
|
*/
|
||||||
@NonNullByDefault
|
@NonNullByDefault
|
||||||
public final class SmartHomeUnits extends CustomUnits {
|
public final class Units extends CustomUnits {
|
||||||
|
|
||||||
private static final SmartHomeUnits INSTANCE = new SmartHomeUnits();
|
private static final Units INSTANCE = new Units();
|
||||||
|
|
||||||
// Alphabetical ordered by Unit.
|
// Alphabetical ordered by Unit.
|
||||||
public static final Unit<Acceleration> METRE_PER_SQUARE_SECOND = addUnit(Units.METRE_PER_SQUARE_SECOND);
|
public static final Unit<Acceleration> METRE_PER_SQUARE_SECOND = addUnit(
|
||||||
|
tec.uom.se.unit.Units.METRE_PER_SQUARE_SECOND);
|
||||||
public static final Unit<Acceleration> STANDARD_GRAVITY = addUnit(METRE_PER_SQUARE_SECOND.multiply(9.80665));
|
public static final Unit<Acceleration> STANDARD_GRAVITY = addUnit(METRE_PER_SQUARE_SECOND.multiply(9.80665));
|
||||||
public static final Unit<AmountOfSubstance> MOLE = addUnit(Units.MOLE);
|
public static final Unit<AmountOfSubstance> MOLE = addUnit(tec.uom.se.unit.Units.MOLE);
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public static final Unit<AmountOfSubstance> DEUTSCHE_HAERTE = addUnit(
|
public static final Unit<AmountOfSubstance> DEUTSCHE_HAERTE = addUnit(
|
||||||
new TransformedUnit<>("°dH", (Unit<AmountOfSubstance>) MetricPrefix.MILLI(Units.MOLE).divide(Units.LITRE),
|
new TransformedUnit<>("°dH", (Unit<AmountOfSubstance>) MetricPrefix.MILLI(tec.uom.se.unit.Units.MOLE)
|
||||||
RationalConverter.of(5.6, 1)));
|
.divide(tec.uom.se.unit.Units.LITRE), RationalConverter.of(5.6, 1)));
|
||||||
public static final Unit<Angle> DEGREE_ANGLE = addUnit(new TransformedUnit<>(Units.RADIAN,
|
public static final Unit<Angle> DEGREE_ANGLE = addUnit(new TransformedUnit<>(tec.uom.se.unit.Units.RADIAN,
|
||||||
new PiMultiplierConverter().concatenate(new RationalConverter(BigInteger.ONE, BigInteger.valueOf(180)))));
|
new PiMultiplierConverter().concatenate(new RationalConverter(BigInteger.ONE, BigInteger.valueOf(180)))));
|
||||||
public static final Unit<Angle> RADIAN = addUnit(Units.RADIAN);
|
public static final Unit<Angle> RADIAN = addUnit(tec.uom.se.unit.Units.RADIAN);
|
||||||
public static final Unit<ArealDensity> DOBSON_UNIT = addUnit(
|
public static final Unit<ArealDensity> DOBSON_UNIT = addUnit(new ProductUnit<ArealDensity>(MetricPrefix
|
||||||
new ProductUnit<ArealDensity>(MetricPrefix.MILLI(Units.MOLE).multiply(0.4462).divide(Units.SQUARE_METRE)));
|
.MILLI(tec.uom.se.unit.Units.MOLE).multiply(0.4462).divide(tec.uom.se.unit.Units.SQUARE_METRE)));
|
||||||
public static final Unit<CatalyticActivity> KATAL = addUnit(Units.KATAL);
|
public static final Unit<CatalyticActivity> KATAL = addUnit(tec.uom.se.unit.Units.KATAL);
|
||||||
public static final Unit<Density> KILOGRAM_PER_CUBICMETRE = addUnit(
|
public static final Unit<Density> KILOGRAM_PER_CUBICMETRE = addUnit(
|
||||||
new ProductUnit<Density>(Units.KILOGRAM.divide(Units.CUBIC_METRE)));
|
new ProductUnit<Density>(tec.uom.se.unit.Units.KILOGRAM.divide(tec.uom.se.unit.Units.CUBIC_METRE)));
|
||||||
public static final Unit<Density> MICROGRAM_PER_CUBICMETRE = addUnit(new TransformedUnit<>(KILOGRAM_PER_CUBICMETRE,
|
public static final Unit<Density> MICROGRAM_PER_CUBICMETRE = addUnit(new TransformedUnit<>(KILOGRAM_PER_CUBICMETRE,
|
||||||
new RationalConverter(BigInteger.ONE, BigInteger.valueOf(1000000000))));
|
new RationalConverter(BigInteger.ONE, BigInteger.valueOf(1000000000))));
|
||||||
public static final Unit<Dimensionless> ONE = addUnit(AbstractUnit.ONE);
|
public static final Unit<Dimensionless> ONE = addUnit(AbstractUnit.ONE);
|
||||||
public static final Unit<Dimensionless> PERCENT = addUnit(Units.PERCENT);
|
public static final Unit<Dimensionless> PERCENT = addUnit(tec.uom.se.unit.Units.PERCENT);
|
||||||
public static final Unit<Dimensionless> PARTS_PER_BILLION = addUnit(
|
public static final Unit<Dimensionless> PARTS_PER_BILLION = addUnit(
|
||||||
new TransformedUnit<>(ONE, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(1000000000))));
|
new TransformedUnit<>(ONE, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(1000000000))));
|
||||||
public static final Unit<Dimensionless> PARTS_PER_MILLION = addUnit(
|
public static final Unit<Dimensionless> PARTS_PER_MILLION = addUnit(
|
||||||
new TransformedUnit<>(ONE, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(1000000))));
|
new TransformedUnit<>(ONE, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(1000000))));
|
||||||
public static final Unit<Dimensionless> DECIBEL = addUnit(ONE.transform(
|
public static final Unit<Dimensionless> DECIBEL = addUnit(ONE.transform(
|
||||||
new LogConverter(10).inverse().concatenate(new RationalConverter(BigInteger.ONE, BigInteger.TEN))));
|
new LogConverter(10).inverse().concatenate(new RationalConverter(BigInteger.ONE, BigInteger.TEN))));
|
||||||
public static final Unit<ElectricCurrent> AMPERE = addUnit(Units.AMPERE);
|
public static final Unit<ElectricCurrent> AMPERE = addUnit(tec.uom.se.unit.Units.AMPERE);
|
||||||
public static final Unit<ElectricCapacitance> FARAD = addUnit(Units.FARAD);
|
public static final Unit<ElectricCapacitance> FARAD = addUnit(tec.uom.se.unit.Units.FARAD);
|
||||||
public static final Unit<ElectricCharge> COULOMB = addUnit(Units.COULOMB);
|
public static final Unit<ElectricCharge> COULOMB = addUnit(tec.uom.se.unit.Units.COULOMB);
|
||||||
public static final Unit<ElectricCharge> AMPERE_HOUR = addUnit(Units.COULOMB.multiply(3600));
|
public static final Unit<ElectricCharge> AMPERE_HOUR = addUnit(tec.uom.se.unit.Units.COULOMB.multiply(3600));
|
||||||
public static final Unit<ElectricCharge> MILLIAMPERE_HOUR = addUnit(MetricPrefix.MILLI(AMPERE_HOUR));
|
public static final Unit<ElectricCharge> MILLIAMPERE_HOUR = addUnit(MetricPrefix.MILLI(AMPERE_HOUR));
|
||||||
public static final Unit<ElectricConductance> SIEMENS = addUnit(Units.SIEMENS);
|
public static final Unit<ElectricConductance> SIEMENS = addUnit(tec.uom.se.unit.Units.SIEMENS);
|
||||||
public static final Unit<ElectricConductivity> SIEMENS_PER_METRE = addUnit(
|
public static final Unit<ElectricConductivity> SIEMENS_PER_METRE = addUnit(
|
||||||
new ProductUnit<ElectricConductivity>(Units.SIEMENS.divide(Units.METRE)));
|
new ProductUnit<ElectricConductivity>(tec.uom.se.unit.Units.SIEMENS.divide(tec.uom.se.unit.Units.METRE)));
|
||||||
public static final Unit<ElectricInductance> HENRY = addUnit(Units.HENRY);
|
public static final Unit<ElectricInductance> HENRY = addUnit(tec.uom.se.unit.Units.HENRY);
|
||||||
public static final Unit<ElectricPotential> VOLT = addUnit(Units.VOLT);
|
public static final Unit<ElectricPotential> VOLT = addUnit(tec.uom.se.unit.Units.VOLT);
|
||||||
public static final Unit<ElectricResistance> OHM = addUnit(Units.OHM);
|
public static final Unit<ElectricResistance> OHM = addUnit(tec.uom.se.unit.Units.OHM);
|
||||||
public static final Unit<Energy> JOULE = addUnit(Units.JOULE);
|
public static final Unit<Energy> JOULE = addUnit(tec.uom.se.unit.Units.JOULE);
|
||||||
public static final Unit<Energy> WATT_SECOND = addUnit(new ProductUnit<>(Units.WATT.multiply(Units.SECOND)));
|
public static final Unit<Energy> WATT_SECOND = addUnit(
|
||||||
public static final Unit<Energy> WATT_HOUR = addUnit(new ProductUnit<>(Units.WATT.multiply(Units.HOUR)));
|
new ProductUnit<>(tec.uom.se.unit.Units.WATT.multiply(tec.uom.se.unit.Units.SECOND)));
|
||||||
|
public static final Unit<Energy> WATT_HOUR = addUnit(
|
||||||
|
new ProductUnit<>(tec.uom.se.unit.Units.WATT.multiply(tec.uom.se.unit.Units.HOUR)));
|
||||||
public static final Unit<Energy> KILOWATT_HOUR = addUnit(MetricPrefix.KILO(WATT_HOUR));
|
public static final Unit<Energy> KILOWATT_HOUR = addUnit(MetricPrefix.KILO(WATT_HOUR));
|
||||||
public static final Unit<Energy> MEGAWATT_HOUR = addUnit(MetricPrefix.MEGA(WATT_HOUR));
|
public static final Unit<Energy> MEGAWATT_HOUR = addUnit(MetricPrefix.MEGA(WATT_HOUR));
|
||||||
public static final Unit<Power> VAR = addUnit(new AlternateUnit<>(Units.WATT, "var"));
|
public static final Unit<Power> VAR = addUnit(new AlternateUnit<>(tec.uom.se.unit.Units.WATT, "var"));
|
||||||
public static final Unit<Power> KILOVAR = addUnit(MetricPrefix.KILO(VAR));
|
public static final Unit<Power> KILOVAR = addUnit(MetricPrefix.KILO(VAR));
|
||||||
public static final Unit<Energy> VAR_HOUR = addUnit(new ProductUnit<>(VAR.multiply(Units.HOUR)), Energy.class);
|
public static final Unit<Energy> VAR_HOUR = addUnit(new ProductUnit<>(VAR.multiply(tec.uom.se.unit.Units.HOUR)),
|
||||||
public static final Unit<Energy> KILOVAR_HOUR = addUnit(MetricPrefix.KILO(VAR_HOUR));
|
|
||||||
public static final Unit<Power> VOLT_AMPERE = addUnit(new AlternateUnit<>(Units.WATT, "VA"));
|
|
||||||
public static final Unit<Energy> VOLT_AMPERE_HOUR = addUnit(new ProductUnit<>(VOLT_AMPERE.multiply(Units.HOUR)),
|
|
||||||
Energy.class);
|
Energy.class);
|
||||||
public static final Unit<Force> NEWTON = addUnit(Units.NEWTON);
|
public static final Unit<Energy> KILOVAR_HOUR = addUnit(MetricPrefix.KILO(VAR_HOUR));
|
||||||
public static final Unit<Frequency> HERTZ = addUnit(Units.HERTZ);
|
public static final Unit<Power> VOLT_AMPERE = addUnit(new AlternateUnit<>(tec.uom.se.unit.Units.WATT, "VA"));
|
||||||
public static final Unit<Intensity> IRRADIANCE = addUnit(new ProductUnit<>(Units.WATT.divide(Units.SQUARE_METRE)));
|
public static final Unit<Energy> VOLT_AMPERE_HOUR = addUnit(
|
||||||
|
new ProductUnit<>(VOLT_AMPERE.multiply(tec.uom.se.unit.Units.HOUR)), Energy.class);
|
||||||
|
public static final Unit<Force> NEWTON = addUnit(tec.uom.se.unit.Units.NEWTON);
|
||||||
|
public static final Unit<Frequency> HERTZ = addUnit(tec.uom.se.unit.Units.HERTZ);
|
||||||
|
public static final Unit<Intensity> IRRADIANCE = addUnit(
|
||||||
|
new ProductUnit<>(tec.uom.se.unit.Units.WATT.divide(tec.uom.se.unit.Units.SQUARE_METRE)));
|
||||||
public static final Unit<Intensity> MICROWATT_PER_SQUARE_CENTIMETRE = addUnit(
|
public static final Unit<Intensity> MICROWATT_PER_SQUARE_CENTIMETRE = addUnit(
|
||||||
new TransformedUnit<>(IRRADIANCE, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(100))));
|
new TransformedUnit<>(IRRADIANCE, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(100))));
|
||||||
public static final Unit<Illuminance> LUX = addUnit(Units.LUX);
|
public static final Unit<Illuminance> LUX = addUnit(tec.uom.se.unit.Units.LUX);
|
||||||
public static final Unit<LuminousFlux> LUMEN = addUnit(Units.LUMEN);
|
public static final Unit<LuminousFlux> LUMEN = addUnit(tec.uom.se.unit.Units.LUMEN);
|
||||||
public static final Unit<LuminousIntensity> CANDELA = addUnit(Units.CANDELA);
|
public static final Unit<LuminousIntensity> CANDELA = addUnit(tec.uom.se.unit.Units.CANDELA);
|
||||||
public static final Unit<MagneticFlux> WEBER = addUnit(Units.WEBER);
|
public static final Unit<MagneticFlux> WEBER = addUnit(tec.uom.se.unit.Units.WEBER);
|
||||||
public static final Unit<MagneticFluxDensity> TESLA = addUnit(Units.TESLA);
|
public static final Unit<MagneticFluxDensity> TESLA = addUnit(tec.uom.se.unit.Units.TESLA);
|
||||||
public static final Unit<Power> WATT = addUnit(Units.WATT);
|
public static final Unit<Power> WATT = addUnit(tec.uom.se.unit.Units.WATT);
|
||||||
public static final Unit<Power> DECIBEL_MILLIWATTS = new TransformedUnit<>("dBm", MetricPrefix.MILLI(WATT),
|
public static final Unit<Power> DECIBEL_MILLIWATTS = new TransformedUnit<>("dBm", MetricPrefix.MILLI(WATT),
|
||||||
new ExpConverter(10.0).concatenate(new MultiplyConverter(0.1)));
|
new ExpConverter(10.0).concatenate(new MultiplyConverter(0.1)));
|
||||||
public static final Unit<Pressure> MILLIMETRE_OF_MERCURY = addUnit(new TransformedUnit<>("mmHg", Units.PASCAL,
|
public static final Unit<Pressure> MILLIMETRE_OF_MERCURY = addUnit(
|
||||||
|
new TransformedUnit<>("mmHg", tec.uom.se.unit.Units.PASCAL,
|
||||||
new RationalConverter(BigInteger.valueOf(133322368), BigInteger.valueOf(1000000))));
|
new RationalConverter(BigInteger.valueOf(133322368), BigInteger.valueOf(1000000))));
|
||||||
public static final Unit<Pressure> BAR = addUnit(new TransformedUnit<>("bar", Units.PASCAL,
|
public static final Unit<Pressure> BAR = addUnit(new TransformedUnit<>("bar", tec.uom.se.unit.Units.PASCAL,
|
||||||
new RationalConverter(BigInteger.valueOf(100000), BigInteger.ONE)));
|
new RationalConverter(BigInteger.valueOf(100000), BigInteger.ONE)));
|
||||||
public static final Unit<Pressure> MILLIBAR = addUnit(MetricPrefix.MILLI(BAR));
|
public static final Unit<Pressure> MILLIBAR = addUnit(MetricPrefix.MILLI(BAR));
|
||||||
public static final Unit<Radioactivity> BECQUEREL = addUnit(Units.BECQUEREL);
|
public static final Unit<Radioactivity> BECQUEREL = addUnit(tec.uom.se.unit.Units.BECQUEREL);
|
||||||
public static final Unit<Density> BECQUEREL_PER_CUBIC_METRE = addUnit(
|
public static final Unit<Density> BECQUEREL_PER_CUBIC_METRE = addUnit(
|
||||||
new ProductUnit<>(Units.BECQUEREL.divide(Units.CUBIC_METRE)));
|
new ProductUnit<>(tec.uom.se.unit.Units.BECQUEREL.divide(tec.uom.se.unit.Units.CUBIC_METRE)));
|
||||||
public static final Unit<RadiationDoseAbsorbed> GRAY = addUnit(Units.GRAY);
|
public static final Unit<RadiationDoseAbsorbed> GRAY = addUnit(tec.uom.se.unit.Units.GRAY);
|
||||||
public static final Unit<RadiationDoseEffective> SIEVERT = addUnit(Units.SIEVERT);
|
public static final Unit<RadiationDoseEffective> SIEVERT = addUnit(tec.uom.se.unit.Units.SIEVERT);
|
||||||
public static final Unit<Speed> MILLIMETRE_PER_HOUR = addUnit(new TransformedUnit<>("mm/h",
|
public static final Unit<Speed> MILLIMETRE_PER_HOUR = addUnit(
|
||||||
Units.KILOMETRE_PER_HOUR, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(1000000))));
|
new TransformedUnit<>("mm/h", tec.uom.se.unit.Units.KILOMETRE_PER_HOUR,
|
||||||
|
new RationalConverter(BigInteger.ONE, BigInteger.valueOf(1000000))));
|
||||||
public static final Unit<Speed> INCHES_PER_HOUR = addUnit(new TransformedUnit<>("in/h",
|
public static final Unit<Speed> INCHES_PER_HOUR = addUnit(new TransformedUnit<>("in/h",
|
||||||
ImperialUnits.MILES_PER_HOUR, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(63360))));
|
ImperialUnits.MILES_PER_HOUR, new RationalConverter(BigInteger.ONE, BigInteger.valueOf(63360))));
|
||||||
public static final Unit<Speed> METRE_PER_SECOND = addUnit(Units.METRE_PER_SECOND);
|
public static final Unit<Speed> METRE_PER_SECOND = addUnit(tec.uom.se.unit.Units.METRE_PER_SECOND);
|
||||||
public static final Unit<Speed> KNOT = addUnit(new TransformedUnit<>("kn", Units.KILOMETRE_PER_HOUR,
|
public static final Unit<Speed> KNOT = addUnit(new TransformedUnit<>("kn", tec.uom.se.unit.Units.KILOMETRE_PER_HOUR,
|
||||||
new RationalConverter(BigInteger.valueOf(1852), BigInteger.valueOf(1000))));
|
new RationalConverter(BigInteger.valueOf(1852), BigInteger.valueOf(1000))));
|
||||||
public static final Unit<SolidAngle> STERADIAN = addUnit(Units.STERADIAN);
|
public static final Unit<SolidAngle> STERADIAN = addUnit(tec.uom.se.unit.Units.STERADIAN);
|
||||||
public static final Unit<Temperature> KELVIN = addUnit(Units.KELVIN);
|
public static final Unit<Temperature> KELVIN = addUnit(tec.uom.se.unit.Units.KELVIN);
|
||||||
public static final Unit<Time> SECOND = addUnit(Units.SECOND);
|
public static final Unit<Time> SECOND = addUnit(tec.uom.se.unit.Units.SECOND);
|
||||||
public static final Unit<Time> MINUTE = addUnit(Units.MINUTE);
|
public static final Unit<Time> MINUTE = addUnit(tec.uom.se.unit.Units.MINUTE);
|
||||||
public static final Unit<Time> HOUR = addUnit(Units.HOUR);
|
public static final Unit<Time> HOUR = addUnit(tec.uom.se.unit.Units.HOUR);
|
||||||
public static final Unit<Time> DAY = addUnit(Units.DAY);
|
public static final Unit<Time> DAY = addUnit(tec.uom.se.unit.Units.DAY);
|
||||||
public static final Unit<Time> WEEK = addUnit(Units.WEEK);
|
public static final Unit<Time> WEEK = addUnit(tec.uom.se.unit.Units.WEEK);
|
||||||
public static final Unit<Time> YEAR = addUnit(Units.YEAR);
|
public static final Unit<Time> YEAR = addUnit(tec.uom.se.unit.Units.YEAR);
|
||||||
public static final Unit<Volume> LITRE = addUnit(Units.LITRE);
|
public static final Unit<Volume> LITRE = addUnit(tec.uom.se.unit.Units.LITRE);
|
||||||
public static final Unit<VolumetricFlowRate> LITRE_PER_MINUTE = addUnit(
|
public static final Unit<VolumetricFlowRate> LITRE_PER_MINUTE = addUnit(
|
||||||
new ProductUnit<VolumetricFlowRate>(Units.LITRE.divide(Units.MINUTE)));
|
new ProductUnit<VolumetricFlowRate>(tec.uom.se.unit.Units.LITRE.divide(tec.uom.se.unit.Units.MINUTE)));
|
||||||
public static final Unit<VolumetricFlowRate> CUBICMETRE_PER_SECOND = addUnit(
|
public static final Unit<VolumetricFlowRate> CUBICMETRE_PER_SECOND = addUnit(new ProductUnit<VolumetricFlowRate>(
|
||||||
new ProductUnit<VolumetricFlowRate>(Units.CUBIC_METRE.divide(Units.SECOND)));
|
tec.uom.se.unit.Units.CUBIC_METRE.divide(tec.uom.se.unit.Units.SECOND)));
|
||||||
public static final Unit<VolumetricFlowRate> CUBICMETRE_PER_MINUTE = addUnit(
|
public static final Unit<VolumetricFlowRate> CUBICMETRE_PER_MINUTE = addUnit(new ProductUnit<VolumetricFlowRate>(
|
||||||
new ProductUnit<VolumetricFlowRate>(Units.CUBIC_METRE.divide(Units.MINUTE)));
|
tec.uom.se.unit.Units.CUBIC_METRE.divide(tec.uom.se.unit.Units.MINUTE)));
|
||||||
public static final Unit<VolumetricFlowRate> CUBICMETRE_PER_HOUR = addUnit(
|
public static final Unit<VolumetricFlowRate> CUBICMETRE_PER_HOUR = addUnit(
|
||||||
new ProductUnit<VolumetricFlowRate>(Units.CUBIC_METRE.divide(Units.HOUR)));
|
new ProductUnit<VolumetricFlowRate>(tec.uom.se.unit.Units.CUBIC_METRE.divide(tec.uom.se.unit.Units.HOUR)));
|
||||||
public static final Unit<VolumetricFlowRate> CUBICMETRE_PER_DAY = addUnit(
|
public static final Unit<VolumetricFlowRate> CUBICMETRE_PER_DAY = addUnit(
|
||||||
new ProductUnit<VolumetricFlowRate>(Units.CUBIC_METRE.divide(Units.DAY)));
|
new ProductUnit<VolumetricFlowRate>(tec.uom.se.unit.Units.CUBIC_METRE.divide(tec.uom.se.unit.Units.DAY)));
|
||||||
public static final Unit<DataAmount> BIT = addUnit(new AlternateUnit<>(ONE, "bit"));
|
public static final Unit<DataAmount> BIT = addUnit(new AlternateUnit<>(ONE, "bit"));
|
||||||
public static final Unit<DataAmount> KILOBIT = addUnit(MetricPrefix.KILO(BIT));
|
public static final Unit<DataAmount> KILOBIT = addUnit(MetricPrefix.KILO(BIT));
|
||||||
public static final Unit<DataAmount> MEGABIT = addUnit(MetricPrefix.MEGA(BIT));
|
public static final Unit<DataAmount> MEGABIT = addUnit(MetricPrefix.MEGA(BIT));
|
||||||
|
@ -203,7 +209,7 @@ public final class SmartHomeUnits extends CustomUnits {
|
||||||
public static final Unit<DataAmount> TEBIOCTET = addUnit(BinaryPrefix.TEBI(OCTET));
|
public static final Unit<DataAmount> TEBIOCTET = addUnit(BinaryPrefix.TEBI(OCTET));
|
||||||
public static final Unit<DataAmount> PEBIOCTET = addUnit(BinaryPrefix.PEBI(OCTET));
|
public static final Unit<DataAmount> PEBIOCTET = addUnit(BinaryPrefix.PEBI(OCTET));
|
||||||
public static final Unit<DataTransferRate> BIT_PER_SECOND = addUnit(
|
public static final Unit<DataTransferRate> BIT_PER_SECOND = addUnit(
|
||||||
new ProductUnit<DataTransferRate>(BIT.divide(Units.SECOND)));
|
new ProductUnit<DataTransferRate>(BIT.divide(tec.uom.se.unit.Units.SECOND)));
|
||||||
public static final Unit<DataTransferRate> KILOBIT_PER_SECOND = addUnit(MetricPrefix.KILO(BIT_PER_SECOND));
|
public static final Unit<DataTransferRate> KILOBIT_PER_SECOND = addUnit(MetricPrefix.KILO(BIT_PER_SECOND));
|
||||||
public static final Unit<DataTransferRate> MEGABIT_PER_SECOND = addUnit(MetricPrefix.MEGA(BIT_PER_SECOND));
|
public static final Unit<DataTransferRate> MEGABIT_PER_SECOND = addUnit(MetricPrefix.MEGA(BIT_PER_SECOND));
|
||||||
public static final Unit<DataTransferRate> GIGABIT_PER_SECOND = addUnit(MetricPrefix.GIGA(BIT_PER_SECOND));
|
public static final Unit<DataTransferRate> GIGABIT_PER_SECOND = addUnit(MetricPrefix.GIGA(BIT_PER_SECOND));
|
||||||
|
@ -278,7 +284,7 @@ public final class SmartHomeUnits extends CustomUnits {
|
||||||
SimpleUnitFormat.getInstance().label(WATT_SECOND, "Ws");
|
SimpleUnitFormat.getInstance().label(WATT_SECOND, "Ws");
|
||||||
}
|
}
|
||||||
|
|
||||||
private SmartHomeUnits() {
|
private Units() {
|
||||||
// avoid external instantiation
|
// avoid external instantiation
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,14 +32,13 @@ import org.eclipse.jdt.annotation.Nullable;
|
||||||
import org.openhab.core.internal.library.unit.UnitInitializer;
|
import org.openhab.core.internal.library.unit.UnitInitializer;
|
||||||
import org.openhab.core.library.unit.ImperialUnits;
|
import org.openhab.core.library.unit.ImperialUnits;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import tec.uom.se.quantity.Quantities;
|
import tec.uom.se.quantity.Quantities;
|
||||||
import tec.uom.se.unit.MetricPrefix;
|
import tec.uom.se.unit.MetricPrefix;
|
||||||
import tec.uom.se.unit.TransformedUnit;
|
import tec.uom.se.unit.TransformedUnit;
|
||||||
import tec.uom.se.unit.Units;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A utility for parsing dimensions to interface classes of {@link Quantity} and parsing units from format strings.
|
* A utility for parsing dimensions to interface classes of {@link Quantity} and parsing units from format strings.
|
||||||
|
@ -58,7 +57,7 @@ public class UnitUtils {
|
||||||
private static final String FRAMEWORK_DIMENSION_PREFIX = "org.openhab.core.library.dimension.";
|
private static final String FRAMEWORK_DIMENSION_PREFIX = "org.openhab.core.library.dimension.";
|
||||||
|
|
||||||
private static final Collection<Class<? extends SystemOfUnits>> ALL_SYSTEM_OF_UNITS = Arrays.asList(SIUnits.class,
|
private static final Collection<Class<? extends SystemOfUnits>> ALL_SYSTEM_OF_UNITS = Arrays.asList(SIUnits.class,
|
||||||
ImperialUnits.class, SmartHomeUnits.class, Units.class);
|
ImperialUnits.class, Units.class, tec.uom.se.unit.Units.class);
|
||||||
|
|
||||||
static {
|
static {
|
||||||
UnitInitializer.init();
|
UnitInitializer.init();
|
||||||
|
@ -155,7 +154,7 @@ public class UnitUtils {
|
||||||
|
|
||||||
if (!UNIT_PLACEHOLDER.equals(unitSymbol)) {
|
if (!UNIT_PLACEHOLDER.equals(unitSymbol)) {
|
||||||
if (UNIT_PERCENT_FORMAT_STRING.equals(unitSymbol)) {
|
if (UNIT_PERCENT_FORMAT_STRING.equals(unitSymbol)) {
|
||||||
return SmartHomeUnits.PERCENT;
|
return Units.PERCENT;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
Quantity<?> quantity = Quantities.getQuantity("1 " + unitSymbol);
|
Quantity<?> quantity = Quantities.getQuantity("1 " + unitSymbol);
|
||||||
|
|
|
@ -23,14 +23,14 @@ import org.eclipse.jdt.annotation.NonNullByDefault;
|
||||||
import org.junit.jupiter.params.ParameterizedTest;
|
import org.junit.jupiter.params.ParameterizedTest;
|
||||||
import org.junit.jupiter.params.provider.Arguments;
|
import org.junit.jupiter.params.provider.Arguments;
|
||||||
import org.junit.jupiter.params.provider.MethodSource;
|
import org.junit.jupiter.params.provider.MethodSource;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.types.util.UnitUtils;
|
import org.openhab.core.types.util.UnitUtils;
|
||||||
|
|
||||||
import tec.uom.se.ComparableQuantity;
|
import tec.uom.se.ComparableQuantity;
|
||||||
import tec.uom.se.quantity.Quantities;
|
import tec.uom.se.quantity.Quantities;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test for volumentric flow rate constants defined in {@link SmartHomeUnits}.
|
* Test for volumentric flow rate constants defined in {@link Units}.
|
||||||
*
|
*
|
||||||
* @author Łukasz Dywicki - Initial contribution
|
* @author Łukasz Dywicki - Initial contribution
|
||||||
*/
|
*/
|
||||||
|
@ -40,7 +40,7 @@ public class VolumetricFlowRateTest {
|
||||||
/**
|
/**
|
||||||
* While its not SI base unit it produces nice and fairly rounded numbers (si base is m3/s).
|
* While its not SI base unit it produces nice and fairly rounded numbers (si base is m3/s).
|
||||||
*/
|
*/
|
||||||
private static final Unit<VolumetricFlowRate> BASE_UNIT = SmartHomeUnits.CUBICMETRE_PER_HOUR;
|
private static final Unit<VolumetricFlowRate> BASE_UNIT = Units.CUBICMETRE_PER_HOUR;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An additional test which converts given test quantity into base unit and then compares it with expected value.
|
* An additional test which converts given test quantity into base unit and then compares it with expected value.
|
||||||
|
@ -72,10 +72,10 @@ public class VolumetricFlowRateTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Stream<Arguments> arguments() {
|
private static Stream<Arguments> arguments() {
|
||||||
return Stream.of(Arguments.of(SmartHomeUnits.LITRE_PER_MINUTE, "l/min", 100.0, 6.0),
|
return Stream.of(Arguments.of(Units.LITRE_PER_MINUTE, "l/min", 100.0, 6.0),
|
||||||
Arguments.of(SmartHomeUnits.CUBICMETRE_PER_SECOND, "m³/s", 100.0, 360000.0),
|
Arguments.of(Units.CUBICMETRE_PER_SECOND, "m³/s", 100.0, 360000.0),
|
||||||
Arguments.of(SmartHomeUnits.CUBICMETRE_PER_MINUTE, "m³/min", 100.0, 6000.0),
|
Arguments.of(Units.CUBICMETRE_PER_MINUTE, "m³/min", 100.0, 6000.0),
|
||||||
Arguments.of(SmartHomeUnits.CUBICMETRE_PER_HOUR, "m³/h", 100.0, 100.0),
|
Arguments.of(Units.CUBICMETRE_PER_HOUR, "m³/h", 100.0, 100.0),
|
||||||
Arguments.of(SmartHomeUnits.CUBICMETRE_PER_DAY, "m³/d", 100.0, 4.166666666666667));
|
Arguments.of(Units.CUBICMETRE_PER_DAY, "m³/d", 100.0, 4.166666666666667));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,7 @@ package org.openhab.core.library.types;
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Kai Kreuzer - Initial contribution
|
* @author Kai Kreuzer - Initial contribution
|
||||||
|
@ -75,7 +75,7 @@ public class PercentTypeTest {
|
||||||
public void testConversionToQuantityType() {
|
public void testConversionToQuantityType() {
|
||||||
assertEquals(new QuantityType<>("100 %"), PercentType.HUNDRED.as(QuantityType.class));
|
assertEquals(new QuantityType<>("100 %"), PercentType.HUNDRED.as(QuantityType.class));
|
||||||
assertEquals(new QuantityType<>("1 one"),
|
assertEquals(new QuantityType<>("1 one"),
|
||||||
((QuantityType<?>) PercentType.HUNDRED.as(QuantityType.class)).toUnit(SmartHomeUnits.ONE));
|
((QuantityType<?>) PercentType.HUNDRED.as(QuantityType.class)).toUnit(Units.ONE));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -37,11 +37,10 @@ import org.openhab.core.library.dimension.Intensity;
|
||||||
import org.openhab.core.library.unit.BinaryPrefix;
|
import org.openhab.core.library.unit.BinaryPrefix;
|
||||||
import org.openhab.core.library.unit.MetricPrefix;
|
import org.openhab.core.library.unit.MetricPrefix;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.types.util.UnitUtils;
|
import org.openhab.core.types.util.UnitUtils;
|
||||||
|
|
||||||
import tec.uom.se.quantity.QuantityDimension;
|
import tec.uom.se.quantity.QuantityDimension;
|
||||||
import tec.uom.se.unit.Units;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Gaël L'hopital - Initial contribution
|
* @author Gaël L'hopital - Initial contribution
|
||||||
|
@ -125,9 +124,9 @@ public class QuantityTypeTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testFormats() {
|
public void testFormats() {
|
||||||
QuantityType<Time> seconds = new QuantityType<>(80, SmartHomeUnits.SECOND);
|
QuantityType<Time> seconds = new QuantityType<>(80, Units.SECOND);
|
||||||
QuantityType<Time> millis = seconds.toUnit(MetricPrefix.MILLI(SmartHomeUnits.SECOND));
|
QuantityType<Time> millis = seconds.toUnit(MetricPrefix.MILLI(Units.SECOND));
|
||||||
QuantityType<Time> minutes = seconds.toUnit(SmartHomeUnits.MINUTE);
|
QuantityType<Time> minutes = seconds.toUnit(Units.MINUTE);
|
||||||
|
|
||||||
assertThat(seconds.format("%.1f " + UnitUtils.UNIT_PLACEHOLDER), is("80" + SEP + "0 s"));
|
assertThat(seconds.format("%.1f " + UnitUtils.UNIT_PLACEHOLDER), is("80" + SEP + "0 s"));
|
||||||
assertThat(millis.format("%.1f " + UnitUtils.UNIT_PLACEHOLDER), is("80000" + SEP + "0 ms"));
|
assertThat(millis.format("%.1f " + UnitUtils.UNIT_PLACEHOLDER), is("80000" + SEP + "0 ms"));
|
||||||
|
@ -152,7 +151,7 @@ public class QuantityTypeTest {
|
||||||
assertTrue(dt2.equals(dt3));
|
assertTrue(dt2.equals(dt3));
|
||||||
|
|
||||||
QuantityType<?> tempInC = new QuantityType<>("22 °C");
|
QuantityType<?> tempInC = new QuantityType<>("22 °C");
|
||||||
QuantityType<?> tempInK = tempInC.toUnit(SmartHomeUnits.KELVIN);
|
QuantityType<?> tempInK = tempInC.toUnit(Units.KELVIN);
|
||||||
assertTrue(tempInC.equals(tempInK));
|
assertTrue(tempInC.equals(tempInK));
|
||||||
tempInK = tempInC.toUnit("K");
|
tempInK = tempInC.toUnit("K");
|
||||||
assertTrue(tempInC.equals(tempInK));
|
assertTrue(tempInC.equals(tempInK));
|
||||||
|
@ -284,12 +283,12 @@ public class QuantityTypeTest {
|
||||||
public void testIntensity() {
|
public void testIntensity() {
|
||||||
QuantityType<Intensity> density = new QuantityType<>("10 W/m²");
|
QuantityType<Intensity> density = new QuantityType<>("10 W/m²");
|
||||||
assertEquals(10, density.doubleValue(), 1E-5);
|
assertEquals(10, density.doubleValue(), 1E-5);
|
||||||
assertEquals(SmartHomeUnits.IRRADIANCE.toString(), density.getUnit().toString());
|
assertEquals(Units.IRRADIANCE.toString(), density.getUnit().toString());
|
||||||
|
|
||||||
density = density.toUnit("W/cm²");
|
density = density.toUnit("W/cm²");
|
||||||
assertEquals("0.001 W/cm²", density.toString());
|
assertEquals("0.001 W/cm²", density.toString());
|
||||||
|
|
||||||
density = new QuantityType<>(2, SmartHomeUnits.IRRADIANCE);
|
density = new QuantityType<>(2, Units.IRRADIANCE);
|
||||||
assertEquals(2, density.doubleValue(), 1E-5);
|
assertEquals(2, density.doubleValue(), 1E-5);
|
||||||
assertEquals("2 W/m²", density.toString());
|
assertEquals("2 W/m²", density.toString());
|
||||||
|
|
||||||
|
@ -327,36 +326,35 @@ public class QuantityTypeTest {
|
||||||
@Test
|
@Test
|
||||||
public void testDataAmount() {
|
public void testDataAmount() {
|
||||||
QuantityType<DataAmount> amount = new QuantityType<>("8 bit");
|
QuantityType<DataAmount> amount = new QuantityType<>("8 bit");
|
||||||
QuantityType<DataAmount> octet = amount.toUnit(SmartHomeUnits.BYTE);
|
QuantityType<DataAmount> octet = amount.toUnit(Units.BYTE);
|
||||||
assertEquals(1, octet.byteValue());
|
assertEquals(1, octet.byteValue());
|
||||||
QuantityType<DataAmount> bytes = new QuantityType<>("1 B");
|
QuantityType<DataAmount> bytes = new QuantityType<>("1 B");
|
||||||
assertEquals("1 B", bytes.toString());
|
assertEquals("1 B", bytes.toString());
|
||||||
QuantityType<DataAmount> bits = bytes.toUnit(SmartHomeUnits.BIT);
|
QuantityType<DataAmount> bits = bytes.toUnit(Units.BIT);
|
||||||
assertEquals(8, bits.byteValue());
|
assertEquals(8, bits.byteValue());
|
||||||
bytes = new QuantityType<>("1 MB");
|
bytes = new QuantityType<>("1 MB");
|
||||||
assertEquals("1 MB", bytes.toString());
|
assertEquals("1 MB", bytes.toString());
|
||||||
bytes = new QuantityType<DataAmount>(1, MetricPrefix.MEGA(SmartHomeUnits.BYTE));
|
bytes = new QuantityType<DataAmount>(1, MetricPrefix.MEGA(Units.BYTE));
|
||||||
assertEquals("1 MB", bytes.toString());
|
assertEquals("1 MB", bytes.toString());
|
||||||
bytes = new QuantityType<>("1 GiB");
|
bytes = new QuantityType<>("1 GiB");
|
||||||
assertEquals("1 GiB", bytes.toString());
|
assertEquals("1 GiB", bytes.toString());
|
||||||
bytes = new QuantityType<DataAmount>(1, BinaryPrefix.GIBI(SmartHomeUnits.BYTE));
|
bytes = new QuantityType<DataAmount>(1, BinaryPrefix.GIBI(Units.BYTE));
|
||||||
assertEquals("1 GiB", bytes.toString());
|
assertEquals("1 GiB", bytes.toString());
|
||||||
QuantityType<DataAmount> bigAmount = new QuantityType<>("1 Kio");
|
QuantityType<DataAmount> bigAmount = new QuantityType<>("1 Kio");
|
||||||
QuantityType<DataAmount> octets = bigAmount.toUnit(SmartHomeUnits.OCTET);
|
QuantityType<DataAmount> octets = bigAmount.toUnit(Units.OCTET);
|
||||||
assertEquals(1024, octets.intValue());
|
assertEquals(1024, octets.intValue());
|
||||||
QuantityType<DataAmount> hugeAmount = new QuantityType<>("1024Gio");
|
QuantityType<DataAmount> hugeAmount = new QuantityType<>("1024Gio");
|
||||||
QuantityType<DataAmount> lotOfOctets = hugeAmount.toUnit(SmartHomeUnits.OCTET);
|
QuantityType<DataAmount> lotOfOctets = hugeAmount.toUnit(Units.OCTET);
|
||||||
assertEquals("1099511627776 o", lotOfOctets.format("%d o"));
|
assertEquals("1099511627776 o", lotOfOctets.format("%d o"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testDataTransferRate() {
|
public void testDataTransferRate() {
|
||||||
QuantityType<DataTransferRate> speed = new QuantityType<>("1024 bit/s");
|
QuantityType<DataTransferRate> speed = new QuantityType<>("1024 bit/s");
|
||||||
QuantityType<DataTransferRate> octet = speed.toUnit(SmartHomeUnits.OCTET.divide(Units.SECOND));
|
QuantityType<DataTransferRate> octet = speed.toUnit(Units.OCTET.divide(Units.SECOND));
|
||||||
assertEquals(128, octet.intValue());
|
assertEquals(128, octet.intValue());
|
||||||
QuantityType<DataTransferRate> gsm2G = new QuantityType<>("115 Mbit/s");
|
QuantityType<DataTransferRate> gsm2G = new QuantityType<>("115 Mbit/s");
|
||||||
QuantityType<DataTransferRate> octets = gsm2G
|
QuantityType<DataTransferRate> octets = gsm2G.toUnit(MetricPrefix.KILO(Units.OCTET).divide(Units.SECOND));
|
||||||
.toUnit(MetricPrefix.KILO(SmartHomeUnits.OCTET).divide(Units.SECOND));
|
|
||||||
assertEquals(14375, octets.intValue());
|
assertEquals(14375, octets.intValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,14 +35,13 @@ import org.openhab.core.library.dimension.Intensity;
|
||||||
import org.openhab.core.library.types.QuantityType;
|
import org.openhab.core.library.types.QuantityType;
|
||||||
|
|
||||||
import tec.uom.se.quantity.Quantities;
|
import tec.uom.se.quantity.Quantities;
|
||||||
import tec.uom.se.unit.Units;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test for the framework defined {@link SmartHomeUnits}.
|
* Test for the framework defined {@link Units}.
|
||||||
*
|
*
|
||||||
* @author Henning Treu - Initial contribution
|
* @author Henning Treu - Initial contribution
|
||||||
*/
|
*/
|
||||||
public class SmartHomeUnitsTest {
|
public class UnitsTest {
|
||||||
|
|
||||||
private static final double DEFAULT_ERROR = 0.0000000000000001d;
|
private static final double DEFAULT_ERROR = 0.0000000000000001d;
|
||||||
|
|
||||||
|
@ -71,7 +70,7 @@ public class SmartHomeUnitsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testmmHg2PascalConversion() {
|
public void testmmHg2PascalConversion() {
|
||||||
Quantity<Pressure> mmHg = Quantities.getQuantity(BigDecimal.ONE, SmartHomeUnits.MILLIMETRE_OF_MERCURY);
|
Quantity<Pressure> mmHg = Quantities.getQuantity(BigDecimal.ONE, Units.MILLIMETRE_OF_MERCURY);
|
||||||
|
|
||||||
assertThat(mmHg.to(SIUnits.PASCAL), is(Quantities.getQuantity(new BigDecimal("133.322368"), SIUnits.PASCAL)));
|
assertThat(mmHg.to(SIUnits.PASCAL), is(Quantities.getQuantity(new BigDecimal("133.322368"), SIUnits.PASCAL)));
|
||||||
assertThat(mmHg.to(MetricPrefix.HECTO(SIUnits.PASCAL)),
|
assertThat(mmHg.to(MetricPrefix.HECTO(SIUnits.PASCAL)),
|
||||||
|
@ -80,16 +79,16 @@ public class SmartHomeUnitsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testMmHgUnitSymbol() {
|
public void testMmHgUnitSymbol() {
|
||||||
assertThat(SmartHomeUnits.MILLIMETRE_OF_MERCURY.getSymbol(), is("mmHg"));
|
assertThat(Units.MILLIMETRE_OF_MERCURY.getSymbol(), is("mmHg"));
|
||||||
assertThat(SmartHomeUnits.MILLIMETRE_OF_MERCURY.toString(), is("mmHg"));
|
assertThat(Units.MILLIMETRE_OF_MERCURY.toString(), is("mmHg"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testPascal2mmHgConversion() {
|
public void testPascal2mmHgConversion() {
|
||||||
Quantity<Pressure> pascal = Quantities.getQuantity(new BigDecimal("133.322368"), SIUnits.PASCAL);
|
Quantity<Pressure> pascal = Quantities.getQuantity(new BigDecimal("133.322368"), SIUnits.PASCAL);
|
||||||
|
|
||||||
assertThat(pascal.to(SmartHomeUnits.MILLIMETRE_OF_MERCURY),
|
assertThat(pascal.to(Units.MILLIMETRE_OF_MERCURY),
|
||||||
is(Quantities.getQuantity(BigDecimal.ONE, SmartHomeUnits.MILLIMETRE_OF_MERCURY)));
|
is(Quantities.getQuantity(BigDecimal.ONE, Units.MILLIMETRE_OF_MERCURY)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -107,7 +106,7 @@ public class SmartHomeUnitsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testKelvin2Fahrenheit() {
|
public void testKelvin2Fahrenheit() {
|
||||||
Quantity<Temperature> kelvin = Quantities.getQuantity(BigDecimal.ZERO, SmartHomeUnits.KELVIN);
|
Quantity<Temperature> kelvin = Quantities.getQuantity(BigDecimal.ZERO, Units.KELVIN);
|
||||||
|
|
||||||
assertThat(kelvin.to(ImperialUnits.FAHRENHEIT),
|
assertThat(kelvin.to(ImperialUnits.FAHRENHEIT),
|
||||||
is(Quantities.getQuantity(new BigDecimal("-459.67"), ImperialUnits.FAHRENHEIT)));
|
is(Quantities.getQuantity(new BigDecimal("-459.67"), ImperialUnits.FAHRENHEIT)));
|
||||||
|
@ -115,7 +114,7 @@ public class SmartHomeUnitsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testKelvin2Fahrenheit2() {
|
public void testKelvin2Fahrenheit2() {
|
||||||
Quantity<Temperature> kelvin = Quantities.getQuantity(new BigDecimal("300"), SmartHomeUnits.KELVIN);
|
Quantity<Temperature> kelvin = Quantities.getQuantity(new BigDecimal("300"), Units.KELVIN);
|
||||||
|
|
||||||
assertThat(kelvin.to(ImperialUnits.FAHRENHEIT),
|
assertThat(kelvin.to(ImperialUnits.FAHRENHEIT),
|
||||||
is(Quantities.getQuantity(new BigDecimal("80.33"), ImperialUnits.FAHRENHEIT)));
|
is(Quantities.getQuantity(new BigDecimal("80.33"), ImperialUnits.FAHRENHEIT)));
|
||||||
|
@ -125,8 +124,8 @@ public class SmartHomeUnitsTest {
|
||||||
public void testFahrenheit2Kelvin() {
|
public void testFahrenheit2Kelvin() {
|
||||||
Quantity<Temperature> fahrenheit = Quantities.getQuantity(new BigDecimal("100"), ImperialUnits.FAHRENHEIT);
|
Quantity<Temperature> fahrenheit = Quantities.getQuantity(new BigDecimal("100"), ImperialUnits.FAHRENHEIT);
|
||||||
|
|
||||||
Quantity<Temperature> kelvin = fahrenheit.to(SmartHomeUnits.KELVIN);
|
Quantity<Temperature> kelvin = fahrenheit.to(Units.KELVIN);
|
||||||
assertThat(kelvin.getUnit(), is(SmartHomeUnits.KELVIN));
|
assertThat(kelvin.getUnit(), is(Units.KELVIN));
|
||||||
assertThat(kelvin.getValue().doubleValue(), is(closeTo(310.92777777777777778d, DEFAULT_ERROR)));
|
assertThat(kelvin.getValue().doubleValue(), is(closeTo(310.92777777777777778d, DEFAULT_ERROR)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -152,14 +151,14 @@ public class SmartHomeUnitsTest {
|
||||||
public void testKmh2Knot() {
|
public void testKmh2Knot() {
|
||||||
Quantity<Speed> kmh = Quantities.getQuantity(new BigDecimal("1.852"), SIUnits.KILOMETRE_PER_HOUR);
|
Quantity<Speed> kmh = Quantities.getQuantity(new BigDecimal("1.852"), SIUnits.KILOMETRE_PER_HOUR);
|
||||||
|
|
||||||
Quantity<Speed> knot = kmh.to(SmartHomeUnits.KNOT);
|
Quantity<Speed> knot = kmh.to(Units.KNOT);
|
||||||
assertThat(knot.getUnit(), is(SmartHomeUnits.KNOT));
|
assertThat(knot.getUnit(), is(Units.KNOT));
|
||||||
assertThat(knot.getValue().doubleValue(), is(closeTo(1.000, DEFAULT_ERROR)));
|
assertThat(knot.getValue().doubleValue(), is(closeTo(1.000, DEFAULT_ERROR)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testKnot2Kmh() {
|
public void testKnot2Kmh() {
|
||||||
Quantity<Speed> knot = Quantities.getQuantity(BigDecimal.TEN, SmartHomeUnits.KNOT);
|
Quantity<Speed> knot = Quantities.getQuantity(BigDecimal.TEN, Units.KNOT);
|
||||||
|
|
||||||
Quantity<Speed> kmh = knot.to(SIUnits.KILOMETRE_PER_HOUR);
|
Quantity<Speed> kmh = knot.to(SIUnits.KILOMETRE_PER_HOUR);
|
||||||
assertThat(kmh.getUnit(), is(SIUnits.KILOMETRE_PER_HOUR));
|
assertThat(kmh.getUnit(), is(SIUnits.KILOMETRE_PER_HOUR));
|
||||||
|
@ -168,26 +167,26 @@ public class SmartHomeUnitsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testKnotUnitSymbol() {
|
public void testKnotUnitSymbol() {
|
||||||
assertThat(SmartHomeUnits.KNOT.getSymbol(), is("kn"));
|
assertThat(Units.KNOT.getSymbol(), is("kn"));
|
||||||
assertThat(SmartHomeUnits.KNOT.toString(), is("kn"));
|
assertThat(Units.KNOT.toString(), is("kn"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testVarUnitSymbol() {
|
public void testVarUnitSymbol() {
|
||||||
assertThat(SmartHomeUnits.VAR.getSymbol(), is("var"));
|
assertThat(Units.VAR.getSymbol(), is("var"));
|
||||||
assertThat(SmartHomeUnits.VAR.toString(), is("var"));
|
assertThat(Units.VAR.toString(), is("var"));
|
||||||
assertThat(SmartHomeUnits.VAR_HOUR.toString(), is("varh"));
|
assertThat(Units.VAR_HOUR.toString(), is("varh"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testKVarUnitSymbol() {
|
public void testKVarUnitSymbol() {
|
||||||
assertThat(SmartHomeUnits.KILOVAR.toString(), is("kvar"));
|
assertThat(Units.KILOVAR.toString(), is("kvar"));
|
||||||
assertThat(SmartHomeUnits.KILOVAR_HOUR.toString(), is("kvarh"));
|
assertThat(Units.KILOVAR_HOUR.toString(), is("kvarh"));
|
||||||
|
|
||||||
Quantity<Power> kvar = Quantities.getQuantity(BigDecimal.TEN, MetricPrefix.KILO(SmartHomeUnits.VAR));
|
Quantity<Power> kvar = Quantities.getQuantity(BigDecimal.TEN, MetricPrefix.KILO(Units.VAR));
|
||||||
assertThat(kvar.getUnit().toString(), is("kvar"));
|
assertThat(kvar.getUnit().toString(), is("kvar"));
|
||||||
|
|
||||||
Quantity<Energy> kvarh = Quantities.getQuantity(BigDecimal.TEN, MetricPrefix.KILO(SmartHomeUnits.VAR_HOUR));
|
Quantity<Energy> kvarh = Quantities.getQuantity(BigDecimal.TEN, MetricPrefix.KILO(Units.VAR_HOUR));
|
||||||
assertThat(kvarh.getUnit().toString(), is("kvarh"));
|
assertThat(kvarh.getUnit().toString(), is("kvarh"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -198,15 +197,14 @@ public class SmartHomeUnitsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testVoltAmpereUnitSymbol() {
|
public void testVoltAmpereUnitSymbol() {
|
||||||
assertThat(SmartHomeUnits.VOLT_AMPERE.toString(), is("VA"));
|
assertThat(Units.VOLT_AMPERE.toString(), is("VA"));
|
||||||
assertThat(SmartHomeUnits.VOLT_AMPERE.getSymbol(), is("VA"));
|
assertThat(Units.VOLT_AMPERE.getSymbol(), is("VA"));
|
||||||
assertThat(SmartHomeUnits.VOLT_AMPERE_HOUR.toString(), is("VAh"));
|
assertThat(Units.VOLT_AMPERE_HOUR.toString(), is("VAh"));
|
||||||
|
|
||||||
Quantity<Power> kVA = Quantities.getQuantity(BigDecimal.TEN, MetricPrefix.KILO(SmartHomeUnits.VOLT_AMPERE));
|
Quantity<Power> kVA = Quantities.getQuantity(BigDecimal.TEN, MetricPrefix.KILO(Units.VOLT_AMPERE));
|
||||||
assertThat(kVA.getUnit().toString(), is("kVA"));
|
assertThat(kVA.getUnit().toString(), is("kVA"));
|
||||||
|
|
||||||
Quantity<Energy> kVAh = Quantities.getQuantity(BigDecimal.TEN,
|
Quantity<Energy> kVAh = Quantities.getQuantity(BigDecimal.TEN, MetricPrefix.KILO(Units.VOLT_AMPERE_HOUR));
|
||||||
MetricPrefix.KILO(SmartHomeUnits.VOLT_AMPERE_HOUR));
|
|
||||||
assertThat(kVAh.getUnit().toString(), is("kVAh"));
|
assertThat(kVAh.getUnit().toString(), is("kVAh"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -271,10 +269,10 @@ public class SmartHomeUnitsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testOneUnitSymbol() {
|
public void testOneUnitSymbol() {
|
||||||
assertThat(SmartHomeUnits.ONE.getSymbol(), is(""));
|
assertThat(Units.ONE.getSymbol(), is(""));
|
||||||
|
|
||||||
Quantity<Dimensionless> one1 = Quantities.getQuantity(BigDecimal.ONE, SmartHomeUnits.ONE);
|
Quantity<Dimensionless> one1 = Quantities.getQuantity(BigDecimal.ONE, Units.ONE);
|
||||||
Quantity<Dimensionless> one2 = Quantities.getQuantity(BigDecimal.ONE, SmartHomeUnits.ONE);
|
Quantity<Dimensionless> one2 = Quantities.getQuantity(BigDecimal.ONE, Units.ONE);
|
||||||
|
|
||||||
assertThat(one1.add(one2).toString(), is("2 one"));
|
assertThat(one1.add(one2).toString(), is("2 one"));
|
||||||
}
|
}
|
||||||
|
@ -295,27 +293,28 @@ public class SmartHomeUnitsTest {
|
||||||
public void testDobsonUnits() {
|
public void testDobsonUnits() {
|
||||||
// https://en.wikipedia.org/wiki/Dobson_unit
|
// https://en.wikipedia.org/wiki/Dobson_unit
|
||||||
QuantityType<ArealDensity> oneDU = new QuantityType<>("1 DU");
|
QuantityType<ArealDensity> oneDU = new QuantityType<>("1 DU");
|
||||||
QuantityType<ArealDensity> mmolpsq = oneDU.toUnit(MetricPrefix.MILLI(Units.MOLE).multiply(Units.METRE.pow(-2)));
|
QuantityType<ArealDensity> mmolpsq = oneDU
|
||||||
|
.toUnit(MetricPrefix.MILLI(Units.MOLE).multiply(tec.uom.se.unit.Units.METRE.pow(-2)));
|
||||||
assertThat(mmolpsq.doubleValue(), is(closeTo(0.4462d, DEFAULT_ERROR)));
|
assertThat(mmolpsq.doubleValue(), is(closeTo(0.4462d, DEFAULT_ERROR)));
|
||||||
assertThat(mmolpsq.toUnit(SmartHomeUnits.DOBSON_UNIT).doubleValue(), is(closeTo(1, DEFAULT_ERROR)));
|
assertThat(mmolpsq.toUnit(Units.DOBSON_UNIT).doubleValue(), is(closeTo(1, DEFAULT_ERROR)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBar2Pascal() {
|
public void testBar2Pascal() {
|
||||||
Quantity<Pressure> bar = Quantities.getQuantity(BigDecimal.valueOf(1), SmartHomeUnits.BAR);
|
Quantity<Pressure> bar = Quantities.getQuantity(BigDecimal.valueOf(1), Units.BAR);
|
||||||
assertThat(bar.to(SIUnits.PASCAL), is(Quantities.getQuantity(100000, SIUnits.PASCAL)));
|
assertThat(bar.to(SIUnits.PASCAL), is(Quantities.getQuantity(100000, SIUnits.PASCAL)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testMicrogramPerCubicMeter2KilogramPerCubicMeter() {
|
public void testMicrogramPerCubicMeter2KilogramPerCubicMeter() {
|
||||||
Quantity<Density> oneKgM3 = Quantities.getQuantity(BigDecimal.ONE, SmartHomeUnits.KILOGRAM_PER_CUBICMETRE);
|
Quantity<Density> oneKgM3 = Quantities.getQuantity(BigDecimal.ONE, Units.KILOGRAM_PER_CUBICMETRE);
|
||||||
Quantity<Density> converted = oneKgM3.to(SmartHomeUnits.MICROGRAM_PER_CUBICMETRE);
|
Quantity<Density> converted = oneKgM3.to(Units.MICROGRAM_PER_CUBICMETRE);
|
||||||
assertThat(converted.getValue().doubleValue(), is(closeTo(1000000000, DEFAULT_ERROR)));
|
assertThat(converted.getValue().doubleValue(), is(closeTo(1000000000, DEFAULT_ERROR)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testMicrogramPerCubicMeterUnitSymbol() {
|
public void testMicrogramPerCubicMeterUnitSymbol() {
|
||||||
assertThat(SmartHomeUnits.MICROGRAM_PER_CUBICMETRE.toString(), is("µg/m³"));
|
assertThat(Units.MICROGRAM_PER_CUBICMETRE.toString(), is("µg/m³"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -325,14 +324,14 @@ public class SmartHomeUnitsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testMicrowattPerSquareCentimetre2KilogramPerSquareCentiMetre() {
|
public void testMicrowattPerSquareCentimetre2KilogramPerSquareCentiMetre() {
|
||||||
Quantity<Intensity> oneMwCm2 = Quantities.getQuantity(BigDecimal.ONE, SmartHomeUnits.IRRADIANCE);
|
Quantity<Intensity> oneMwCm2 = Quantities.getQuantity(BigDecimal.ONE, Units.IRRADIANCE);
|
||||||
Quantity<Intensity> converted = oneMwCm2.to(SmartHomeUnits.MICROWATT_PER_SQUARE_CENTIMETRE);
|
Quantity<Intensity> converted = oneMwCm2.to(Units.MICROWATT_PER_SQUARE_CENTIMETRE);
|
||||||
assertThat(converted.getValue().doubleValue(), is(100d));
|
assertThat(converted.getValue().doubleValue(), is(100d));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testMicrowattPerSquareCentimetreUnitSymbol() {
|
public void testMicrowattPerSquareCentimetreUnitSymbol() {
|
||||||
assertThat(SmartHomeUnits.MICROWATT_PER_SQUARE_CENTIMETRE.toString(), is("µW/cm²"));
|
assertThat(Units.MICROWATT_PER_SQUARE_CENTIMETRE.toString(), is("µW/cm²"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -343,8 +342,8 @@ public class SmartHomeUnitsTest {
|
||||||
@Test
|
@Test
|
||||||
public void testElectricCharge() {
|
public void testElectricCharge() {
|
||||||
QuantityType<?> oneAh = QuantityType.valueOf("3600 C");
|
QuantityType<?> oneAh = QuantityType.valueOf("3600 C");
|
||||||
QuantityType<?> converted = oneAh.toUnit(SmartHomeUnits.AMPERE_HOUR);
|
QuantityType<?> converted = oneAh.toUnit(Units.AMPERE_HOUR);
|
||||||
QuantityType<?> converted2 = oneAh.toUnit(SmartHomeUnits.MILLIAMPERE_HOUR);
|
QuantityType<?> converted2 = oneAh.toUnit(Units.MILLIAMPERE_HOUR);
|
||||||
assertThat(converted.doubleValue(), is(closeTo(1.00, DEFAULT_ERROR)));
|
assertThat(converted.doubleValue(), is(closeTo(1.00, DEFAULT_ERROR)));
|
||||||
assertEquals("1000 mAh", converted2.toString());
|
assertEquals("1000 mAh", converted2.toString());
|
||||||
}
|
}
|
|
@ -32,7 +32,7 @@ import org.openhab.core.library.dimension.Intensity;
|
||||||
import org.openhab.core.library.unit.ImperialUnits;
|
import org.openhab.core.library.unit.ImperialUnits;
|
||||||
import org.openhab.core.library.unit.MetricPrefix;
|
import org.openhab.core.library.unit.MetricPrefix;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Henning Treu - Initial contribution
|
* @author Henning Treu - Initial contribution
|
||||||
|
@ -72,12 +72,9 @@ public class UnitUtilsTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testConversionOfUnit() {
|
public void testConversionOfUnit() {
|
||||||
assertThat(SmartHomeUnits.DECIBEL_MILLIWATTS.getConverterTo(SmartHomeUnits.WATT).convert(50),
|
assertThat(Units.DECIBEL_MILLIWATTS.getConverterTo(Units.WATT).convert(50), closeTo(100, 0.001));
|
||||||
closeTo(100, 0.001));
|
assertThat(Units.WATT.getConverterTo(Units.DECIBEL_MILLIWATTS).convert(0.1), closeTo(20, 0.0001));
|
||||||
assertThat(SmartHomeUnits.WATT.getConverterTo(SmartHomeUnits.DECIBEL_MILLIWATTS).convert(0.1),
|
assertThat(Units.METRE_PER_SQUARE_SECOND.getConverterTo(Units.STANDARD_GRAVITY).convert(9.8065),
|
||||||
closeTo(20, 0.0001));
|
|
||||||
assertThat(
|
|
||||||
SmartHomeUnits.METRE_PER_SQUARE_SECOND.getConverterTo(SmartHomeUnits.STANDARD_GRAVITY).convert(9.8065),
|
|
||||||
closeTo(1.0, 0.0001));
|
closeTo(1.0, 0.0001));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -86,25 +83,25 @@ public class UnitUtilsTest {
|
||||||
assertThat(UnitUtils.parseUnit("%.2f °F"), is(ImperialUnits.FAHRENHEIT));
|
assertThat(UnitUtils.parseUnit("%.2f °F"), is(ImperialUnits.FAHRENHEIT));
|
||||||
assertThat(UnitUtils.parseUnit("%.2f °C"), is(SIUnits.CELSIUS));
|
assertThat(UnitUtils.parseUnit("%.2f °C"), is(SIUnits.CELSIUS));
|
||||||
assertThat(UnitUtils.parseUnit("myLabel km"), is(KILO(SIUnits.METRE)));
|
assertThat(UnitUtils.parseUnit("myLabel km"), is(KILO(SIUnits.METRE)));
|
||||||
assertThat(UnitUtils.parseUnit("%.2f %%"), is(SmartHomeUnits.PERCENT));
|
assertThat(UnitUtils.parseUnit("%.2f %%"), is(Units.PERCENT));
|
||||||
assertThat(UnitUtils.parseUnit("myLabel %unit%"), is(nullValue()));
|
assertThat(UnitUtils.parseUnit("myLabel %unit%"), is(nullValue()));
|
||||||
assertThat(UnitUtils.parseUnit("%.2f kvarh"), is(SmartHomeUnits.KILOVAR_HOUR));
|
assertThat(UnitUtils.parseUnit("%.2f kvarh"), is(Units.KILOVAR_HOUR));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testParsePureUnit() {
|
public void testParsePureUnit() {
|
||||||
assertThat(UnitUtils.parseUnit("DU"), is(SmartHomeUnits.DOBSON_UNIT));
|
assertThat(UnitUtils.parseUnit("DU"), is(Units.DOBSON_UNIT));
|
||||||
assertThat(UnitUtils.parseUnit("°F"), is(ImperialUnits.FAHRENHEIT));
|
assertThat(UnitUtils.parseUnit("°F"), is(ImperialUnits.FAHRENHEIT));
|
||||||
assertThat(UnitUtils.parseUnit("m"), is(SIUnits.METRE));
|
assertThat(UnitUtils.parseUnit("m"), is(SIUnits.METRE));
|
||||||
assertThat(UnitUtils.parseUnit("%"), is(SmartHomeUnits.PERCENT));
|
assertThat(UnitUtils.parseUnit("%"), is(Units.PERCENT));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetDimensionName() {
|
public void testGetDimensionName() {
|
||||||
assertThat(UnitUtils.getDimensionName(SIUnits.CELSIUS), is(Temperature.class.getSimpleName()));
|
assertThat(UnitUtils.getDimensionName(SIUnits.CELSIUS), is(Temperature.class.getSimpleName()));
|
||||||
assertThat(UnitUtils.getDimensionName(SmartHomeUnits.KILOWATT_HOUR), is(Energy.class.getSimpleName()));
|
assertThat(UnitUtils.getDimensionName(Units.KILOWATT_HOUR), is(Energy.class.getSimpleName()));
|
||||||
assertThat(UnitUtils.getDimensionName(SmartHomeUnits.WATT), is(Power.class.getSimpleName()));
|
assertThat(UnitUtils.getDimensionName(Units.WATT), is(Power.class.getSimpleName()));
|
||||||
assertThat(UnitUtils.getDimensionName(MetricPrefix.MEGA(SmartHomeUnits.KILOWATT_HOUR)),
|
assertThat(UnitUtils.getDimensionName(MetricPrefix.MEGA(Units.KILOWATT_HOUR)),
|
||||||
is(Energy.class.getSimpleName()));
|
is(Energy.class.getSimpleName()));
|
||||||
|
|
||||||
Unit<?> unit = UnitUtils.parseUnit("°F");
|
Unit<?> unit = UnitUtils.parseUnit("°F");
|
||||||
|
|
|
@ -38,7 +38,7 @@ import org.openhab.core.library.types.OnOffType;
|
||||||
import org.openhab.core.library.types.QuantityType;
|
import org.openhab.core.library.types.QuantityType;
|
||||||
import org.openhab.core.library.unit.MetricPrefix;
|
import org.openhab.core.library.unit.MetricPrefix;
|
||||||
import org.openhab.core.library.unit.SIUnits;
|
import org.openhab.core.library.unit.SIUnits;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.model.script.ScriptServiceUtil;
|
import org.openhab.core.model.script.ScriptServiceUtil;
|
||||||
import org.openhab.core.test.java.JavaOSGiTest;
|
import org.openhab.core.test.java.JavaOSGiTest;
|
||||||
import org.openhab.core.types.State;
|
import org.openhab.core.types.State;
|
||||||
|
@ -299,9 +299,9 @@ public class ScriptEngineOSGiTest extends JavaOSGiTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testToUnitQuantityType3() throws ScriptParsingException, ScriptExecutionException {
|
public void testToUnitQuantityType3() throws ScriptParsingException, ScriptExecutionException {
|
||||||
assertThat(runScript("new QuantityType(1, KELVIN)"), is(new QuantityType<>(1, SmartHomeUnits.KELVIN)));
|
assertThat(runScript("new QuantityType(1, KELVIN)"), is(new QuantityType<>(1, Units.KELVIN)));
|
||||||
assertThat(runScript("new QuantityType(1, MICRO(KELVIN))"),
|
assertThat(runScript("new QuantityType(1, MICRO(KELVIN))"),
|
||||||
is(new QuantityType<>(1, MetricPrefix.MICRO(SmartHomeUnits.KELVIN))));
|
is(new QuantityType<>(1, MetricPrefix.MICRO(Units.KELVIN))));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -25,7 +25,7 @@ import javax.measure.quantity.Temperature;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.openhab.core.library.types.DecimalType;
|
import org.openhab.core.library.types.DecimalType;
|
||||||
import org.openhab.core.library.types.QuantityType;
|
import org.openhab.core.library.types.QuantityType;
|
||||||
import org.openhab.core.library.unit.SmartHomeUnits;
|
import org.openhab.core.library.unit.Units;
|
||||||
import org.openhab.core.types.Type;
|
import org.openhab.core.types.Type;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -43,8 +43,8 @@ public class NumberExtensionsTest {
|
||||||
private static final QuantityType<Length> Q_LENGTH_1_M = new QuantityType<>("1 m");
|
private static final QuantityType<Length> Q_LENGTH_1_M = new QuantityType<>("1 m");
|
||||||
private static final QuantityType<Length> Q_LENGTH_2_CM = new QuantityType<>("2 cm");
|
private static final QuantityType<Length> Q_LENGTH_2_CM = new QuantityType<>("2 cm");
|
||||||
|
|
||||||
private static final QuantityType<Dimensionless> Q_ONE_1 = new QuantityType<>(1, SmartHomeUnits.ONE);
|
private static final QuantityType<Dimensionless> Q_ONE_1 = new QuantityType<>(1, Units.ONE);
|
||||||
private static final QuantityType<Dimensionless> Q_ONE_2 = new QuantityType<>(2, SmartHomeUnits.ONE);
|
private static final QuantityType<Dimensionless> Q_ONE_2 = new QuantityType<>(2, Units.ONE);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void operatorPlusNumberNumber() {
|
public void operatorPlusNumberNumber() {
|
||||||
|
|
Loading…
Reference in New Issue