diff options
| author | shedaniel <daniel@shedaniel.me> | 2022-06-16 23:06:03 +0800 |
|---|---|---|
| committer | shedaniel <daniel@shedaniel.me> | 2022-06-16 23:06:03 +0800 |
| commit | 4b905c710d65ce50516a02cf3808269e8f493b0b (patch) | |
| tree | 94b1e5ad8fb9134b7a1ba9dfe25dd5146ca38d3f /runtime/src | |
| parent | 08bfbc9fc67f3260f4fdd172077cfb89a0f95884 (diff) | |
| download | RoughlyEnoughItems-4b905c710d65ce50516a02cf3808269e8f493b0b.tar.gz RoughlyEnoughItems-4b905c710d65ce50516a02cf3808269e8f493b0b.tar.bz2 RoughlyEnoughItems-4b905c710d65ce50516a02cf3808269e8f493b0b.zip | |
Add acceptsNull() in EntryDefinition
Diffstat (limited to 'runtime/src')
3 files changed, 15 insertions, 0 deletions
diff --git a/runtime/src/main/java/me/shedaniel/rei/impl/common/entry/TypedEntryStack.java b/runtime/src/main/java/me/shedaniel/rei/impl/common/entry/TypedEntryStack.java index 7112af245..5d159d79b 100644 --- a/runtime/src/main/java/me/shedaniel/rei/impl/common/entry/TypedEntryStack.java +++ b/runtime/src/main/java/me/shedaniel/rei/impl/common/entry/TypedEntryStack.java @@ -34,6 +34,11 @@ public class TypedEntryStack<T> extends AbstractEntryStack<T> { public TypedEntryStack(EntryDefinition<T> definition, T value) { this.definition = definition; this.value = value; + if (!definition.acceptsNull()) { + if (value == null) { + throw new IllegalArgumentException("Value cannot be null for " + definition.getType().getId()); + } + } } @Override diff --git a/runtime/src/main/java/me/shedaniel/rei/plugin/client/entry/FluidEntryDefinition.java b/runtime/src/main/java/me/shedaniel/rei/plugin/client/entry/FluidEntryDefinition.java index 5bdfec4c1..ce7061d3e 100644 --- a/runtime/src/main/java/me/shedaniel/rei/plugin/client/entry/FluidEntryDefinition.java +++ b/runtime/src/main/java/me/shedaniel/rei/plugin/client/entry/FluidEntryDefinition.java @@ -180,6 +180,11 @@ public class FluidEntryDefinition implements EntryDefinition<FluidStack>, EntryS } @Override + public boolean acceptsNull() { + return false; + } + + @Override public CompoundTag save(EntryStack<FluidStack> entry, FluidStack value) { return value.write(new CompoundTag()); } diff --git a/runtime/src/main/java/me/shedaniel/rei/plugin/client/entry/ItemEntryDefinition.java b/runtime/src/main/java/me/shedaniel/rei/plugin/client/entry/ItemEntryDefinition.java index bb53ba44b..7728a55a2 100644 --- a/runtime/src/main/java/me/shedaniel/rei/plugin/client/entry/ItemEntryDefinition.java +++ b/runtime/src/main/java/me/shedaniel/rei/plugin/client/entry/ItemEntryDefinition.java @@ -170,6 +170,11 @@ public class ItemEntryDefinition implements EntryDefinition<ItemStack>, EntrySer } @Override + public boolean acceptsNull() { + return false; + } + + @Override public CompoundTag save(EntryStack<ItemStack> entry, ItemStack value) { return value.save(new CompoundTag()); } |
