Merge remote-tracking branch 'origin/master'

This commit is contained in:
themode 2020-10-03 03:45:22 +02:00
commit f85e7ca4a9
11 changed files with 589 additions and 240 deletions

View File

@ -5,17 +5,18 @@ import net.minestom.server.network.packet.server.ServerPacket;
import net.minestom.server.network.packet.server.ServerPacketIdentifier;
import net.minestom.server.utils.binary.BinaryWriter;
import net.minestom.server.utils.validate.Check;
import org.jetbrains.annotations.NotNull;
public class DeclareRecipesPacket implements ServerPacket {
public Recipe[] recipes;
public DeclaredRecipe[] recipes;
@Override
public void write(BinaryWriter writer) {
Check.notNull(recipes, "Recipes cannot be null!");
writer.writeVarInt(recipes.length);
for (Recipe recipe : recipes) {
for (DeclaredRecipe recipe : recipes) {
recipe.write(writer);
}
}
@ -25,91 +26,287 @@ public class DeclareRecipesPacket implements ServerPacket {
return ServerPacketIdentifier.DECLARE_RECIPES;
}
public static class Recipe {
public abstract static class DeclaredRecipe {
protected final String recipeId;
protected final String recipeType;
public String recipeId;
public String recipeType;
protected DeclaredRecipe(@NotNull String recipeId, @NotNull String recipeType) {
this.recipeId = recipeId;
this.recipeType = recipeType;
}
public String group;
// crafting_shapeless
// ++ group
// ++ ingredients
// ++ result
// crafting_shaped
public int width;
public int height;
// ++ group
// ++ ingredients
// ++ result
// smelting, blasting, smoking and campfire
// ++ group
// ++ ingredient
// ++ result
public float experience;
public int cookingTime;
// smithing
// ++ ingredient (base)
public Ingredient additionIngredient;
// ++ result
public Ingredient ingredient;
public Ingredient[] ingredients;
public ItemStack result;
private void write(BinaryWriter writer) {
public void write(@NotNull BinaryWriter writer) {
writer.writeSizedString(recipeType);
writer.writeSizedString(recipeId);
}
}
switch (recipeType) {
case "crafting_shapeless": {
writer.writeSizedString(group);
writer.writeVarInt(ingredients.length);
for (Ingredient ingredient : ingredients) {
ingredient.write(writer);
}
writer.writeItemStack(result);
break;
}
case "crafting_shaped": {
writer.writeVarInt(width);
writer.writeVarInt(height);
writer.writeSizedString(group);
for (Ingredient ingredient : ingredients) {
ingredient.write(writer);
}
writer.writeItemStack(result);
break;
}
case "smelting":
case "blasting":
case "smoking":
case "campfire_cooking": {
writer.writeSizedString(group);
ingredient.write(writer);
writer.writeItemStack(result);
writer.writeFloat(experience);
writer.writeVarInt(cookingTime);
break;
}
case "stonecutting": {
writer.writeSizedString(group);
ingredient.write(writer);
writer.writeItemStack(result);
break;
}
case "smithing": {
ingredient.write(writer);
additionIngredient.write(writer);
writer.writeItemStack(result);
break;
}
public static class DeclaredShapelessCraftingRecipe extends DeclaredRecipe {
private final String group;
private final Ingredient[] ingredients;
private final ItemStack result;
public DeclaredShapelessCraftingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull Ingredient[] ingredients,
@NotNull ItemStack result
) {
super(recipeId, "crafting_shapeless");
this.group = group;
this.ingredients = ingredients;
this.result = result;
}
@Override
public void write(@NotNull BinaryWriter writer) {
// Write type & id
super.write(writer);
// Write recipe specific stuff.
writer.writeSizedString(group);
writer.writeVarInt(ingredients.length);
for (Ingredient ingredient : ingredients) {
ingredient.write(writer);
}
writer.writeItemStack(result);
}
}
public static class DeclaredShapedCraftingRecipe extends DeclaredRecipe {
public final int width;
public final int height;
private final String group;
private final Ingredient[] ingredients;
private final ItemStack result;
public DeclaredShapedCraftingRecipe(
@NotNull String recipeId,
int width,
int height,
@NotNull String group,
@NotNull Ingredient[] ingredients,
@NotNull ItemStack result
) {
super(recipeId, "crafting_shaped");
this.group = group;
this.ingredients = ingredients;
this.result = result;
this.width = width;
this.height = height;
}
@Override
public void write(@NotNull BinaryWriter writer) {
// Write type & id
super.write(writer);
// Write recipe specific stuff.
writer.writeVarInt(width);
writer.writeVarInt(height);
writer.writeSizedString(group);
for (Ingredient ingredient : ingredients) {
ingredient.write(writer);
}
writer.writeItemStack(result);
}
}
public static class DeclaredSmeltingRecipe extends DeclaredRecipe {
private final String group;
private final Ingredient ingredient;
private final ItemStack result;
private final float experience;
private final int cookingTime;
public DeclaredSmeltingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull Ingredient ingredient,
@NotNull ItemStack result,
float experience,
int cookingTime
) {
super(recipeId, "smelting");
this.group = group;
this.ingredient = ingredient;
this.result = result;
this.experience = experience;
this.cookingTime = cookingTime;
}
@Override
public void write(@NotNull BinaryWriter writer) {
// Write type & id
super.write(writer);
// Write recipe specific stuff.
writer.writeSizedString(group);
ingredient.write(writer);
writer.writeItemStack(result);
writer.writeFloat(experience);
writer.writeVarInt(cookingTime);
}
}
public static class DeclaredBlastingRecipe extends DeclaredRecipe {
private final String group;
private final Ingredient ingredient;
private final ItemStack result;
private final float experience;
private final int cookingTime;
public DeclaredBlastingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull Ingredient ingredient,
@NotNull ItemStack result,
float experience,
int cookingTime
) {
super(recipeId, "blasting");
this.group = group;
this.ingredient = ingredient;
this.result = result;
this.experience = experience;
this.cookingTime = cookingTime;
}
@Override
public void write(@NotNull BinaryWriter writer) {
// Write type & id
super.write(writer);
// Write recipe specific stuff.
writer.writeSizedString(group);
ingredient.write(writer);
writer.writeItemStack(result);
writer.writeFloat(experience);
writer.writeVarInt(cookingTime);
}
}
public static class DeclaredSmokingRecipe extends DeclaredRecipe {
private final String group;
private final Ingredient ingredient;
private final ItemStack result;
private final float experience;
private final int cookingTime;
public DeclaredSmokingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull Ingredient ingredient,
@NotNull ItemStack result,
float experience,
int cookingTime
) {
super(recipeId, "smoking");
this.group = group;
this.ingredient = ingredient;
this.result = result;
this.experience = experience;
this.cookingTime = cookingTime;
}
@Override
public void write(@NotNull BinaryWriter writer) {
// Write type & id
super.write(writer);
// Write recipe specific stuff.
writer.writeSizedString(group);
ingredient.write(writer);
writer.writeItemStack(result);
writer.writeFloat(experience);
writer.writeVarInt(cookingTime);
}
}
public static class DeclaredCampfireCookingRecipe extends DeclaredRecipe {
private final String group;
private final Ingredient ingredient;
private final ItemStack result;
private final float experience;
private final int cookingTime;
public DeclaredCampfireCookingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull Ingredient ingredient,
@NotNull ItemStack result,
float experience,
int cookingTime
) {
super(recipeId, "campfire_cooking");
this.group = group;
this.ingredient = ingredient;
this.result = result;
this.experience = experience;
this.cookingTime = cookingTime;
}
@Override
public void write(@NotNull BinaryWriter writer) {
// Write type & id
super.write(writer);
// Write recipe specific stuff.
writer.writeSizedString(group);
ingredient.write(writer);
writer.writeItemStack(result);
writer.writeFloat(experience);
writer.writeVarInt(cookingTime);
}
}
public static class DeclaredStonecutterRecipe extends DeclaredRecipe {
private final String group;
private final Ingredient ingredient;
private final ItemStack result;
public DeclaredStonecutterRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull Ingredient ingredient,
@NotNull ItemStack result
) {
super(recipeId, "stonecutter");
this.group = group;
this.ingredient = ingredient;
this.result = result;
}
@Override
public void write(@NotNull BinaryWriter writer) {
// Write type & id
super.write(writer);
// Write recipe specific stuff.
writer.writeSizedString(group);
ingredient.write(writer);
writer.writeItemStack(result);
}
}
public final static class DeclaredSmithingRecipe extends DeclaredRecipe {
private final Ingredient base;
private final Ingredient addition;
private final ItemStack result;
public DeclaredSmithingRecipe(
@NotNull String recipeId,
@NotNull Ingredient base,
@NotNull Ingredient addition,
@NotNull ItemStack result
) {
super(recipeId, "smithing");
this.base = base;
this.addition = addition;
this.result = result;
}
@Override
public void write(@NotNull BinaryWriter writer) {
// Write type & id
super.write(writer);
// Write recipe specific stuff.
base.write(writer);
addition.write(writer);
writer.writeItemStack(result);
}
}

View File

@ -2,35 +2,53 @@ package net.minestom.server.recipe;
import net.minestom.server.item.ItemStack;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
public abstract class BlastingRecipe extends Recipe {
private String group;
private DeclareRecipesPacket.Ingredient ingredient;
private ItemStack result = ItemStack.getAirItem();
private ItemStack result;
private float experience;
private int cookingTime;
public BlastingRecipe(String recipeId, String group) {
super(RecipeType.SMELTING, recipeId);
setGroup(group);
protected BlastingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull ItemStack result,
float experience,
int cookingTime
) {
super(RecipeType.BLASTING, recipeId);
this.group = group;
this.result = result;
this.experience = experience;
this.cookingTime = cookingTime;
}
@NotNull
public String getGroup() {
return group;
}
public void setGroup(@NotNull String group) {
this.group = group;
}
@NotNull
public DeclareRecipesPacket.Ingredient getIngredient() {
return ingredient;
}
public void setIngredient(DeclareRecipesPacket.Ingredient ingredient) {
public void setIngredient(@NotNull DeclareRecipesPacket.Ingredient ingredient) {
this.ingredient = ingredient;
}
@NotNull
public ItemStack getResult() {
return result;
}
public void setResult(ItemStack result) {
public void setResult(@NotNull ItemStack result) {
this.result = result;
}

View File

@ -2,35 +2,53 @@ package net.minestom.server.recipe;
import net.minestom.server.item.ItemStack;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
public abstract class CampfireCookingRecipe extends Recipe {
private String group;
private DeclareRecipesPacket.Ingredient ingredient;
private ItemStack result = ItemStack.getAirItem();
private ItemStack result;
private float experience;
private int cookingTime;
public CampfireCookingRecipe(String recipeId, String group) {
super(RecipeType.SMELTING, recipeId);
setGroup(group);
protected CampfireCookingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull ItemStack result,
float experience,
int cookingTime
) {
super(RecipeType.CAMPFIRE_COOKING, recipeId);
this.group = group;
this.result = result;
this.experience = experience;
this.cookingTime = cookingTime;
}
@NotNull
public String getGroup() {
return group;
}
public void setGroup(@NotNull String group) {
this.group = group;
}
@NotNull
public DeclareRecipesPacket.Ingredient getIngredient() {
return ingredient;
}
public void setIngredient(DeclareRecipesPacket.Ingredient ingredient) {
public void setIngredient(@NotNull DeclareRecipesPacket.Ingredient ingredient) {
this.ingredient = ingredient;
}
@NotNull
public ItemStack getResult() {
return result;
}
public void setResult(ItemStack result) {
public void setResult(@NotNull ItemStack result) {
this.result = result;
}

View File

@ -1,32 +1,25 @@
package net.minestom.server.recipe;
import net.minestom.server.entity.Player;
import org.jetbrains.annotations.NotNull;
public abstract class Recipe {
protected final RecipeType recipeType;
protected final String recipeId;
protected RecipeType recipeType;
protected String recipeId;
protected String group;
protected Recipe(RecipeType recipeType, String recipeId) {
protected Recipe(@NotNull RecipeType recipeType, @NotNull String recipeId) {
this.recipeType = recipeType;
this.recipeId = recipeId;
}
public abstract boolean shouldShow(Player player);
public String getGroup() {
return group;
}
public void setGroup(String group) {
this.group = group;
}
public abstract boolean shouldShow(@NotNull Player player);
@NotNull
public RecipeType getRecipeType() {
return recipeType;
}
@NotNull
public String getRecipeId() {
return recipeId;
}

View File

@ -1,6 +1,7 @@
package net.minestom.server.recipe;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
import java.util.ArrayList;
import java.util.List;
@ -8,12 +9,10 @@ import java.util.Set;
import java.util.concurrent.CopyOnWriteArraySet;
public class RecipeManager {
private final DeclareRecipesPacket declareRecipesPacket = new DeclareRecipesPacket();
private final Set<Recipe> recipes = new CopyOnWriteArraySet<>();
private Set<Recipe> recipes = new CopyOnWriteArraySet<>();
private DeclareRecipesPacket declareRecipesPacket = new DeclareRecipesPacket();
public void addRecipe(Recipe recipe) {
public void addRecipe(@NotNull Recipe recipe) {
if (this.recipes.add(recipe)) {
// TODO add to all players
@ -21,7 +20,7 @@ public class RecipeManager {
}
}
public void removeRecipe(Recipe recipe) {
public void removeRecipe(@NotNull Recipe recipe) {
if (this.recipes.remove(recipe)) {
// TODO remove to all players
@ -29,118 +28,130 @@ public class RecipeManager {
}
}
@NotNull
public Set<Recipe> getRecipes() {
return recipes;
}
@NotNull
public DeclareRecipesPacket getDeclareRecipesPacket() {
return declareRecipesPacket;
}
private void refreshRecipesPacket() {
List<DeclareRecipesPacket.Recipe> recipesCache = new ArrayList<>();
List<DeclareRecipesPacket.DeclaredRecipe> recipesCache = new ArrayList<>();
for (Recipe recipe : recipes) {
DeclareRecipesPacket.Recipe packetRecipe = new DeclareRecipesPacket.Recipe();
switch (recipe.recipeType) {
case SHAPELESS: {
packetRecipe.recipeType = "crafting_shapeless";
packetRecipe.group = recipe.getGroup();
ShapelessRecipe shapelessRecipe = (ShapelessRecipe) recipe;
List<DeclareRecipesPacket.Ingredient> ingredients = shapelessRecipe.getIngredients();
packetRecipe.ingredients = ingredients.toArray(new DeclareRecipesPacket.Ingredient[0]);
packetRecipe.result = shapelessRecipe.getResult();
recipesCache.add(
new DeclareRecipesPacket.DeclaredShapelessCraftingRecipe(
shapelessRecipe.getRecipeId(),
shapelessRecipe.getGroup(),
shapelessRecipe.getIngredients().toArray(new DeclareRecipesPacket.Ingredient[0]),
shapelessRecipe.getResult()
)
);
break;
}
case SHAPED: {
packetRecipe.recipeType = "crafting_shaped";
packetRecipe.group = recipe.getGroup();
ShapedRecipe shapedRecipe = (ShapedRecipe) recipe;
List<DeclareRecipesPacket.Ingredient> ingredients2 = shapedRecipe.getIngredients();
packetRecipe.ingredients = ingredients2.toArray(new DeclareRecipesPacket.Ingredient[0]);
packetRecipe.result = shapedRecipe.getResult();
recipesCache.add(
new DeclareRecipesPacket.DeclaredShapedCraftingRecipe(
shapedRecipe.getRecipeId(),
shapedRecipe.getWidth(),
shapedRecipe.getHeight(),
shapedRecipe.getGroup(),
shapedRecipe.getIngredients().toArray(new DeclareRecipesPacket.Ingredient[0]),
shapedRecipe.getResult()
)
);
break;
}
case SMELTING: {
packetRecipe.recipeType = "smelting";
packetRecipe.group = recipe.getGroup();
SmeltingRecipe smeltingRecipe = (SmeltingRecipe) recipe;
packetRecipe.ingredient = smeltingRecipe.getIngredient();
packetRecipe.result = smeltingRecipe.getResult();
packetRecipe.experience = smeltingRecipe.getExperience();
packetRecipe.cookingTime = smeltingRecipe.getCookingTime();
recipesCache.add(
new DeclareRecipesPacket.DeclaredSmeltingRecipe(
smeltingRecipe.getRecipeId(),
smeltingRecipe.getGroup(),
smeltingRecipe.getIngredient(),
smeltingRecipe.getResult(),
smeltingRecipe.getExperience(),
smeltingRecipe.getCookingTime()
)
);
break;
}
case BLASTING: {
packetRecipe.recipeType = "blasting";
packetRecipe.group = recipe.getGroup();
BlastingRecipe blastingRecipe = (BlastingRecipe) recipe;
packetRecipe.ingredient = blastingRecipe.getIngredient();
packetRecipe.result = blastingRecipe.getResult();
packetRecipe.experience = blastingRecipe.getExperience();
packetRecipe.cookingTime = blastingRecipe.getCookingTime();
recipesCache.add(
new DeclareRecipesPacket.DeclaredBlastingRecipe(
blastingRecipe.getRecipeId(),
blastingRecipe.getGroup(),
blastingRecipe.getIngredient(),
blastingRecipe.getResult(),
blastingRecipe.getExperience(),
blastingRecipe.getCookingTime()
)
);
break;
}
case SMOKING: {
packetRecipe.recipeType = "smoking";
packetRecipe.group = recipe.getGroup();
SmokingRecipe smokingRecipe = (SmokingRecipe) recipe;
packetRecipe.ingredient = smokingRecipe.getIngredient();
packetRecipe.result = smokingRecipe.getResult();
packetRecipe.experience = smokingRecipe.getExperience();
packetRecipe.cookingTime = smokingRecipe.getCookingTime();
recipesCache.add(
new DeclareRecipesPacket.DeclaredSmokingRecipe(
smokingRecipe.getRecipeId(),
smokingRecipe.getGroup(),
smokingRecipe.getIngredient(),
smokingRecipe.getResult(),
smokingRecipe.getExperience(),
smokingRecipe.getCookingTime()
)
);
break;
}
case CAMPFIRE_COOKING: {
packetRecipe.recipeType = "campfire_cooking";
packetRecipe.group = recipe.getGroup();
CampfireCookingRecipe campfireCookingRecipe = (CampfireCookingRecipe) recipe;
packetRecipe.ingredient = campfireCookingRecipe.getIngredient();
packetRecipe.result = campfireCookingRecipe.getResult();
packetRecipe.experience = campfireCookingRecipe.getExperience();
packetRecipe.cookingTime = campfireCookingRecipe.getCookingTime();
recipesCache.add(
new DeclareRecipesPacket.DeclaredCampfireCookingRecipe(
campfireCookingRecipe.getRecipeId(),
campfireCookingRecipe.getGroup(),
campfireCookingRecipe.getIngredient(),
campfireCookingRecipe.getResult(),
campfireCookingRecipe.getExperience(),
campfireCookingRecipe.getCookingTime()
)
);
break;
}
case STONECUTTING: {
packetRecipe.recipeType = "stonecutting";
packetRecipe.group = recipe.getGroup();
StonecutterRecipe stonecuttingRecipe = (StonecutterRecipe) recipe;
packetRecipe.ingredient = stonecuttingRecipe.getIngredient();
packetRecipe.result = stonecuttingRecipe.getResult();
recipesCache.add(
new DeclareRecipesPacket.DeclaredStonecutterRecipe(
stonecuttingRecipe.getRecipeId(),
stonecuttingRecipe.getGroup(),
stonecuttingRecipe.getIngredient(),
stonecuttingRecipe.getResult()
)
);
break;
}
case SMITHING: {
packetRecipe.recipeType = "smithing";
SmithingRecipe smithingRecipe = (SmithingRecipe) recipe;
packetRecipe.ingredient = smithingRecipe.getBaseIngredient();
packetRecipe.additionIngredient = smithingRecipe.getAdditionIngredient();
packetRecipe.result = smithingRecipe.getResult();
recipesCache.add(
new DeclareRecipesPacket.DeclaredSmithingRecipe(
smithingRecipe.getRecipeId(),
smithingRecipe.getBaseIngredient(),
smithingRecipe.getAdditionIngredient(),
smithingRecipe.getResult()
)
);
break;
}
}
packetRecipe.recipeId = recipe.recipeId;
recipesCache.add(packetRecipe);
}
declareRecipesPacket.recipes = recipesCache.toArray(new DeclareRecipesPacket.Recipe[0]);
declareRecipesPacket.recipes = recipesCache.toArray(new DeclareRecipesPacket.DeclaredRecipe[0]);
}
}

View File

@ -2,41 +2,70 @@ package net.minestom.server.recipe;
import net.minestom.server.item.ItemStack;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.Objects;
public abstract class ShapedRecipe extends Recipe {
private final int width;
private final int height;
private String group;
private final List<DeclareRecipesPacket.Ingredient> ingredients;
private ItemStack result;
private int width, height;
private List<DeclareRecipesPacket.Ingredient> ingredients = new ArrayList<>();
private ItemStack result = ItemStack.getAirItem();
public ShapedRecipe(String recipeId, String group, int width, int height) {
protected ShapedRecipe(@NotNull String recipeId,
int width,
int height,
@NotNull String group,
@Nullable List<DeclareRecipesPacket.Ingredient> ingredients,
@NotNull ItemStack result) {
super(RecipeType.SHAPED, recipeId);
setGroup(group);
this.width = width;
this.height = height;
this.group = group;
this.ingredients = Objects.requireNonNullElseGet(ingredients, LinkedList::new);
this.result = result;
}
public int getWidth() {
return width;
}
public int getHeight() {
return height;
}
@NotNull
public String getGroup() {
return group;
}
public void setGroup(@NotNull String group) {
this.group = group;
}
public void addIngredient(DeclareRecipesPacket.Ingredient ingredient) {
if (ingredients.size() + 1 > width * height)
if (ingredients.size() + 1 > width * height) {
throw new IndexOutOfBoundsException("You cannot add more ingredients than width*height");
}
ingredients.add(ingredient);
}
@NotNull
public List<DeclareRecipesPacket.Ingredient> getIngredients() {
return ingredients;
}
@NotNull
public ItemStack getResult() {
return result;
}
public void setResult(ItemStack result) {
public void setResult(@NotNull ItemStack result) {
this.result = result;
}
}

View File

@ -2,34 +2,54 @@ package net.minestom.server.recipe;
import net.minestom.server.item.ItemStack;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.Objects;
public abstract class ShapelessRecipe extends Recipe {
private String group;
private final List<DeclareRecipesPacket.Ingredient> ingredients;
private ItemStack result;
private List<DeclareRecipesPacket.Ingredient> ingredients = new ArrayList<>();
private ItemStack result = ItemStack.getAirItem();
public ShapelessRecipe(String recipeId, String group) {
protected ShapelessRecipe(
@NotNull String recipeId,
@NotNull String group,
@Nullable List<DeclareRecipesPacket.Ingredient> ingredients,
@NotNull ItemStack result
) {
super(RecipeType.SHAPELESS, recipeId);
setGroup(group);
this.group = group;
this.ingredients = Objects.requireNonNullElseGet(ingredients, LinkedList::new);
this.result = result;
}
@NotNull
public String getGroup() {
return group;
}
public void setGroup(@NotNull String group) {
this.group = group;
}
public void addIngredient(DeclareRecipesPacket.Ingredient ingredient) {
ingredients.add(ingredient);
}
@NotNull
public List<DeclareRecipesPacket.Ingredient> getIngredients() {
return ingredients;
}
@NotNull
public ItemStack getResult() {
return result;
}
public void setResult(ItemStack result) {
public void setResult(@NotNull ItemStack result) {
this.result = result;
}
}

View File

@ -2,35 +2,53 @@ package net.minestom.server.recipe;
import net.minestom.server.item.ItemStack;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
public abstract class SmeltingRecipe extends Recipe {
private String group;
private DeclareRecipesPacket.Ingredient ingredient;
private ItemStack result = ItemStack.getAirItem();
private ItemStack result;
private float experience;
private int cookingTime;
public SmeltingRecipe(String recipeId, String group) {
protected SmeltingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull ItemStack result,
float experience,
int cookingTime
) {
super(RecipeType.SMELTING, recipeId);
setGroup(group);
this.group = group;
this.result = result;
this.experience = experience;
this.cookingTime = cookingTime;
}
@NotNull
public String getGroup() {
return group;
}
public void setGroup(@NotNull String group) {
this.group = group;
}
@NotNull
public DeclareRecipesPacket.Ingredient getIngredient() {
return ingredient;
}
public void setIngredient(DeclareRecipesPacket.Ingredient ingredient) {
public void setIngredient(@NotNull DeclareRecipesPacket.Ingredient ingredient) {
this.ingredient = ingredient;
}
@NotNull
public ItemStack getResult() {
return result;
}
public void setResult(ItemStack result) {
public void setResult(@NotNull ItemStack result) {
this.result = result;
}

View File

@ -2,40 +2,49 @@ package net.minestom.server.recipe;
import net.minestom.server.item.ItemStack;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
public abstract class SmithingRecipe extends Recipe {
private DeclareRecipesPacket.Ingredient baseIngredient;
private DeclareRecipesPacket.Ingredient additionIngredient;
private ItemStack result;
private ItemStack result = ItemStack.getAirItem();
protected SmithingRecipe(String recipeId, String group) {
protected SmithingRecipe(
@NotNull String recipeId,
@NotNull DeclareRecipesPacket.Ingredient baseIngredient,
@NotNull DeclareRecipesPacket.Ingredient additionIngredient,
@NotNull ItemStack result
) {
super(RecipeType.SMITHING, recipeId);
setGroup(group);
this.baseIngredient = baseIngredient;
this.additionIngredient = additionIngredient;
this.result = result;
}
@NotNull
public DeclareRecipesPacket.Ingredient getBaseIngredient() {
return baseIngredient;
}
public void setBaseIngredient(DeclareRecipesPacket.Ingredient baseIngredient) {
public void setBaseIngredient(@NotNull DeclareRecipesPacket.Ingredient baseIngredient) {
this.baseIngredient = baseIngredient;
}
@NotNull
public DeclareRecipesPacket.Ingredient getAdditionIngredient() {
return additionIngredient;
}
public void setAdditionIngredient(DeclareRecipesPacket.Ingredient additionIngredient) {
public void setAdditionIngredient(@NotNull DeclareRecipesPacket.Ingredient additionIngredient) {
this.additionIngredient = additionIngredient;
}
@NotNull
public ItemStack getResult() {
return result;
}
public void setResult(ItemStack result) {
public void setResult(@NotNull ItemStack result) {
this.result = result;
}
}

View File

@ -2,35 +2,53 @@ package net.minestom.server.recipe;
import net.minestom.server.item.ItemStack;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
public abstract class SmokingRecipe extends Recipe {
private String group;
private DeclareRecipesPacket.Ingredient ingredient;
private ItemStack result = ItemStack.getAirItem();
private ItemStack result;
private float experience;
private int cookingTime;
public SmokingRecipe(String recipeId, String group) {
super(RecipeType.SMELTING, recipeId);
setGroup(group);
protected SmokingRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull ItemStack result,
float experience,
int cookingTime
) {
super(RecipeType.SMOKING, recipeId);
this.group = group;
this.result = result;
this.experience = experience;
this.cookingTime = cookingTime;
}
@NotNull
public String getGroup() {
return group;
}
public void setGroup(@NotNull String group) {
this.group = group;
}
@NotNull
public DeclareRecipesPacket.Ingredient getIngredient() {
return ingredient;
}
public void setIngredient(DeclareRecipesPacket.Ingredient ingredient) {
public void setIngredient(@NotNull DeclareRecipesPacket.Ingredient ingredient) {
this.ingredient = ingredient;
}
@NotNull
public ItemStack getResult() {
return result;
}
public void setResult(ItemStack result) {
public void setResult(@NotNull ItemStack result) {
this.result = result;
}

View File

@ -2,31 +2,49 @@ package net.minestom.server.recipe;
import net.minestom.server.item.ItemStack;
import net.minestom.server.network.packet.server.play.DeclareRecipesPacket;
import org.jetbrains.annotations.NotNull;
public abstract class StonecutterRecipe extends Recipe {
private String group;
private DeclareRecipesPacket.Ingredient ingredient;
private ItemStack result;
private ItemStack result = ItemStack.getAirItem();
protected StonecutterRecipe(String recipeId, String group) {
protected StonecutterRecipe(
@NotNull String recipeId,
@NotNull String group,
@NotNull DeclareRecipesPacket.Ingredient ingredient,
@NotNull ItemStack result
) {
super(RecipeType.STONECUTTING, recipeId);
setGroup(group);
this.group = group;
this.ingredient = ingredient;
this.result = result;
}
@NotNull
public String getGroup() {
return group;
}
public void setGroup(@NotNull String group) {
this.group = group;
}
@NotNull
public DeclareRecipesPacket.Ingredient getIngredient() {
return ingredient;
}
public void setIngredient(DeclareRecipesPacket.Ingredient ingredient) {
public void setIngredient(@NotNull DeclareRecipesPacket.Ingredient ingredient) {
this.ingredient = ingredient;
}
@NotNull
public ItemStack getResult() {
return result;
}
public void setResult(ItemStack result) {
public void setResult(@NotNull ItemStack result) {
this.result = result;
}
}