registry changes

This commit is contained in:
kashike 2018-07-05 01:48:37 -07:00 committed by Matthew Miller
parent a48c319e7e
commit d33e2e98aa
25 changed files with 1496 additions and 1528 deletions

View File

@ -557,9 +557,9 @@ public class LocalSession {
public void setTool(ItemType item, @Nullable Tool tool) throws InvalidToolBindException { public void setTool(ItemType item, @Nullable Tool tool) throws InvalidToolBindException {
if (item.hasBlockType()) { if (item.hasBlockType()) {
throw new InvalidToolBindException(item, "Blocks can't be used"); throw new InvalidToolBindException(item, "Blocks can't be used");
} else if (item == ItemTypes.getItemType(config.wandItem)) { } else if (item == ItemTypes.get(config.wandItem)) {
throw new InvalidToolBindException(item, "Already used for the wand"); throw new InvalidToolBindException(item, "Already used for the wand");
} else if (item == ItemTypes.getItemType(config.navigationWand)) { } else if (item == ItemTypes.get(config.navigationWand)) {
throw new InvalidToolBindException(item, "Already used for the navigation wand"); throw new InvalidToolBindException(item, "Already used for the navigation wand");
} }

View File

@ -163,7 +163,7 @@ public class GeneralCommands {
boolean blocksOnly = args.hasFlag('b'); boolean blocksOnly = args.hasFlag('b');
boolean itemsOnly = args.hasFlag('i'); boolean itemsOnly = args.hasFlag('i');
ItemType type = ItemTypes.getItemType(query); ItemType type = ItemTypes.get(query);
if (type != null) { if (type != null) {
actor.print(type.getId() + " (" + type.getName() + ")"); actor.print(type.getId() + " (" + type.getName() + ")");

View File

@ -278,7 +278,7 @@ public class SelectionCommands {
@CommandPermissions("worldedit.wand") @CommandPermissions("worldedit.wand")
public void wand(Player player, LocalSession session, EditSession editSession, CommandContext args) throws WorldEditException { public void wand(Player player, LocalSession session, EditSession editSession, CommandContext args) throws WorldEditException {
player.giveItem(new BaseItemStack(ItemTypes.getItemType(we.getConfiguration().wandItem), 1)); player.giveItem(new BaseItemStack(ItemTypes.get(we.getConfiguration().wandItem), 1));
player.print("Left click: select pos #1; Right click: select pos #2"); player.print("Left click: select pos #1; Right click: select pos #2");
} }

View File

@ -232,7 +232,7 @@ class DefaultBlockParser extends InputParser<BlockStateHolder> {
blockStates = blockInHand.getStates(); blockStates = blockInHand.getStates();
} else { } else {
// Attempt to lookup a block from ID or name. // Attempt to lookup a block from ID or name.
blockType = BlockTypes.getBlockType(typeString); blockType = BlockTypes.get(typeString);
if (blockType == null) { if (blockType == null) {
throw new NoMatchException("Does not match a valid block type: '" + input + "'"); throw new NoMatchException("Does not match a valid block type: '" + input + "'");

View File

@ -0,0 +1,66 @@
/*
* WorldEdit, a Minecraft world manipulation toolkit
* Copyright (C) sk89q <http://www.sk89q.com>
* Copyright (C) WorldEdit team and contributors
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by the
* Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.sk89q.worldedit.registry;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import javax.annotation.Nullable;
import static com.google.common.base.Preconditions.checkState;
import static java.util.Objects.requireNonNull;
public final class NamespacedRegistry<V> {
private static final String MINECRAFT_NAMESPACE = "minecraft";
private final Map<String, V> map = new HashMap<>();
public @Nullable V get(final String key) {
checkState(key.equals(key.toLowerCase()), "key must be lowercase");
return this.map.get(this.orDefaultNamespace(key));
}
public V register(final String key, final V value) {
requireNonNull(key, "key");
requireNonNull(value, "value");
checkState(key.indexOf(':') > -1, "key is not namespaced");
checkState(key.equals(key.toLowerCase()), "key must be lowercase");
checkState(!this.map.containsKey(key), "key %s already has an entry", key);
this.map.put(key, value);
return value;
}
public Set<String> keySet() {
return Collections.unmodifiableSet(this.map.keySet());
}
public Collection<V> values() {
return Collections.unmodifiableCollection(this.map.values());
}
private String orDefaultNamespace(final String key) {
if (key.indexOf(':') == -1) {
return MINECRAFT_NAMESPACE + ':' + key;
}
return key;
}
}

View File

@ -34,71 +34,53 @@ public class BlockCategories {
private BlockCategories() { private BlockCategories() {
} }
public static final BlockCategory ACACIA_LOGS = new BlockCategory("minecraft:acacia_logs"); public static final BlockCategory ACACIA_LOGS = register("minecraft:acacia_logs");
public static final BlockCategory ANVIL = new BlockCategory("minecraft:anvil"); public static final BlockCategory ANVIL = register("minecraft:anvil");
public static final BlockCategory BANNERS = new BlockCategory("minecraft:banners"); public static final BlockCategory BANNERS = register("minecraft:banners");
public static final BlockCategory BIRCH_LOGS = new BlockCategory("minecraft:birch_logs"); public static final BlockCategory BIRCH_LOGS = register("minecraft:birch_logs");
public static final BlockCategory BUTTONS = new BlockCategory("minecraft:buttons"); public static final BlockCategory BUTTONS = register("minecraft:buttons");
public static final BlockCategory CARPETS = new BlockCategory("minecraft:carpets"); public static final BlockCategory CARPETS = register("minecraft:carpets");
public static final BlockCategory CORAL = new BlockCategory("minecraft:coral"); public static final BlockCategory CORAL = register("minecraft:coral");
public static final BlockCategory CORAL_PLANTS = new BlockCategory("minecraft:coral_plants"); public static final BlockCategory CORAL_PLANTS = register("minecraft:coral_plants");
public static final BlockCategory DARK_OAK_LOGS = new BlockCategory("minecraft:dark_oak_logs"); public static final BlockCategory DARK_OAK_LOGS = register("minecraft:dark_oak_logs");
public static final BlockCategory DOORS = new BlockCategory("minecraft:doors"); public static final BlockCategory DOORS = register("minecraft:doors");
public static final BlockCategory ENDERMAN_HOLDABLE = new BlockCategory("minecraft:enderman_holdable"); public static final BlockCategory ENDERMAN_HOLDABLE = register("minecraft:enderman_holdable");
public static final BlockCategory FLOWER_POTS = new BlockCategory("minecraft:flower_pots"); public static final BlockCategory FLOWER_POTS = register("minecraft:flower_pots");
public static final BlockCategory ICE = new BlockCategory("minecraft:ice"); public static final BlockCategory ICE = register("minecraft:ice");
public static final BlockCategory JUNGLE_LOGS = new BlockCategory("minecraft:jungle_logs"); public static final BlockCategory JUNGLE_LOGS = register("minecraft:jungle_logs");
public static final BlockCategory LEAVES = new BlockCategory("minecraft:leaves"); public static final BlockCategory LEAVES = register("minecraft:leaves");
public static final BlockCategory LOGS = new BlockCategory("minecraft:logs"); public static final BlockCategory LOGS = register("minecraft:logs");
public static final BlockCategory OAK_LOGS = new BlockCategory("minecraft:oak_logs"); public static final BlockCategory OAK_LOGS = register("minecraft:oak_logs");
public static final BlockCategory PLANKS = new BlockCategory("minecraft:planks"); public static final BlockCategory PLANKS = register("minecraft:planks");
public static final BlockCategory RAILS = new BlockCategory("minecraft:rails"); public static final BlockCategory RAILS = register("minecraft:rails");
public static final BlockCategory SAND = new BlockCategory("minecraft:sand"); public static final BlockCategory SAND = register("minecraft:sand");
public static final BlockCategory SAPLINGS = new BlockCategory("minecraft:saplings"); public static final BlockCategory SAPLINGS = register("minecraft:saplings");
public static final BlockCategory SLABS = new BlockCategory("minecraft:slabs"); public static final BlockCategory SLABS = register("minecraft:slabs");
public static final BlockCategory SPRUCE_LOGS = new BlockCategory("minecraft:spruce_logs"); public static final BlockCategory SPRUCE_LOGS = register("minecraft:spruce_logs");
public static final BlockCategory STAIRS = new BlockCategory("minecraft:stairs"); public static final BlockCategory STAIRS = register("minecraft:stairs");
public static final BlockCategory STONE_BRICKS = new BlockCategory("minecraft:stone_bricks"); public static final BlockCategory STONE_BRICKS = register("minecraft:stone_bricks");
public static final BlockCategory VALID_SPAWN = new BlockCategory("minecraft:valid_spawn"); public static final BlockCategory VALID_SPAWN = register("minecraft:valid_spawn");
public static final BlockCategory WOODEN_BUTTONS = new BlockCategory("minecraft:wooden_buttons"); public static final BlockCategory WOODEN_BUTTONS = register("minecraft:wooden_buttons");
public static final BlockCategory WOODEN_DOORS = new BlockCategory("minecraft:wooden_doors"); public static final BlockCategory WOODEN_DOORS = register("minecraft:wooden_doors");
public static final BlockCategory WOODEN_PRESSURE_PLATES = new BlockCategory("minecraft:wooden_pressure_plates"); public static final BlockCategory WOODEN_PRESSURE_PLATES = register("minecraft:wooden_pressure_plates");
public static final BlockCategory WOODEN_SLABS = new BlockCategory("minecraft:wooden_slabs"); public static final BlockCategory WOODEN_SLABS = register("minecraft:wooden_slabs");
public static final BlockCategory WOODEN_STAIRS = new BlockCategory("minecraft:wooden_stairs"); public static final BlockCategory WOODEN_STAIRS = register("minecraft:wooden_stairs");
public static final BlockCategory WOOL = new BlockCategory("minecraft:wool"); public static final BlockCategory WOOL = register("minecraft:wool");
private static final Map<String, BlockCategory> categoryMapping = new HashMap<>(); private static BlockCategory register(final String id) {
return register(new BlockCategory(id));
static {
for (Field field : BlockCategories.class.getFields()) {
if (field.getType() == BlockCategory.class) {
try {
registerCategory((BlockCategory) field.get(null));
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
} }
public static void registerCategory(BlockCategory blockCategory) { public static BlockCategory register(final BlockCategory tag) {
if (categoryMapping.containsKey(blockCategory.getId()) && !blockCategory.getId().startsWith("minecraft:")) { return BlockCategory.REGISTRY.register(tag.getId(), tag);
throw new IllegalArgumentException("Existing category with this ID already registered");
}
categoryMapping.put(blockCategory.getId(), blockCategory);
} }
@Nullable @Nullable
public static BlockCategory getBlockCategory(String id) { public static BlockCategory get(final String id) {
// If it has no namespace, assume minecraft. return BlockCategory.REGISTRY.get(id);
if (id != null && !id.contains(":")) {
id = "minecraft:" + id;
}
return categoryMapping.get(id);
} }
public static Collection<BlockCategory> values() { public static Collection<BlockCategory> values() {
return categoryMapping.values(); return BlockCategory.REGISTRY.values();
} }
} }

View File

@ -21,6 +21,7 @@ package com.sk89q.worldedit.world.block;
import com.sk89q.worldedit.WorldEdit; import com.sk89q.worldedit.WorldEdit;
import com.sk89q.worldedit.extension.platform.Capability; import com.sk89q.worldedit.extension.platform.Capability;
import com.sk89q.worldedit.registry.NamespacedRegistry;
import java.util.Set; import java.util.Set;
@ -30,6 +31,8 @@ import java.util.Set;
*/ */
public class BlockCategory { public class BlockCategory {
public static final NamespacedRegistry<BlockCategory> REGISTRY = new NamespacedRegistry<>();
private final String id; private final String id;
public BlockCategory(String id) { public BlockCategory(String id) {

View File

@ -22,6 +22,7 @@ package com.sk89q.worldedit.world.block;
import com.sk89q.worldedit.WorldEdit; import com.sk89q.worldedit.WorldEdit;
import com.sk89q.worldedit.blocks.BlockMaterial; import com.sk89q.worldedit.blocks.BlockMaterial;
import com.sk89q.worldedit.extension.platform.Capability; import com.sk89q.worldedit.extension.platform.Capability;
import com.sk89q.worldedit.registry.NamespacedRegistry;
import com.sk89q.worldedit.world.item.ItemType; import com.sk89q.worldedit.world.item.ItemType;
import com.sk89q.worldedit.world.item.ItemTypes; import com.sk89q.worldedit.world.item.ItemTypes;
import com.sk89q.worldedit.world.registry.BundledBlockData; import com.sk89q.worldedit.world.registry.BundledBlockData;
@ -33,6 +34,8 @@ import javax.annotation.Nullable;
public class BlockType { public class BlockType {
public static final NamespacedRegistry<BlockType> REGISTRY = new NamespacedRegistry<>();
private String id; private String id;
private BlockState defaultState; private BlockState defaultState;
@ -100,7 +103,7 @@ public class BlockType {
*/ */
@Nullable @Nullable
public ItemType getItemType() { public ItemType getItemType() {
return ItemTypes.getItemType(this.id); return ItemTypes.get(this.id);
} }
/** /**

View File

@ -19,10 +19,7 @@
package com.sk89q.worldedit.world.fluid; package com.sk89q.worldedit.world.fluid;
import java.lang.reflect.Field;
import java.util.Collection; import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import javax.annotation.Nullable; import javax.annotation.Nullable;
@ -34,41 +31,23 @@ public class FluidCategories {
private FluidCategories() { private FluidCategories() {
} }
public static final FluidCategory LAVA = new FluidCategory("minecraft:lava"); public static final FluidCategory LAVA = register("minecraft:lava");
public static final FluidCategory WATER = new FluidCategory("minecraft:water"); public static final FluidCategory WATER = register("minecraft:water");
private static final Map<String, FluidCategory> categoryMapping = new HashMap<>(); private static FluidCategory register(final String id) {
return register(new FluidCategory(id));
static {
for (Field field : FluidCategories.class.getFields()) {
if (field.getType() == FluidCategory.class) {
try {
registerCategory((FluidCategory) field.get(null));
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
} }
public static void registerCategory(FluidCategory fluidCategory) { public static FluidCategory register(final FluidCategory tag) {
if (categoryMapping.containsKey(fluidCategory.getId()) && !fluidCategory.getId().startsWith("minecraft:")) { return FluidCategory.REGISTRY.register(tag.getId(), tag);
throw new IllegalArgumentException("Existing category with this ID already registered");
}
categoryMapping.put(fluidCategory.getId(), fluidCategory);
} }
@Nullable @Nullable
public static FluidCategory getFluidCategory(String id) { public static FluidCategory get(final String id) {
// If it has no namespace, assume minecraft. return FluidCategory.REGISTRY.get(id);
if (id != null && !id.contains(":")) {
id = "minecraft:" + id;
}
return categoryMapping.get(id);
} }
public static Collection<FluidCategory> values() { public static Collection<FluidCategory> values() {
return categoryMapping.values(); return FluidCategory.REGISTRY.values();
} }
} }

View File

@ -19,6 +19,8 @@
package com.sk89q.worldedit.world.fluid; package com.sk89q.worldedit.world.fluid;
import com.sk89q.worldedit.registry.NamespacedRegistry;
import java.util.Collections; import java.util.Collections;
import java.util.Set; import java.util.Set;
@ -28,6 +30,8 @@ import java.util.Set;
*/ */
public class FluidCategory { public class FluidCategory {
public static final NamespacedRegistry<FluidCategory> REGISTRY = new NamespacedRegistry<>();
private final String id; private final String id;
public FluidCategory(String id) { public FluidCategory(String id) {

View File

@ -19,12 +19,16 @@
package com.sk89q.worldedit.world.fluid; package com.sk89q.worldedit.world.fluid;
import com.sk89q.worldedit.registry.NamespacedRegistry;
/** /**
* Minecraft now has a 'fluid' system. This is a * Minecraft now has a 'fluid' system. This is a
* stub class to represent what it may be in the future. * stub class to represent what it may be in the future.
*/ */
public class FluidType { public class FluidType {
public static final NamespacedRegistry<FluidType> REGISTRY = new NamespacedRegistry<>();
private String id; private String id;
public FluidType(String id) { public FluidType(String id) {

View File

@ -19,10 +19,7 @@
package com.sk89q.worldedit.world.fluid; package com.sk89q.worldedit.world.fluid;
import java.lang.reflect.Field;
import java.util.Collection; import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import javax.annotation.Nullable; import javax.annotation.Nullable;
@ -34,45 +31,26 @@ public class FluidTypes {
private FluidTypes() { private FluidTypes() {
} }
public static final FluidType EMPTY = new FluidType("minecraft:empty"); public static final FluidType EMPTY = register("minecraft:empty");
public static final FluidType FLOWING_LAVA = new FluidType("minecraft:flowing_lava"); public static final FluidType FLOWING_LAVA = register("minecraft:flowing_lava");
public static final FluidType FLOWING_WATER = new FluidType("minecraft:flowing_water"); public static final FluidType FLOWING_WATER = register("minecraft:flowing_water");
public static final FluidType LAVA = new FluidType("minecraft:lava"); public static final FluidType LAVA = register("minecraft:lava");
public static final FluidType WATER = new FluidType("minecraft:water"); public static final FluidType WATER = register("minecraft:water");
private static FluidType register(final String id) {
private static final Map<String, FluidType> fluidMapping = new HashMap<>(); return register(new FluidType(id));
static {
for (Field field : FluidTypes.class.getFields()) {
if (field.getType() == FluidType.class) {
try {
registerFluid((FluidType) field.get(null));
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
} }
public static void registerFluid(FluidType fluidType) { public static FluidType register(final FluidType fluid) {
if (fluidMapping.containsKey(fluidType.getId()) && !fluidType.getId().startsWith("minecraft:")) { return FluidType.REGISTRY.register(fluid.getId(), fluid);
throw new IllegalArgumentException("Existing fluid with this ID already registered");
}
fluidMapping.put(fluidType.getId(), fluidType);
} }
@Nullable @Nullable
public static FluidType getFluidType(String id) { public static FluidType getFluidType(final String id) {
// If it has no namespace, assume minecraft. return FluidType.REGISTRY.get(id);
if (id != null && !id.contains(":")) {
id = "minecraft:" + id;
}
return fluidMapping.get(id);
} }
public static Collection<FluidType> values() { public static Collection<FluidType> values() {
return fluidMapping.values(); return FluidType.REGISTRY.values();
} }
} }

View File

@ -34,69 +34,51 @@ public class ItemCategories {
private ItemCategories() { private ItemCategories() {
} }
public static final ItemCategory ACACIA_LOGS = new ItemCategory("minecraft:acacia_logs"); public static final ItemCategory ACACIA_LOGS = register("minecraft:acacia_logs");
public static final ItemCategory ANVIL = new ItemCategory("minecraft:anvil"); public static final ItemCategory ANVIL = register("minecraft:anvil");
public static final ItemCategory BANNERS = new ItemCategory("minecraft:banners"); public static final ItemCategory BANNERS = register("minecraft:banners");
public static final ItemCategory BIRCH_LOGS = new ItemCategory("minecraft:birch_logs"); public static final ItemCategory BIRCH_LOGS = register("minecraft:birch_logs");
public static final ItemCategory BOATS = new ItemCategory("minecraft:boats"); public static final ItemCategory BOATS = register("minecraft:boats");
public static final ItemCategory BUTTONS = new ItemCategory("minecraft:buttons"); public static final ItemCategory BUTTONS = register("minecraft:buttons");
public static final ItemCategory CARPETS = new ItemCategory("minecraft:carpets"); public static final ItemCategory CARPETS = register("minecraft:carpets");
public static final ItemCategory CORAL = new ItemCategory("minecraft:coral"); public static final ItemCategory CORAL = register("minecraft:coral");
public static final ItemCategory CORAL_PLANTS = new ItemCategory("minecraft:coral_plants"); public static final ItemCategory CORAL_PLANTS = register("minecraft:coral_plants");
public static final ItemCategory DARK_OAK_LOGS = new ItemCategory("minecraft:dark_oak_logs"); public static final ItemCategory DARK_OAK_LOGS = register("minecraft:dark_oak_logs");
public static final ItemCategory DOORS = new ItemCategory("minecraft:doors"); public static final ItemCategory DOORS = register("minecraft:doors");
public static final ItemCategory FISHES = new ItemCategory("minecraft:fishes"); public static final ItemCategory FISHES = register("minecraft:fishes");
public static final ItemCategory JUNGLE_LOGS = new ItemCategory("minecraft:jungle_logs"); public static final ItemCategory JUNGLE_LOGS = register("minecraft:jungle_logs");
public static final ItemCategory LEAVES = new ItemCategory("minecraft:leaves"); public static final ItemCategory LEAVES = register("minecraft:leaves");
public static final ItemCategory LOGS = new ItemCategory("minecraft:logs"); public static final ItemCategory LOGS = register("minecraft:logs");
public static final ItemCategory OAK_LOGS = new ItemCategory("minecraft:oak_logs"); public static final ItemCategory OAK_LOGS = register("minecraft:oak_logs");
public static final ItemCategory PLANKS = new ItemCategory("minecraft:planks"); public static final ItemCategory PLANKS = register("minecraft:planks");
public static final ItemCategory RAILS = new ItemCategory("minecraft:rails"); public static final ItemCategory RAILS = register("minecraft:rails");
public static final ItemCategory SAND = new ItemCategory("minecraft:sand"); public static final ItemCategory SAND = register("minecraft:sand");
public static final ItemCategory SAPLINGS = new ItemCategory("minecraft:saplings"); public static final ItemCategory SAPLINGS = register("minecraft:saplings");
public static final ItemCategory SLABS = new ItemCategory("minecraft:slabs"); public static final ItemCategory SLABS = register("minecraft:slabs");
public static final ItemCategory SPRUCE_LOGS = new ItemCategory("minecraft:spruce_logs"); public static final ItemCategory SPRUCE_LOGS = register("minecraft:spruce_logs");
public static final ItemCategory STAIRS = new ItemCategory("minecraft:stairs"); public static final ItemCategory STAIRS = register("minecraft:stairs");
public static final ItemCategory STONE_BRICKS = new ItemCategory("minecraft:stone_bricks"); public static final ItemCategory STONE_BRICKS = register("minecraft:stone_bricks");
public static final ItemCategory WOODEN_BUTTONS = new ItemCategory("minecraft:wooden_buttons"); public static final ItemCategory WOODEN_BUTTONS = register("minecraft:wooden_buttons");
public static final ItemCategory WOODEN_DOORS = new ItemCategory("minecraft:wooden_doors"); public static final ItemCategory WOODEN_DOORS = register("minecraft:wooden_doors");
public static final ItemCategory WOODEN_PRESSURE_PLATES = new ItemCategory("minecraft:wooden_pressure_plates"); public static final ItemCategory WOODEN_PRESSURE_PLATES = register("minecraft:wooden_pressure_plates");
public static final ItemCategory WOODEN_SLABS = new ItemCategory("minecraft:wooden_slabs"); public static final ItemCategory WOODEN_SLABS = register("minecraft:wooden_slabs");
public static final ItemCategory WOODEN_STAIRS = new ItemCategory("minecraft:wooden_stairs"); public static final ItemCategory WOODEN_STAIRS = register("minecraft:wooden_stairs");
public static final ItemCategory WOOL = new ItemCategory("minecraft:wool"); public static final ItemCategory WOOL = register("minecraft:wool");
private static final Map<String, ItemCategory> categoryMapping = new HashMap<>(); private static ItemCategory register(final String id) {
return register(new ItemCategory(id));
static {
for (Field field : ItemCategories.class.getFields()) {
if (field.getType() == ItemCategory.class) {
try {
registerCategory((ItemCategory) field.get(null));
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
} }
public static void registerCategory(ItemCategory itemCategory) { public static ItemCategory register(final ItemCategory tag) {
if (categoryMapping.containsKey(itemCategory.getId()) && !itemCategory.getId().startsWith("minecraft:")) { return ItemCategory.REGISTRY.register(tag.getId(), tag);
throw new IllegalArgumentException("Existing category with this ID already registered");
}
categoryMapping.put(itemCategory.getId(), itemCategory);
} }
@Nullable @Nullable
public static ItemCategory getItemCategory(String id) { public static ItemCategory get(final String id) {
// If it has no namespace, assume minecraft. return ItemCategory.REGISTRY.get(id);
if (id != null && !id.contains(":")) {
id = "minecraft:" + id;
}
return categoryMapping.get(id);
} }
public static Collection<ItemCategory> values() { public static Collection<ItemCategory> values() {
return categoryMapping.values(); return ItemCategory.REGISTRY.values();
} }
} }

View File

@ -22,6 +22,7 @@ package com.sk89q.worldedit.world.item;
import com.sk89q.worldedit.WorldEdit; import com.sk89q.worldedit.WorldEdit;
import com.sk89q.worldedit.blocks.BaseItem; import com.sk89q.worldedit.blocks.BaseItem;
import com.sk89q.worldedit.extension.platform.Capability; import com.sk89q.worldedit.extension.platform.Capability;
import com.sk89q.worldedit.registry.NamespacedRegistry;
import java.util.Set; import java.util.Set;
@ -31,6 +32,8 @@ import java.util.Set;
*/ */
public class ItemCategory { public class ItemCategory {
public static final NamespacedRegistry<ItemCategory> REGISTRY = new NamespacedRegistry<>();
private final String id; private final String id;
public ItemCategory(String id) { public ItemCategory(String id) {

View File

@ -19,6 +19,7 @@
package com.sk89q.worldedit.world.item; package com.sk89q.worldedit.world.item;
import com.sk89q.worldedit.registry.NamespacedRegistry;
import com.sk89q.worldedit.world.block.BlockType; import com.sk89q.worldedit.world.block.BlockType;
import com.sk89q.worldedit.world.block.BlockTypes; import com.sk89q.worldedit.world.block.BlockTypes;
import com.sk89q.worldedit.world.registry.BundledItemData; import com.sk89q.worldedit.world.registry.BundledItemData;
@ -28,6 +29,8 @@ import javax.annotation.Nullable;
public class ItemType { public class ItemType {
public static final NamespacedRegistry<ItemType> REGISTRY = new NamespacedRegistry<>();
private String id; private String id;
public ItemType(String id) { public ItemType(String id) {
@ -73,7 +76,7 @@ public class ItemType {
*/ */
@Nullable @Nullable
public BlockType getBlockType() { public BlockType getBlockType() {
return BlockTypes.getBlockType(this.id); return BlockTypes.get(this.id);
} }
/** /**

View File

@ -38,7 +38,7 @@ public class BundledBlockRegistry implements BlockRegistry {
@Nullable @Nullable
@Override @Override
public BlockState createFromId(String id) { public BlockState createFromId(String id) {
return BlockTypes.getBlockType(id).getDefaultState(); return BlockTypes.get(id).getDefaultState();
} }
@Nullable @Nullable

View File

@ -33,6 +33,6 @@ public class BundledItemRegistry implements ItemRegistry {
@Nullable @Nullable
@Override @Override
public BaseItem createFromId(String id) { public BaseItem createFromId(String id) {
return new BaseItem(ItemTypes.getItemType(id)); return new BaseItem(ItemTypes.get(id));
} }
} }

View File

@ -93,7 +93,7 @@ public class LegacyMapper {
for (Map.Entry<String, String> itemEntry : dataFile.items.entrySet()) { for (Map.Entry<String, String> itemEntry : dataFile.items.entrySet()) {
try { try {
itemMap.put(itemEntry.getKey(), ItemTypes.getItemType(itemEntry.getValue())); itemMap.put(itemEntry.getKey(), ItemTypes.get(itemEntry.getValue()));
} catch (Exception e) { } catch (Exception e) {
log.warning("Unknown item: " + itemEntry.getValue()); log.warning("Unknown item: " + itemEntry.getValue());
} }

View File

@ -32,7 +32,7 @@ public class ForgeItemRegistry implements ItemRegistry {
public BaseItem createFromId(String id) { public BaseItem createFromId(String id) {
Item match = Item.REGISTRY.getObject(new ResourceLocation(id)); Item match = Item.REGISTRY.getObject(new ResourceLocation(id));
if (match != null) { if (match != null) {
return new BaseItem(ItemTypes.getItemType(id)); return new BaseItem(ItemTypes.get(id));
} else { } else {
return null; return null;
} }

View File

@ -62,7 +62,7 @@ public class ForgePlayer extends AbstractPlayerActor {
@Override @Override
public BaseItemStack getItemInHand(HandSide handSide) { public BaseItemStack getItemInHand(HandSide handSide) {
ItemStack is = this.player.getHeldItem(handSide == HandSide.MAIN_HAND ? EnumHand.MAIN_HAND : EnumHand.OFF_HAND); ItemStack is = this.player.getHeldItem(handSide == HandSide.MAIN_HAND ? EnumHand.MAIN_HAND : EnumHand.OFF_HAND);
return new BaseItemStack(ItemTypes.getItemType(ForgeRegistries.ITEMS.getKey(is.getItem()).toString())); return new BaseItemStack(ItemTypes.get(ForgeRegistries.ITEMS.getKey(is.getItem()).toString()));
} }
@Override @Override

View File

@ -125,7 +125,7 @@ public class ForgeWorldEdit {
} }
for (Block block : REGISTRY) { for (Block block : REGISTRY) {
BlockTypes.registerBlock(new BlockType(REGISTRY.getNameForObject(block).toString())); BlockTypes.register(new BlockType(REGISTRY.getNameForObject(block).toString()));
} }
} }

View File

@ -66,7 +66,7 @@ public class SpongePlayer extends AbstractPlayerActor {
public BaseItemStack getItemInHand(HandSide handSide) { public BaseItemStack getItemInHand(HandSide handSide) {
Optional<ItemStack> is = this.player.getItemInHand(handSide == HandSide.MAIN_HAND Optional<ItemStack> is = this.player.getItemInHand(handSide == HandSide.MAIN_HAND
? HandTypes.MAIN_HAND : HandTypes.OFF_HAND); ? HandTypes.MAIN_HAND : HandTypes.OFF_HAND);
return is.map(itemStack -> new BaseItemStack(ItemTypes.getItemType(itemStack.getType().getId()))).orElse(null); return is.map(itemStack -> new BaseItemStack(ItemTypes.get(itemStack.getType().getId()))).orElse(null);
} }
@Override @Override

View File

@ -135,11 +135,11 @@ public class SpongeWorldEdit {
for (BlockType blockType : Sponge.getRegistry().getAllOf(BlockType.class)) { for (BlockType blockType : Sponge.getRegistry().getAllOf(BlockType.class)) {
// TODO Handle blockstate stuff // TODO Handle blockstate stuff
com.sk89q.worldedit.world.block.BlockTypes.registerBlock(new com.sk89q.worldedit.world.block.BlockType(blockType.getId())); com.sk89q.worldedit.world.block.BlockTypes.register(new com.sk89q.worldedit.world.block.BlockType(blockType.getId()));
} }
for (ItemType itemType : Sponge.getRegistry().getAllOf(ItemType.class)) { for (ItemType itemType : Sponge.getRegistry().getAllOf(ItemType.class)) {
ItemTypes.registerItem(new com.sk89q.worldedit.world.item.ItemType(itemType.getId())); ItemTypes.register(new com.sk89q.worldedit.world.item.ItemType(itemType.getId()));
} }
WorldEdit.getInstance().getPlatformManager().register(platform); WorldEdit.getInstance().getPlatformManager().register(platform);