/** * Copyright (c) 2014, University of Warsaw * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, are permitted * provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list of * conditions and the following disclaimer in the documentation and/or other materials provided * with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY * WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ package pl.edu.mimuw.cloudatlas.model; import pl.edu.mimuw.cloudatlas.model.Value; import pl.edu.mimuw.cloudatlas.model.ValueDouble; /** * A class that wraps a Java Double object. */ public class ValueDouble extends ValueSimple { /** * Constructs a new ValueDouble object wrapping the specified value. * * @param value the value to wrap */ public ValueDouble(Double value) { super(value); } /* Kryo needs a no-args constructor */ private ValueDouble() { } @Override public Type getType() { return TypePrimitive.DOUBLE; } @Override public Value getDefaultValue() { return new ValueDouble(0.0); } @Override public ValueBoolean isLowerThan(Value value) { sameTypesOrThrow(value, Operation.COMPARE); if(isNull() || value.isNull()) return new ValueBoolean(null); return new ValueBoolean(getValue() < ((ValueDouble)value).getValue()); } @Override public ValueDouble addValue(Value value) { sameTypesOrThrow(value, Operation.ADD); if(isNull() || value.isNull()) return new ValueDouble(null); return new ValueDouble(getValue() + ((ValueDouble)value).getValue()); } @Override public ValueDouble subtract(Value value) { sameTypesOrThrow(value, Operation.SUBTRACT); if(isNull() || value.isNull()) return new ValueDouble(null); return new ValueDouble(getValue() - ((ValueDouble)value).getValue()); } @Override public ValueDouble multiply(Value value) { sameTypesOrThrow(value, Operation.MULTIPLY); if(isNull() || value.isNull()) return new ValueDouble(null); return new ValueDouble(getValue() * ((ValueDouble)value).getValue()); } @Override public ValueDouble divide(Value value) { sameTypesOrThrow(value, Operation.DIVIDE); if(isNull() || value.isNull()) return new ValueDouble(null); return new ValueDouble(getValue() / ((ValueDouble)value).getValue()); } @Override public ValueDouble negate() { return new ValueDouble(isNull()? null : -getValue()); } @Override public Value convertTo(Type type) { switch(type.getPrimaryType()) { case DOUBLE: return this; case INT: return new ValueInt(getValue() == null? null : getValue().longValue()); case STRING: return getValue() == null? ValueString.NULL_STRING : new ValueString(getValue().toString()); default: throw new UnsupportedConversionException(getType(), type); } } }