From 9f5a9eae9a7863412cc5eb433bf15e5ee71da616 Mon Sep 17 00:00:00 2001 From: Danielshe Date: Sun, 3 Nov 2019 14:44:52 +0800 Subject: 3.2.1 --- .../me/shedaniel/rei/impl/AbstractEntryStack.java | 78 ++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 src/main/java/me/shedaniel/rei/impl/AbstractEntryStack.java (limited to 'src/main/java/me/shedaniel/rei/impl/AbstractEntryStack.java') diff --git a/src/main/java/me/shedaniel/rei/impl/AbstractEntryStack.java b/src/main/java/me/shedaniel/rei/impl/AbstractEntryStack.java new file mode 100644 index 000000000..e32ac3275 --- /dev/null +++ b/src/main/java/me/shedaniel/rei/impl/AbstractEntryStack.java @@ -0,0 +1,78 @@ +/* + * Roughly Enough Items by Danielshe. + * Licensed under the MIT License. + */ + +package me.shedaniel.rei.impl; + +import me.shedaniel.rei.api.EntryStack; +import me.shedaniel.rei.api.ObjectHolder; +import net.minecraft.client.gui.DrawableHelper; + +import java.util.HashMap; +import java.util.Map; + +@Deprecated +public abstract class AbstractEntryStack extends DrawableHelper implements EntryStack { + private Map settings = new HashMap<>(); + + @Override + public EntryStack setting(Settings settings, T value) { + this.settings.put(settings, value); + return this; + } + + @Override + public EntryStack removeSetting(Settings settings) { + this.settings.remove(settings); + return this; + } + + @Override + public EntryStack clearSettings() { + this.settings.clear(); + return this; + } + + protected Map getSettings() { + return settings; + } + + @Override + public ObjectHolder getSetting(Settings settings) { + Object o = this.settings.get(settings); + if (o == null) + return new ObjectHolderImpl(settings.getDefaultValue()); + return new ObjectHolderImpl(o); + } + + @Override + public boolean equals(EntryStack stack, boolean ignoreTags, boolean ignoreAmount) { + if (ignoreTags && ignoreAmount) + return equalsIgnoreTagsAndAmount(stack); + if (ignoreAmount) + return equalsIgnoreAmount(stack); + if (ignoreTags) + return equalsIgnoreTags(stack); + return equalsAll(stack); + } + + @Override + public boolean equals(Object obj) { + if (!(obj instanceof EntryStack)) + return false; + EntryStack stack = (EntryStack) obj; + boolean checkTags = getSetting(Settings.CHECK_TAGS).value().get() || stack.getSetting(Settings.CHECK_TAGS).value().get(); + return equals(stack, !checkTags, true); + } + + @Override + public int getZ() { + return blitOffset; + } + + @Override + public void setZ(int z) { + blitOffset = z; + } +} -- cgit