From 13a96e852f2fea4d3b3cb03cf803007b9b63041e Mon Sep 17 00:00:00 2001 From: Benjamin Culkin Date: Thu, 9 Nov 2023 01:58:31 +0000 Subject: Add decimals Add decimal literals and default to them over floats --- .../bjc/dicelang/eval/DecimalEvaluatorResult.java | 39 ++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 base/src/bjc/dicelang/eval/DecimalEvaluatorResult.java (limited to 'base/src/bjc/dicelang/eval/DecimalEvaluatorResult.java') diff --git a/base/src/bjc/dicelang/eval/DecimalEvaluatorResult.java b/base/src/bjc/dicelang/eval/DecimalEvaluatorResult.java new file mode 100644 index 0000000..8b37d53 --- /dev/null +++ b/base/src/bjc/dicelang/eval/DecimalEvaluatorResult.java @@ -0,0 +1,39 @@ +package bjc.dicelang.eval; + +import java.math.BigDecimal; +import java.util.Objects; + +public class DecimalEvaluatorResult extends EvaluatorResult { + public BigDecimal val; + + public DecimalEvaluatorResult(BigDecimal val) { + super(Type.DEC); + + this.val = val; + } + + @Override + public String toString() { + return super.toString() + "(" + val + ")"; + } + + @Override + public int hashCode() { + final int prime = 31; + int result = super.hashCode(); + result = prime * result + Objects.hash(val); + 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; + DecimalEvaluatorResult other = (DecimalEvaluatorResult) obj; + return Objects.equals(val, other.val); + } +} -- cgit v1.2.3