X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.databoard%2Fsrc%2Forg%2Fsimantics%2Fdataboard%2Ftype%2FDoubleType.java;fp=bundles%2Forg.simantics.databoard%2Fsrc%2Forg%2Fsimantics%2Fdataboard%2Ftype%2FDoubleType.java;h=5c60d03a58b0aabad37d361477b4ed25e57418fc;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.databoard/src/org/simantics/databoard/type/DoubleType.java b/bundles/org.simantics.databoard/src/org/simantics/databoard/type/DoubleType.java new file mode 100644 index 000000000..5c60d03a5 --- /dev/null +++ b/bundles/org.simantics.databoard/src/org/simantics/databoard/type/DoubleType.java @@ -0,0 +1,81 @@ +/******************************************************************************* + * Copyright (c) 2010 Association for Decentralized Information Management in + * Industry THTH ry. + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v1.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * VTT Technical Research Centre of Finland - initial API and implementation + *******************************************************************************/ +package org.simantics.databoard.type; + +import java.util.Set; + +import org.simantics.databoard.util.IdentityPair; +import org.simantics.databoard.util.Limit; +import org.simantics.databoard.util.Range; + +public class DoubleType extends NumberType { + + public DoubleType() {} + public DoubleType(String unit) { + setUnit( unit ); + } + public DoubleType(String unit, Range range) { + setUnit( unit ); + setRange(range); + } + public DoubleType(String unit, String range) { + setUnit( unit ); + setRange(range); + } + + public double minValue() { + Range range = getRange(); + if (range==null) return -Double.MAX_VALUE; + Limit l = range.getLower(); + double value = l.getValue().doubleValue(); + + // Won't work + if (l.isExclusive()) value+= Double.MIN_VALUE; + + return value; + } + + public double maxValue() { + Range range = getRange(); + if (range==null) return Double.MAX_VALUE; + Limit l = range.getUpper(); + double value = l.getValue().doubleValue(); + + // Won't work + if (l.isExclusive()) value-= Double.MIN_VALUE; + + return value; + } + + @Override + protected boolean deepEquals(Object obj, Set> compareHistory) { + if (this==obj) return true; + if ( !hasEqualMetadata(obj) ) return false; + return obj instanceof DoubleType; + } + + @Override + public int hashCode() { + return 0xabcff33 + metadataHashCode(); + } + + @Override + public void accept(Visitor1 v, Object obj) { + v.visit(this, obj); + } + + @Override + public T accept(Visitor v) { + return v.visit(this); + } + +}