
soot.jimple.DoubleConstant Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of soot Show documentation
Show all versions of soot Show documentation
A Java Optimization Framework
package soot.jimple;
/*-
* #%L
* Soot - a J*va Optimization Framework
* %%
* Copyright (C) 1997 - 1999 Raja Vallee-Rai
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 2.1 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
import soot.DoubleType;
import soot.Type;
import soot.util.Switch;
/**
* Floating point constant with double precision.
*/
public class DoubleConstant extends RealConstant {
public final double value;
private DoubleConstant(double value) {
this.value = value;
}
public static DoubleConstant v(double value) {
return new DoubleConstant(value);
}
@Override
public boolean equals(Object c) {
return (c instanceof DoubleConstant && Double.compare(((DoubleConstant) c).value, this.value) == 0);
}
/**
* Returns a hash code for this DoubleConstant object.
*/
@Override
public int hashCode() {
long v = Double.doubleToLongBits(value);
return (int) (v ^ (v >>> 32));
}
// PTC 1999/06/28
@Override
public NumericConstant add(NumericConstant c) {
assertInstanceOf(c);
return DoubleConstant.v(this.value + ((DoubleConstant) c).value);
}
@Override
public NumericConstant subtract(NumericConstant c) {
assertInstanceOf(c);
return DoubleConstant.v(this.value - ((DoubleConstant) c).value);
}
@Override
public NumericConstant multiply(NumericConstant c) {
assertInstanceOf(c);
return DoubleConstant.v(this.value * ((DoubleConstant) c).value);
}
@Override
public NumericConstant divide(NumericConstant c) {
assertInstanceOf(c);
return DoubleConstant.v(this.value / ((DoubleConstant) c).value);
}
@Override
public NumericConstant remainder(NumericConstant c) {
assertInstanceOf(c);
return DoubleConstant.v(this.value % ((DoubleConstant) c).value);
}
@Override
public NumericConstant equalEqual(NumericConstant c) {
assertInstanceOf(c);
return IntConstant.v(Double.compare(this.value, ((DoubleConstant) c).value) == 0 ? 1 : 0);
}
@Override
public NumericConstant notEqual(NumericConstant c) {
assertInstanceOf(c);
return IntConstant.v(Double.compare(this.value, ((DoubleConstant) c).value) != 0 ? 1 : 0);
}
@Override
public NumericConstant lessThan(NumericConstant c) {
assertInstanceOf(c);
return IntConstant.v(Double.compare(this.value, ((DoubleConstant) c).value) < 0 ? 1 : 0);
}
@Override
public NumericConstant lessThanOrEqual(NumericConstant c) {
assertInstanceOf(c);
return IntConstant.v(Double.compare(this.value, ((DoubleConstant) c).value) <= 0 ? 1 : 0);
}
@Override
public NumericConstant greaterThan(NumericConstant c) {
assertInstanceOf(c);
return IntConstant.v(Double.compare(this.value, ((DoubleConstant) c).value) > 0 ? 1 : 0);
}
@Override
public NumericConstant greaterThanOrEqual(NumericConstant c) {
assertInstanceOf(c);
return IntConstant.v(Double.compare(this.value, ((DoubleConstant) c).value) >= 0 ? 1 : 0);
}
@Override
public IntConstant cmpg(RealConstant constant) {
assertInstanceOf(constant);
final double cValue = ((DoubleConstant) constant).value;
if (this.value < cValue) {
return IntConstant.v(-1);
} else if (this.value == cValue) {
return IntConstant.v(0);
} else {
return IntConstant.v(1);
}
}
@Override
public IntConstant cmpl(RealConstant constant) {
assertInstanceOf(constant);
final double cValue = ((DoubleConstant) constant).value;
if (this.value > cValue) {
return IntConstant.v(1);
} else if (this.value == cValue) {
return IntConstant.v(0);
} else {
return IntConstant.v(-1);
}
}
@Override
public NumericConstant negate() {
return DoubleConstant.v(-(this.value));
}
@Override
public String toString() {
String doubleString = Double.toString(value);
if (doubleString.equals("NaN") || doubleString.equals("Infinity") || doubleString.equals("-Infinity")) {
return "#" + doubleString;
} else {
return doubleString;
}
}
@Override
public Type getType() {
return DoubleType.v();
}
@Override
public void apply(Switch sw) {
((ConstantSwitch) sw).caseDoubleConstant(this);
}
/**
* Checks if passed argument is instance of expected class.
*
* @param constant
* the instance to check
* @throws IllegalArgumentException
* when check fails
*/
private void assertInstanceOf(NumericConstant constant) {
if (!(constant instanceof DoubleConstant)) {
throw new IllegalArgumentException("DoubleConstant expected");
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy