mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-07 00:48:28 +01:00
Do not copy collections unless necessary
This commit is contained in:
parent
322572c96d
commit
0db44545cd
@ -13,7 +13,10 @@ import org.jetbrains.annotations.Nullable;
|
|||||||
import org.jglrxavpok.hephaistos.nbt.NBTCompound;
|
import org.jglrxavpok.hephaistos.nbt.NBTCompound;
|
||||||
|
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.util.*;
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
public class ItemMeta implements TagReadable, Writeable {
|
public class ItemMeta implements TagReadable, Writeable {
|
||||||
@ -43,12 +46,12 @@ public class ItemMeta implements TagReadable, Writeable {
|
|||||||
this.unbreakable = metaBuilder.unbreakable;
|
this.unbreakable = metaBuilder.unbreakable;
|
||||||
this.hideFlag = metaBuilder.hideFlag;
|
this.hideFlag = metaBuilder.hideFlag;
|
||||||
this.displayName = metaBuilder.displayName;
|
this.displayName = metaBuilder.displayName;
|
||||||
this.lore = new ArrayList<>(metaBuilder.lore);
|
this.lore = List.copyOf(metaBuilder.lore);
|
||||||
this.enchantmentMap = new HashMap<>(metaBuilder.enchantmentMap);
|
this.enchantmentMap = Map.copyOf(metaBuilder.enchantmentMap);
|
||||||
this.attributes = new ArrayList<>(metaBuilder.attributes);
|
this.attributes = List.copyOf(metaBuilder.attributes);
|
||||||
this.customModelData = metaBuilder.customModelData;
|
this.customModelData = metaBuilder.customModelData;
|
||||||
this.canDestroy = new HashSet<>(metaBuilder.canDestroy);
|
this.canDestroy = Set.copyOf(metaBuilder.canDestroy);
|
||||||
this.canPlaceOn = new HashSet<>(metaBuilder.canPlaceOn);
|
this.canPlaceOn = Set.copyOf(metaBuilder.canPlaceOn);
|
||||||
|
|
||||||
this.metaBuilder = metaBuilder;
|
this.metaBuilder = metaBuilder;
|
||||||
this.nbt = metaBuilder.nbt();
|
this.nbt = metaBuilder.nbt();
|
||||||
|
@ -83,7 +83,7 @@ public abstract class ItemMetaBuilder implements TagWritable {
|
|||||||
|
|
||||||
@Contract("_ -> this")
|
@Contract("_ -> this")
|
||||||
public @NotNull ItemMetaBuilder lore(@NotNull List<@NotNull Component> lore) {
|
public @NotNull ItemMetaBuilder lore(@NotNull List<@NotNull Component> lore) {
|
||||||
this.lore = new ArrayList<>(lore);
|
this.lore = List.copyOf(lore);
|
||||||
handleCompound("display", nbtCompound -> {
|
handleCompound("display", nbtCompound -> {
|
||||||
final NBTList<NBTString> loreNBT = new NBTList<>(NBTTypes.TAG_String);
|
final NBTList<NBTString> loreNBT = new NBTList<>(NBTTypes.TAG_String);
|
||||||
for (Component line : lore) {
|
for (Component line : lore) {
|
||||||
@ -102,7 +102,7 @@ public abstract class ItemMetaBuilder implements TagWritable {
|
|||||||
|
|
||||||
@Contract("_ -> this")
|
@Contract("_ -> this")
|
||||||
public @NotNull ItemMetaBuilder enchantments(@NotNull Map<Enchantment, Short> enchantments) {
|
public @NotNull ItemMetaBuilder enchantments(@NotNull Map<Enchantment, Short> enchantments) {
|
||||||
this.enchantmentMap = new HashMap<>(enchantments);
|
this.enchantmentMap = Map.copyOf(enchantments);
|
||||||
handleMap(enchantmentMap, "Enchantments", () -> {
|
handleMap(enchantmentMap, "Enchantments", () -> {
|
||||||
NBTUtils.writeEnchant(nbt, "Enchantments", enchantmentMap);
|
NBTUtils.writeEnchant(nbt, "Enchantments", enchantmentMap);
|
||||||
return nbt.get("Enchantments");
|
return nbt.get("Enchantments");
|
||||||
@ -126,7 +126,7 @@ public abstract class ItemMetaBuilder implements TagWritable {
|
|||||||
|
|
||||||
@Contract("_ -> this")
|
@Contract("_ -> this")
|
||||||
public @NotNull ItemMetaBuilder attributes(@NotNull List<@NotNull ItemAttribute> attributes) {
|
public @NotNull ItemMetaBuilder attributes(@NotNull List<@NotNull ItemAttribute> attributes) {
|
||||||
this.attributes = new ArrayList<>(attributes);
|
this.attributes = List.copyOf(attributes);
|
||||||
|
|
||||||
handleCollection(attributes, "AttributeModifiers", () -> {
|
handleCollection(attributes, "AttributeModifiers", () -> {
|
||||||
NBTList<NBTCompound> attributesNBT = new NBTList<>(NBTTypes.TAG_Compound);
|
NBTList<NBTCompound> attributesNBT = new NBTList<>(NBTTypes.TAG_Compound);
|
||||||
@ -157,7 +157,7 @@ public abstract class ItemMetaBuilder implements TagWritable {
|
|||||||
|
|
||||||
@Contract("_ -> this")
|
@Contract("_ -> this")
|
||||||
public @NotNull ItemMetaBuilder canPlaceOn(@NotNull Set<@NotNull Block> blocks) {
|
public @NotNull ItemMetaBuilder canPlaceOn(@NotNull Set<@NotNull Block> blocks) {
|
||||||
this.canPlaceOn = new HashSet<>(blocks);
|
this.canPlaceOn = Set.copyOf(blocks);
|
||||||
handleCollection(canPlaceOn, "CanPlaceOn", () -> {
|
handleCollection(canPlaceOn, "CanPlaceOn", () -> {
|
||||||
NBTList<NBTString> list = new NBTList<>(NBTTypes.TAG_String);
|
NBTList<NBTString> list = new NBTList<>(NBTTypes.TAG_String);
|
||||||
canPlaceOn.forEach(block -> list.add(new NBTString(block.name())));
|
canPlaceOn.forEach(block -> list.add(new NBTString(block.name())));
|
||||||
@ -173,7 +173,7 @@ public abstract class ItemMetaBuilder implements TagWritable {
|
|||||||
|
|
||||||
@Contract("_ -> this")
|
@Contract("_ -> this")
|
||||||
public @NotNull ItemMetaBuilder canDestroy(@NotNull Set<@NotNull Block> blocks) {
|
public @NotNull ItemMetaBuilder canDestroy(@NotNull Set<@NotNull Block> blocks) {
|
||||||
this.canDestroy = new HashSet<>(blocks);
|
this.canDestroy = Set.copyOf(blocks);
|
||||||
handleCollection(canDestroy, "CanDestroy", () -> {
|
handleCollection(canDestroy, "CanDestroy", () -> {
|
||||||
NBTList<NBTString> list = new NBTList<>(NBTTypes.TAG_String);
|
NBTList<NBTString> list = new NBTList<>(NBTTypes.TAG_String);
|
||||||
canDestroy.forEach(block -> list.add(new NBTString(block.name())));
|
canDestroy.forEach(block -> list.add(new NBTString(block.name())));
|
||||||
|
Loading…
Reference in New Issue
Block a user