From c25b68c6b24d86b7d1169ad4ec1e619d79a2b38d Mon Sep 17 00:00:00 2001 From: student Date: Mon, 12 Feb 2018 12:01:53 -0500 Subject: Split SCLToken into subclasses. Instead of one class with a lot of fields whose state varies based on an enum, we now have a hierarchy of classes that does the same in a more obvious manner. --- base/src/bjc/dicelang/scl/BooleanSCLToken.java | 39 ++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 base/src/bjc/dicelang/scl/BooleanSCLToken.java (limited to 'base/src/bjc/dicelang/scl/BooleanSCLToken.java') diff --git a/base/src/bjc/dicelang/scl/BooleanSCLToken.java b/base/src/bjc/dicelang/scl/BooleanSCLToken.java new file mode 100644 index 0000000..5f89ce0 --- /dev/null +++ b/base/src/bjc/dicelang/scl/BooleanSCLToken.java @@ -0,0 +1,39 @@ +package bjc.dicelang.scl; + +public class BooleanSCLToken extends SCLToken { + /* Used for BLIT */ + public boolean boolVal; + + public BooleanSCLToken(boolean val) { + super(Type.BLIT); + + boolVal = val; + } + + @Override + public int hashCode() { + final int prime = 31; + int result = super.hashCode(); + result = prime * result + (boolVal ? 1231 : 1237); + 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; + BooleanSCLToken other = (BooleanSCLToken) obj; + if (boolVal != other.boolVal) + return false; + return true; + } + + @Override + public String toString() { + return "BooleanSCLToken [boolVal=" + boolVal + "]"; + } +} -- cgit v1.2.3