Skip to content

Commit

Permalink
Add some code comments, update BungeeCord version check
Browse files Browse the repository at this point in the history
  • Loading branch information
onebeastchris committed Dec 10, 2024
1 parent 8779eab commit 94d77b4
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ public void onGeyserInitialize() {
// Copied from ViaVersion.
// https://github.com/ViaVersion/ViaVersion/blob/b8072aad86695cc8ec6f5e4103e43baf3abf6cc5/bungee/src/main/java/us/myles/ViaVersion/BungeePlugin.java#L43
try {
ProtocolConstants.class.getField("MINECRAFT_1_21");
ProtocolConstants.class.getField("MINECRAFT_1_21_4");
} catch (NoSuchFieldException e) {
geyserLogger.error(" / \\");
geyserLogger.error(" / \\");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,7 @@ protected Tag<Item> getFoodTag() {
public void setBody(ItemStack stack) {
super.setBody(stack);
isCurseOfBinding = ItemUtils.hasEffect(session, stack, EnchantmentComponent.PREVENT_ARMOR_CHANGE);
// Not using ItemStack#getDataComponents as that wouldn't include default item components
repairableItems = GeyserItemStack.from(stack).getComponent(DataComponentType.REPAIRABLE);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,10 @@ public int getAmount() {
return isEmpty() ? null : components;
}

/**
* @return whether this GeyserItemStack has any additional components on top of
* the base item components.
*/
public boolean hasNonBaseComponents() {
return components != null;
}
Expand All @@ -137,6 +141,15 @@ public DataComponents getOrCreateComponents() {
return components;
}

/**
* Returns the stored data component for a given {@link DataComponentType}, or null.
* <p>
* This method will first check the additional components that may exist,
* and fallback to the item's default (or, "base") components if need be.
* @param type the {@link DataComponentType} to query
* @return the value for said type, or null.
* @param <T> the value's type
*/
@Nullable
public <T> T getComponent(@NonNull DataComponentType<T> type) {
if (components == null) {
Expand Down
18 changes: 15 additions & 3 deletions core/src/main/java/org/geysermc/geyser/item/type/Item.java
Original file line number Diff line number Diff line change
Expand Up @@ -100,21 +100,33 @@ public Rarity defaultRarity() {
}

/**
* Returns a modifiable DataComponents map. Should only be used when it must be modified.
* Otherwise, prefer using GeyserItemStack's getComponent
* Returns an unmodifiable {@link DataComponents} view containing known data components.
* Optionally, additional components can be provided to replace (or add to)
* the items' base components.
* To add data components, use {@link GeyserItemStack#getOrCreateComponents()}.
*/
@NonNull
@UnmodifiableView
public DataComponents gatherComponents(DataComponents others) {
public DataComponents gatherComponents(@Nullable DataComponents others) {
if (others == null) {
return baseComponents;
}

// Start with the base components that always exist
DataComponents components = baseComponents.clone();
// Add all additional components; these can override base components!
// e.g. custom stack size
components.getDataComponents().putAll(others.getDataComponents());

// Return an unmodified map of the merged components
return new DataComponents(ImmutableMap.copyOf(components.getDataComponents()));
}

/**
* Returns this items value (or null) for a specific {@link DataComponentType}.
* Prefer using {@link GeyserItemStack#getComponent(DataComponentType)}
* to also query additional components that would override the default ones.
*/
@Nullable
public <T> T getComponent(@NonNull DataComponentType<T> type) {
return baseComponents.get(type);
Expand Down

0 comments on commit 94d77b4

Please sign in to comment.