From f2037af115d8459aeaed003bb7c4aa0557a040b9 Mon Sep 17 00:00:00 2001 From: Ben Culkin Date: Wed, 25 Oct 2023 19:33:51 -0400 Subject: Tweak --- .../main/java/bjc/pratt/tokens/SimpleToken.java | 60 ++++++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 JPratt/src/main/java/bjc/pratt/tokens/SimpleToken.java (limited to 'JPratt/src/main/java/bjc/pratt/tokens/SimpleToken.java') diff --git a/JPratt/src/main/java/bjc/pratt/tokens/SimpleToken.java b/JPratt/src/main/java/bjc/pratt/tokens/SimpleToken.java new file mode 100644 index 0000000..18e2e5a --- /dev/null +++ b/JPratt/src/main/java/bjc/pratt/tokens/SimpleToken.java @@ -0,0 +1,60 @@ +package bjc.pratt.tokens; + +import java.util.Objects; + +/** + * Simple token implementation + * + * @author bjcul + * + * @param The key type + * @param The value type + * + */ +public class SimpleToken implements Token { + private K key; + private V value; + + /** + * Create a new token + * @param key The key + * @param value The value + */ + public SimpleToken(K key, V value) { + super(); + this.key = key; + this.value = value; + } + + @Override + public K getKey() { + return key; + } + + @Override + public V getValue() { + return value; + } + + @Override + public int hashCode() { + return Objects.hash(key, value); + } + + @Override + public boolean equals(Object obj) { + if (this == obj) + return true; + if (obj == null) + return false; + if (getClass() != obj.getClass()) + return false; + SimpleToken other = (SimpleToken) obj; + return Objects.equals(key, other.key) && Objects.equals(value, other.value); + } + + @Override + public String toString() { + return "SimpleToken [key=" + key + ", value=" + value + "]"; + } +} -- cgit v1.2.3