Skip to content

Commit

Permalink
24w11a fix, some javadoc (#3819)
Browse files Browse the repository at this point in the history
  • Loading branch information
apple502j authored Mar 17, 2024
1 parent 1fc3291 commit 0c1624a
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 5 deletions.
22 changes: 22 additions & 0 deletions mappings/net/minecraft/component/ComponentHolder.mapping
Original file line number Diff line number Diff line change
@@ -1,9 +1,31 @@
CLASS net/minecraft/class_9322 net/minecraft/component/ComponentHolder
COMMENT An object that holds components. Note that this interface does not expose
COMMENT methods to modify the held components.
COMMENT
COMMENT <p>Component holders usually have "base" components and the overrides to the base
COMMENT (usually referred to as "changes"). The overrides may set additional components,
COMMENT modify the values from the base-provided default, or "unset"/remove base values.
COMMENT Methods in this interface expose the final value, after applying the changes.
COMMENT
COMMENT @see ComponentMap
COMMENT @see ComponentChanges
METHOD method_57353 getComponents ()Lnet/minecraft/class_9323;
METHOD method_57824 get (Lnet/minecraft/class_9331;)Ljava/lang/Object;
COMMENT {@return the value for the component {@code type}, or {@code null} if the
COMMENT component is missing}
COMMENT
COMMENT <p>The returned value should never be mutated.
ARG 1 type
METHOD method_57825 getOrDefault (Lnet/minecraft/class_9331;Ljava/lang/Object;)Ljava/lang/Object;
COMMENT {@return the value for the component {@code type}, or {@code fallback} if the
COMMENT component is missing}
COMMENT
COMMENT <p>This method does not initialize the components with {@code fallback}.
COMMENT The returned value should never be mutated.
ARG 1 type
ARG 2 fallback
METHOD method_57826 contains (Lnet/minecraft/class_9331;)Z
COMMENT {@return whether the held components include {@code type}}
COMMENT
COMMENT @implNote This is implemented as {@code get(type) != null}.
ARG 1 type
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ CLASS net/minecraft/class_9290 net/minecraft/component/type/LoreComponent
FIELD field_49344 STYLE Lnet/minecraft/class_2583;
METHOD <init> (Ljava/util/List;)V
ARG 1 lines
METHOD method_57499 of (Lnet/minecraft/class_2561;)Lnet/minecraft/class_9290;
METHOD method_57499 with (Lnet/minecraft/class_2561;)Lnet/minecraft/class_9290;
ARG 1 line
METHOD method_57500 (Lnet/minecraft/class_2561;)Lnet/minecraft/class_2561;
ARG 0 style
49 changes: 45 additions & 4 deletions mappings/net/minecraft/item/ItemStack.mapping
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,13 @@ CLASS net/minecraft/class_1799 net/minecraft/item/ItemStack
COMMENT is never stored in multiple places. When two inventories hold the same instance, it
COMMENT will duplicate the item stack (and become two instances) when one is saved and reloaded.
COMMENT
COMMENT <h2 id="nbt-operations">NBT operations</h2>
COMMENT <h2 id="components">Components</h2>
COMMENT <p>Components can be used to store data specific to the item stack.
COMMENT Use {@link ComponentHolder#get} or {@link ComponentHolder#getOrDefault} to
COMMENT get the component values. Use {@link #set} or {@link #remove} to set the components.
COMMENT
COMMENT <h3>NBT serialization</h3>
COMMENT
COMMENT An Item Stack can be serialized with {@link #encode(RegistryWrapper.WrapperLookup)}, and deserialized with {@link #fromNbt(RegistryWrapper.WrapperLookup, NbtCompound)}.
COMMENT <h2 id="nbt-serialization">NBT serialization</h2>
COMMENT <p>An Item Stack can be serialized with {@link #encode(RegistryWrapper.WrapperLookup)}, and deserialized with {@link #fromNbt(RegistryWrapper.WrapperLookup, NbtCompound)}.
COMMENT
COMMENT <div class="fabric">
COMMENT <table border=1>
Expand Down Expand Up @@ -234,11 +236,36 @@ CLASS net/minecraft/class_1799 net/minecraft/item/ItemStack
METHOD method_57366 applyChanges (Lnet/minecraft/class_9326;)V
ARG 1 changes
METHOD method_57367 apply (Lnet/minecraft/class_9331;Ljava/lang/Object;Ljava/lang/Object;Ljava/util/function/BiFunction;)Ljava/lang/Object;
COMMENT Sets the component {@code type} by passing the current value and {@code change}
COMMENT to {@code applier}, then setting its return value as the value. If the component is
COMMENT missing, {@code defaultValue} is used as the default.
COMMENT
COMMENT <p>In practice, {@code applier} is a reference to a method of the component
COMMENT class with one parameter, that returns a new instance of the component with the
COMMENT specific value changed to {@code change}. For example, adding a lore can be accomplished
COMMENT by passing reference to {@link net.minecraft.component.type.LoreComponent#with}
COMMENT and the added lore, like
COMMENT {@code stack.apply(DataComponentTypes.LORE, LoreComponent.DEFAULT, text, LoreComponent::with)}.
COMMENT
COMMENT @implNote This is the same as setting {@code applier.apply(stack.getOrDefault(type, defaultValue), change)}.
COMMENT
COMMENT @return the previous value set
COMMENT @see #apply(DataComponentType, Object, UnaryOperator)
COMMENT @see #set
ARG 1 type
ARG 2 defaultValue
ARG 3 change
ARG 4 applier
METHOD method_57368 apply (Lnet/minecraft/class_9331;Ljava/lang/Object;Ljava/util/function/UnaryOperator;)Ljava/lang/Object;
COMMENT Sets the component {@code type} by passing the current value (or {@code defaultValue}
COMMENT if the component is missing) to {@code applier} and then setting its return value as
COMMENT the value.
COMMENT
COMMENT @implNote This is the same as setting {@code applier.apply(stack.getOrDefault(type, defaultValue))}.
COMMENT
COMMENT @return the previous value set
COMMENT @see #set
COMMENT @see #apply(DataComponentType, Object, Object, BiFunction)
ARG 1 type
ARG 2 defaultValue
ARG 3 applier
Expand Down Expand Up @@ -267,10 +294,24 @@ CLASS net/minecraft/class_1799 net/minecraft/item/ItemStack
METHOD method_57378 (Ljava/util/Optional;)Lnet/minecraft/class_1799;
ARG 0 optional
METHOD method_57379 set (Lnet/minecraft/class_9331;Ljava/lang/Object;)Ljava/lang/Object;
COMMENT Sets the component {@code type} for this item stack to {@code value}.
COMMENT
COMMENT <p>If {@code value} is {@code null}, the component is removed and the base component
COMMENT is unset. To reverse the stack-specific change, instead pass the default value
COMMENT as {@code value}.
COMMENT
COMMENT @return the previous value set
COMMENT @see #apply(DataComponentType, Object, UnaryOperator)
COMMENT @see #apply(DataComponentType, Object, Object, BiFunction)
ARG 1 type
ARG 2 value
METHOD method_57380 getComponentChanges ()Lnet/minecraft/class_9326;
METHOD method_57381 remove (Lnet/minecraft/class_9331;)Ljava/lang/Object;
COMMENT Removes the component {@code type}. If it is in the stack's base component,
COMMENT it is unset and the component becomes missing. To reverse the stack-specific change,
COMMENT instead pass the default value as {@code value}.
COMMENT
COMMENT @return the previous value set
ARG 1 type
METHOD method_57382 (Lnet/minecraft/class_1799;)Ljava/util/Optional;
ARG 0 stack
Expand Down

0 comments on commit 0c1624a

Please sign in to comment.