From 7ac470c22e9e179daf0a10579a9f9e347cf6f94f Mon Sep 17 00:00:00 2001 From: "Benjamin J. Culkin" Date: Mon, 28 May 2018 13:42:11 -0300 Subject: Move SCL into new project SCL is now independant of dicelang, and thus deserving of its own repo. --- .../bjc/dicelang/scl/tokens/FloatSCLToken.java | 55 ++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 src/main/java/bjc/dicelang/scl/tokens/FloatSCLToken.java (limited to 'src/main/java/bjc/dicelang/scl/tokens/FloatSCLToken.java') diff --git a/src/main/java/bjc/dicelang/scl/tokens/FloatSCLToken.java b/src/main/java/bjc/dicelang/scl/tokens/FloatSCLToken.java new file mode 100644 index 0000000..82e44e2 --- /dev/null +++ b/src/main/java/bjc/dicelang/scl/tokens/FloatSCLToken.java @@ -0,0 +1,55 @@ +package bjc.dicelang.scl.tokens; + +/** + * Represents a floating-point token. + * + * @author student + * + */ +public class FloatSCLToken extends SCLToken { + /** + * The value of the token. + */ + public double floatVal; + + /** + * Create a new floating-point token. + * + * @param val + * The value of the token. + */ + public FloatSCLToken(double val) { + super(TokenType.FLIT); + + floatVal = val; + } + + @Override + public int hashCode() { + final int prime = 31; + int result = super.hashCode(); + long temp; + temp = Double.doubleToLongBits(floatVal); + result = prime * result + (int) (temp ^ (temp >>> 32)); + return result; + } + + @Override + public boolean equals(Object obj) { + if (this == obj) + return true; + if (!super.equals(obj)) + return false; + if (getClass() != obj.getClass()) + return false; + FloatSCLToken other = (FloatSCLToken) obj; + if (Double.doubleToLongBits(floatVal) != Double.doubleToLongBits(other.floatVal)) + return false; + return true; + } + + @Override + public String toString() { + return "FloatSCLToken [floatVal=" + floatVal + "]"; + } +} -- cgit v1.2.3