From a15873fb42e8db3b2101330514b2208ef3490d70 Mon Sep 17 00:00:00 2001 From: student Date: Mon, 12 Feb 2018 12:14:27 -0500 Subject: Further refactor SCL token organization Added some more SCL token subclasses to make it obvious what classes went to what token types. --- base/src/bjc/dicelang/scl/WordListSCLToken.java | 48 +++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 base/src/bjc/dicelang/scl/WordListSCLToken.java (limited to 'base/src/bjc/dicelang/scl/WordListSCLToken.java') diff --git a/base/src/bjc/dicelang/scl/WordListSCLToken.java b/base/src/bjc/dicelang/scl/WordListSCLToken.java new file mode 100644 index 0000000..d13f7ab --- /dev/null +++ b/base/src/bjc/dicelang/scl/WordListSCLToken.java @@ -0,0 +1,48 @@ +package bjc.dicelang.scl; + +import bjc.utils.funcdata.IList; + +public class WordListSCLToken extends SCLToken { + /* Used for WORDS & ARRAY */ + public IList tokenVals; + + protected WordListSCLToken(boolean isArray, IList tokens) { + if(isArray) { + type = Type.ARRAY; + } else { + type = Type.WORDS; + } + + tokenVals = tokens; + } + + @Override + public int hashCode() { + final int prime = 31; + int result = super.hashCode(); + result = prime * result + ((tokenVals == null) ? 0 : tokenVals.hashCode()); + 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; + WordListSCLToken other = (WordListSCLToken) obj; + if (tokenVals == null) { + if (other.tokenVals != null) + return false; + } else if (!tokenVals.equals(other.tokenVals)) + return false; + return true; + } + + @Override + public String toString() { + return "WordsSCLToken [tokenVals=" + tokenVals + "]"; + } +} -- cgit v1.2.3