mirror of
https://github.com/Sollace/Unicopia.git
synced 2024-11-24 05:47:59 +01:00
Further fattening and dispensibles rewrites
This commit is contained in:
parent
05c6c7b2b4
commit
6ab9343164
20 changed files with 276 additions and 241 deletions
|
@ -1,49 +0,0 @@
|
||||||
package com.minelittlepony.unicopia;
|
|
||||||
|
|
||||||
import java.util.function.Function;
|
|
||||||
|
|
||||||
import com.minelittlepony.unicopia.entity.*;
|
|
||||||
|
|
||||||
import net.minecraft.world.World;
|
|
||||||
|
|
||||||
public enum CloudSize {
|
|
||||||
SMALL(EntityRacingCloud::new),
|
|
||||||
MEDIUM(EntityConstructionCloud::new),
|
|
||||||
LARGE(EntityWildCloud::new);
|
|
||||||
|
|
||||||
private static final CloudSize[] META_LOOKUP = new CloudSize[values().length];
|
|
||||||
static {
|
|
||||||
CloudSize[] values = values();
|
|
||||||
for (CloudSize i : values) {
|
|
||||||
META_LOOKUP[i.getMetadata()] = i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private final String name;
|
|
||||||
|
|
||||||
private final Function<World, EntityCloud> constructor;
|
|
||||||
|
|
||||||
CloudSize(Function<World, EntityCloud> constructor) {
|
|
||||||
this.constructor = constructor;
|
|
||||||
this.name = name().toLowerCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getMetadata() {
|
|
||||||
return ordinal();
|
|
||||||
}
|
|
||||||
|
|
||||||
public EntityCloud createEntity(World w) {
|
|
||||||
return constructor.apply(w);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static CloudSize byMetadata(int meta) {
|
|
||||||
if (meta < 0 || meta >= META_LOOKUP.length) {
|
|
||||||
meta = 0;
|
|
||||||
}
|
|
||||||
return META_LOOKUP[meta];
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -19,10 +19,12 @@ public class Fixes {
|
||||||
CompoundDataFixer forgeDataFixer = (CompoundDataFixer)fixer;
|
CompoundDataFixer forgeDataFixer = (CompoundDataFixer)fixer;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
ModFixs modfix = forgeDataFixer.init(Unicopia.MODID, 1342);
|
ModFixs modfix = forgeDataFixer.init(Unicopia.MODID, 1343);
|
||||||
|
|
||||||
modfix.registerFix(FixTypes.CHUNK, new FixCloudBlocks());
|
modfix.registerFix(FixTypes.CHUNK, new FixCloudBlocks());
|
||||||
modfix.registerFix(FixTypes.ITEM_INSTANCE, new FixCloudItems());
|
modfix.registerFix(FixTypes.ITEM_INSTANCE, new FixCloudItems());
|
||||||
|
modfix.registerFix(FixTypes.ITEM_INSTANCE, new FixItems());
|
||||||
|
|
||||||
} catch (Throwable ignored) {
|
} catch (Throwable ignored) {
|
||||||
// no way to check if our fixer is already registered.
|
// no way to check if our fixer is already registered.
|
||||||
// so just do it anyway and ignore the error.
|
// so just do it anyway and ignore the error.
|
||||||
|
@ -30,6 +32,49 @@ public class Fixes {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static class FixItems implements IFixableData {
|
||||||
|
|
||||||
|
private final String[] cloud_spawners = new String[] {
|
||||||
|
"unicopia:racing_cloud_spawner",
|
||||||
|
"unicopia:construction_cloud_spawner",
|
||||||
|
"unicopia:wild_cloud_spawner"
|
||||||
|
};
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getFixVersion() {
|
||||||
|
return 1343;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NBTTagCompound fixTagCompound(NBTTagCompound compound) {
|
||||||
|
if (compound.hasKey("id", 8)) {
|
||||||
|
String id = compound.getString("id");
|
||||||
|
int damage = compound.hasKey("Damage", 3) ? compound.getInteger("Damage") : 0;
|
||||||
|
|
||||||
|
if (id == "unicopia:cloud") {
|
||||||
|
id = cloud_spawners[damage % cloud_spawners.length];
|
||||||
|
damage = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (id == "unicopia:tomato" && damage == 1) {
|
||||||
|
id = "unicopia:rotten_tomato";
|
||||||
|
damage = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (id == "unicopia:cloudsdale_tomato" && damage == 1) {
|
||||||
|
id = "unicopia:rotten_cloudsdale_tomato";
|
||||||
|
damage = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
compound.setString("id", id);
|
||||||
|
compound.setInteger("Damage", 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return compound;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static class FixCloudItems implements IFixableData {
|
static class FixCloudItems implements IFixableData {
|
||||||
@Override
|
@Override
|
||||||
public int getFixVersion() {
|
public int getFixVersion() {
|
||||||
|
|
|
@ -123,7 +123,7 @@ public class BlockTomatoPlant extends BlockCrops {
|
||||||
public Item getItemDropped(IBlockState state, Random rand, int fortune) {
|
public Item getItemDropped(IBlockState state, Random rand, int fortune) {
|
||||||
|
|
||||||
if (isMaxAge(state)) {
|
if (isMaxAge(state)) {
|
||||||
return state.getValue(TYPE) == Type.CLOUDSDALE ? UItems.cloudsdale_tomato : UItems.tomato;
|
return state.getValue(TYPE).getCrop();
|
||||||
}
|
}
|
||||||
|
|
||||||
return getSeed();
|
return getSeed();
|
||||||
|
@ -148,18 +148,16 @@ public class BlockTomatoPlant extends BlockCrops {
|
||||||
if (player.getHeldItem(hand).isEmpty()) {
|
if (player.getHeldItem(hand).isEmpty()) {
|
||||||
Type type = state.getValue(TYPE);
|
Type type = state.getValue(TYPE);
|
||||||
|
|
||||||
Item crop = type == Type.CLOUDSDALE ? UItems.cloudsdale_tomato : UItems.tomato;
|
|
||||||
|
|
||||||
int good = getAge(state);
|
int good = getAge(state);
|
||||||
int rotten = world.rand.nextInt(good);
|
int rotten = world.rand.nextInt(good);
|
||||||
|
|
||||||
good -= rotten;
|
good -= rotten;
|
||||||
|
|
||||||
if (good > 0) {
|
if (good > 0) {
|
||||||
spawnAsEntity(world, pos, new ItemStack(crop, good, 0));
|
spawnAsEntity(world, pos, new ItemStack(type.getCrop(), good));
|
||||||
}
|
}
|
||||||
if (rotten > 0) {
|
if (rotten > 0) {
|
||||||
spawnAsEntity(world, pos, new ItemStack(crop, rotten, 1));
|
spawnAsEntity(world, pos, new ItemStack(type.getWaste(), rotten));
|
||||||
}
|
}
|
||||||
|
|
||||||
world.setBlockState(pos, state.withProperty(getAgeProperty(), 0));
|
world.setBlockState(pos, state.withProperty(getAgeProperty(), 0));
|
||||||
|
@ -239,5 +237,13 @@ public class BlockTomatoPlant extends BlockCrops {
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return this == NORMAL ? "normal" : "cloudsdale";
|
return this == NORMAL ? "normal" : "cloudsdale";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Item getCrop() {
|
||||||
|
return this == CLOUDSDALE ? UItems.cloudsdale_tomato : UItems.tomato;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Item getWaste() {
|
||||||
|
return this == CLOUDSDALE ? UItems.rotten_cloudsdale_tomato : UItems.rotten_tomato;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,13 +4,14 @@ import com.minelittlepony.unicopia.item.ItemAlicornAmulet;
|
||||||
import com.minelittlepony.unicopia.item.ItemApple;
|
import com.minelittlepony.unicopia.item.ItemApple;
|
||||||
import com.minelittlepony.unicopia.item.ItemAppleMultiType;
|
import com.minelittlepony.unicopia.item.ItemAppleMultiType;
|
||||||
import com.minelittlepony.unicopia.item.ItemCereal;
|
import com.minelittlepony.unicopia.item.ItemCereal;
|
||||||
import com.minelittlepony.unicopia.item.ItemCloud;
|
import com.minelittlepony.unicopia.item.ItemCloudPlacer;
|
||||||
import com.minelittlepony.unicopia.item.ItemCurse;
|
import com.minelittlepony.unicopia.item.ItemCurse;
|
||||||
import com.minelittlepony.unicopia.item.ItemFruitLeaves;
|
import com.minelittlepony.unicopia.item.ItemFruitLeaves;
|
||||||
import com.minelittlepony.unicopia.item.ItemMagicStaff;
|
import com.minelittlepony.unicopia.item.ItemMagicStaff;
|
||||||
import com.minelittlepony.unicopia.item.ItemMoss;
|
import com.minelittlepony.unicopia.item.ItemMoss;
|
||||||
import com.minelittlepony.unicopia.item.ItemOfHolding;
|
import com.minelittlepony.unicopia.item.ItemOfHolding;
|
||||||
import com.minelittlepony.unicopia.item.ItemRottenApple;
|
import com.minelittlepony.unicopia.item.ItemRottenApple;
|
||||||
|
import com.minelittlepony.unicopia.item.ItemRottenTomato;
|
||||||
import com.minelittlepony.unicopia.item.ItemSpell;
|
import com.minelittlepony.unicopia.item.ItemSpell;
|
||||||
import com.minelittlepony.unicopia.item.ItemSpellbook;
|
import com.minelittlepony.unicopia.item.ItemSpellbook;
|
||||||
import com.minelittlepony.unicopia.item.ItemStaff;
|
import com.minelittlepony.unicopia.item.ItemStaff;
|
||||||
|
@ -58,6 +59,9 @@ import com.minelittlepony.unicopia.edibles.FlowerToxicityDeterminent;
|
||||||
import com.minelittlepony.unicopia.edibles.MultiItemEdible;
|
import com.minelittlepony.unicopia.edibles.MultiItemEdible;
|
||||||
import com.minelittlepony.unicopia.edibles.Toxicity;
|
import com.minelittlepony.unicopia.edibles.Toxicity;
|
||||||
import com.minelittlepony.unicopia.edibles.UItemFoodDelegate;
|
import com.minelittlepony.unicopia.edibles.UItemFoodDelegate;
|
||||||
|
import com.minelittlepony.unicopia.entity.EntityConstructionCloud;
|
||||||
|
import com.minelittlepony.unicopia.entity.EntityRacingCloud;
|
||||||
|
import com.minelittlepony.unicopia.entity.EntityWildCloud;
|
||||||
import com.minelittlepony.unicopia.extern.Baubles;
|
import com.minelittlepony.unicopia.extern.Baubles;
|
||||||
import com.minelittlepony.unicopia.forgebullshit.BuildInTexturesBakery;
|
import com.minelittlepony.unicopia.forgebullshit.BuildInTexturesBakery;
|
||||||
import com.minelittlepony.unicopia.forgebullshit.ItemRegistrar;
|
import com.minelittlepony.unicopia.forgebullshit.ItemRegistrar;
|
||||||
|
@ -87,7 +91,9 @@ public class UItems {
|
||||||
.setTranslationKey("dew_drop")
|
.setTranslationKey("dew_drop")
|
||||||
.setRegistryName(Unicopia.MODID, "dew_drop");
|
.setRegistryName(Unicopia.MODID, "dew_drop");
|
||||||
|
|
||||||
public static final ItemCloud cloud_spawner = new ItemCloud(Unicopia.MODID, "cloud");
|
public static final ItemCloudPlacer racing_cloud_spawner = new ItemCloudPlacer(EntityRacingCloud::new, Unicopia.MODID, "racing_cloud_spawner");
|
||||||
|
public static final ItemCloudPlacer construction_cloud_spawner = new ItemCloudPlacer(EntityConstructionCloud::new, Unicopia.MODID, "construction_cloud_spawner");
|
||||||
|
public static final ItemCloudPlacer wild_cloud_spawner = new ItemCloudPlacer(EntityWildCloud::new, Unicopia.MODID, "wild_cloud_spawner");
|
||||||
|
|
||||||
public static final Item cloud_block = new UItemBlock(UBlocks.normal_cloud, INTERACT_WITH_CLOUDS);
|
public static final Item cloud_block = new UItemBlock(UBlocks.normal_cloud, INTERACT_WITH_CLOUDS);
|
||||||
public static final Item enchanted_cloud = new UItemBlock(UBlocks.enchanted_cloud, INTERACT_WITH_CLOUDS);
|
public static final Item enchanted_cloud = new UItemBlock(UBlocks.enchanted_cloud, INTERACT_WITH_CLOUDS);
|
||||||
|
@ -169,7 +175,11 @@ public class UItems {
|
||||||
public static final Item sugar_cereal = new ItemCereal(Unicopia.MODID, "sugar_cereal", 20, -2).setSugarAmount(110).setAlwaysEdible();
|
public static final Item sugar_cereal = new ItemCereal(Unicopia.MODID, "sugar_cereal", 20, -2).setSugarAmount(110).setAlwaysEdible();
|
||||||
|
|
||||||
public static final ItemTomato tomato = new ItemTomato(Unicopia.MODID, "tomato", 4, 34);
|
public static final ItemTomato tomato = new ItemTomato(Unicopia.MODID, "tomato", 4, 34);
|
||||||
|
public static final ItemRottenTomato rotten_tomato = new ItemRottenTomato(Unicopia.MODID, "rotten_tomato", 4, 34);
|
||||||
|
|
||||||
public static final ItemTomato cloudsdale_tomato = new ItemTomato(Unicopia.MODID, "cloudsdale_tomato", 16, 4);
|
public static final ItemTomato cloudsdale_tomato = new ItemTomato(Unicopia.MODID, "cloudsdale_tomato", 16, 4);
|
||||||
|
public static final ItemRottenTomato rotten_cloudsdale_tomato = new ItemRottenTomato(Unicopia.MODID, "rotten_cloudsdale_tomato", 4, 34);
|
||||||
|
|
||||||
public static final ItemTomatoSeeds tomato_seeds = new ItemTomatoSeeds(Unicopia.MODID, "tomato_seeds");
|
public static final ItemTomatoSeeds tomato_seeds = new ItemTomatoSeeds(Unicopia.MODID, "tomato_seeds");
|
||||||
|
|
||||||
public static final Item apple_seeds = new UItemDecoration(UBlocks.apple_tree, Unicopia.MODID, "apple_seeds");
|
public static final Item apple_seeds = new UItemDecoration(UBlocks.apple_tree, Unicopia.MODID, "apple_seeds");
|
||||||
|
@ -244,14 +254,16 @@ public class UItems {
|
||||||
.replace(Item.getItemFromBlock(Blocks.RED_FLOWER), red_flower));
|
.replace(Item.getItemFromBlock(Blocks.RED_FLOWER), red_flower));
|
||||||
|
|
||||||
ItemRegistrar.registerAll(registry,
|
ItemRegistrar.registerAll(registry,
|
||||||
cloud_spawner,
|
racing_cloud_spawner, construction_cloud_spawner, wild_cloud_spawner,
|
||||||
green_apple, sweet_apple, sour_apple,
|
green_apple, sweet_apple, sour_apple,
|
||||||
zap_apple, rotten_apple, cooked_zap_apple,
|
zap_apple, rotten_apple, cooked_zap_apple,
|
||||||
apple_seeds, apple_leaves,
|
apple_seeds, apple_leaves,
|
||||||
|
|
||||||
dew_drop,
|
dew_drop,
|
||||||
|
|
||||||
tomato, cloudsdale_tomato, tomato_seeds, moss,
|
tomato, rotten_tomato,
|
||||||
|
cloudsdale_tomato, rotten_cloudsdale_tomato,
|
||||||
|
tomato_seeds, moss,
|
||||||
|
|
||||||
cloud_matter, cloud_block, enchanted_cloud, packed_cloud,
|
cloud_matter, cloud_block, enchanted_cloud, packed_cloud,
|
||||||
cloud_stairs,
|
cloud_stairs,
|
||||||
|
|
|
@ -4,15 +4,41 @@ import com.minelittlepony.unicopia.entity.EntitySpell;
|
||||||
import com.minelittlepony.unicopia.spell.IDispenceable;
|
import com.minelittlepony.unicopia.spell.IDispenceable;
|
||||||
import com.minelittlepony.unicopia.spell.IMagicEffect;
|
import com.minelittlepony.unicopia.spell.IMagicEffect;
|
||||||
import com.minelittlepony.unicopia.spell.SpellCastResult;
|
import com.minelittlepony.unicopia.spell.SpellCastResult;
|
||||||
|
import com.minelittlepony.unicopia.spell.SpellRegistry;
|
||||||
|
|
||||||
import net.minecraft.dispenser.IBlockSource;
|
import net.minecraft.dispenser.IBlockSource;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.util.ActionResult;
|
||||||
|
import net.minecraft.util.EnumActionResult;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public interface ICastable extends IMagicalItem {
|
public interface ICastable extends IMagicalItem, IDispensable {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
default ActionResult<ItemStack> dispenseStack(IBlockSource source, ItemStack stack) {
|
||||||
|
IDispenceable effect = SpellRegistry.instance().getDispenseActionFrom(stack);
|
||||||
|
|
||||||
|
if (effect == null) {
|
||||||
|
return new ActionResult<>(EnumActionResult.FAIL, stack);
|
||||||
|
}
|
||||||
|
|
||||||
|
SpellCastResult dispenceResult = onDispenseSpell(source, stack, effect);
|
||||||
|
|
||||||
|
if (dispenceResult == SpellCastResult.DEFAULT) {
|
||||||
|
return new ActionResult<>(EnumActionResult.PASS, stack);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dispenceResult == SpellCastResult.PLACE) {
|
||||||
|
castContainedSpell(source.getWorld(), source.getBlockPos(), stack, effect);
|
||||||
|
|
||||||
|
stack.shrink(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new ActionResult<>(EnumActionResult.SUCCESS, stack);
|
||||||
|
}
|
||||||
|
|
||||||
SpellCastResult onDispenseSpell(IBlockSource source, ItemStack stack, IDispenceable effect);
|
SpellCastResult onDispenseSpell(IBlockSource source, ItemStack stack, IDispenceable effect);
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
package com.minelittlepony.unicopia.item;
|
||||||
|
|
||||||
|
import net.minecraft.block.BlockDispenser;
|
||||||
|
import net.minecraft.dispenser.BehaviorDefaultDispenseItem;
|
||||||
|
import net.minecraft.dispenser.IBehaviorDispenseItem;
|
||||||
|
import net.minecraft.dispenser.IBlockSource;
|
||||||
|
import net.minecraft.item.Item;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.util.ActionResult;
|
||||||
|
import net.minecraft.util.EnumActionResult;
|
||||||
|
|
||||||
|
public interface IDispensable {
|
||||||
|
IBehaviorDispenseItem dispenserBehavior = new BehaviorDefaultDispenseItem() {
|
||||||
|
@Override
|
||||||
|
protected ItemStack dispenseStack(IBlockSource source, ItemStack stack) {
|
||||||
|
|
||||||
|
ActionResult<ItemStack> result = ((IDispensable)stack.getItem()).dispenseStack(source, stack);
|
||||||
|
|
||||||
|
if (result.getType() != EnumActionResult.SUCCESS) {
|
||||||
|
return super.dispense(source, stack);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result.getResult();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enables dispensing behaviours for this item.
|
||||||
|
*/
|
||||||
|
default Item setDispenseable() {
|
||||||
|
BlockDispenser.DISPENSE_BEHAVIOR_REGISTRY.putObject((Item)(Object)this, dispenserBehavior);
|
||||||
|
|
||||||
|
return (Item)(Object)this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called to dispense this stack.
|
||||||
|
*/
|
||||||
|
ActionResult<ItemStack> dispenseStack(IBlockSource source, ItemStack stack);
|
||||||
|
}
|
|
@ -1,10 +1,14 @@
|
||||||
package com.minelittlepony.unicopia.item;
|
package com.minelittlepony.unicopia.item;
|
||||||
|
|
||||||
import com.minelittlepony.unicopia.CloudSize;
|
import java.util.function.Function;
|
||||||
import com.minelittlepony.unicopia.entity.EntityCloud;
|
|
||||||
import com.minelittlepony.unicopia.forgebullshit.IMultiItem;
|
|
||||||
|
|
||||||
|
import com.minelittlepony.unicopia.entity.EntityCloud;
|
||||||
|
import com.minelittlepony.unicopia.init.UItems;
|
||||||
|
|
||||||
|
import net.minecraft.block.BlockDispenser;
|
||||||
import net.minecraft.creativetab.CreativeTabs;
|
import net.minecraft.creativetab.CreativeTabs;
|
||||||
|
import net.minecraft.dispenser.IBlockSource;
|
||||||
|
import net.minecraft.dispenser.IPosition;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
@ -16,24 +20,36 @@ import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.RayTraceResult;
|
import net.minecraft.util.math.RayTraceResult;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public class ItemCloud extends Item implements IMultiItem {
|
public class ItemCloudPlacer extends Item implements IDispensable {
|
||||||
|
|
||||||
private static final String[] variants = new String[] {"cloud_small", "cloud_medium", "cloud_large"};
|
private final Function<World, EntityCloud> cloudSupplier;
|
||||||
|
|
||||||
public ItemCloud(String domain, String name) {
|
public ItemCloudPlacer(Function<World, EntityCloud> cloudSupplier, String domain, String name) {
|
||||||
super();
|
super();
|
||||||
setHasSubtypes(true);
|
|
||||||
setMaxDamage(0);
|
|
||||||
setTranslationKey(name);
|
setTranslationKey(name);
|
||||||
setRegistryName(domain, name);
|
setRegistryName(domain, name);
|
||||||
setCreativeTab(CreativeTabs.MATERIALS);
|
setCreativeTab(CreativeTabs.MATERIALS);
|
||||||
|
|
||||||
maxStackSize = 16;
|
maxStackSize = 16;
|
||||||
|
|
||||||
|
this.cloudSupplier = cloudSupplier;
|
||||||
|
|
||||||
|
setDispenseable();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String[] getVariants() {
|
public void getSubItems(CreativeTabs tab, NonNullList<ItemStack> items) {
|
||||||
return variants;
|
if (this == UItems.racing_cloud_spawner && isInCreativeTab(tab)) {
|
||||||
|
items.add(new ItemStack(this));
|
||||||
|
items.add(new ItemStack(UItems.construction_cloud_spawner));
|
||||||
|
items.add(new ItemStack(UItems.wild_cloud_spawner));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void placeCloud(World world, BlockPos pos) {
|
||||||
|
EntityCloud cloud = cloudSupplier.apply(world);
|
||||||
|
cloud.moveToBlockPosAndAngles(pos, 0, 0);
|
||||||
|
world.spawnEntity(cloud);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -51,9 +67,7 @@ public class ItemCloud extends Item implements IMultiItem {
|
||||||
pos = player.getPosition();
|
pos = player.getPosition();
|
||||||
}
|
}
|
||||||
|
|
||||||
EntityCloud cloud = CloudSize.byMetadata(stack.getItemDamage()).createEntity(world);
|
placeCloud(world, pos);
|
||||||
cloud.moveToBlockPosAndAngles(pos, 0, 0);
|
|
||||||
world.spawnEntity(cloud);
|
|
||||||
|
|
||||||
if (!player.capabilities.isCreativeMode) {
|
if (!player.capabilities.isCreativeMode) {
|
||||||
stack.shrink(1);
|
stack.shrink(1);
|
||||||
|
@ -64,16 +78,13 @@ public class ItemCloud extends Item implements IMultiItem {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getTranslationKey(ItemStack stack) {
|
public ActionResult<ItemStack> dispenseStack(IBlockSource source, ItemStack stack) {
|
||||||
return super.getTranslationKey(stack) + "." + CloudSize.byMetadata(stack.getItemDamage()).getName();
|
IPosition pos = BlockDispenser.getDispensePosition(source);
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
placeCloud(source.getWorld(), new BlockPos(pos.getX(), pos.getY(), pos.getZ()));
|
||||||
public void getSubItems(CreativeTabs tab, NonNullList<ItemStack> subs) {
|
|
||||||
if (isInCreativeTab(tab)) {
|
stack.shrink(1);
|
||||||
for (CloudSize i : CloudSize.values()) {
|
|
||||||
subs.add(new ItemStack(this, 1, i.getMetadata()));
|
return new ActionResult<>(EnumActionResult.SUCCESS, stack);
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -128,15 +128,11 @@ public class ItemMagicStaff extends ItemStaff implements IAligned, ITossableItem
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public int getMaxItemUseDuration(ItemStack stack) {
|
public int getMaxItemUseDuration(ItemStack stack) {
|
||||||
return 72000;
|
return 72000;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean canBeThrown(ItemStack stack) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void toss(World world, ItemStack stack, EntityPlayer player) {
|
public void toss(World world, ItemStack stack, EntityPlayer player) {
|
||||||
IPlayer iplayer = PlayerSpeciesList.instance().getPlayer(player);
|
IPlayer iplayer = PlayerSpeciesList.instance().getPlayer(player);
|
||||||
|
|
|
@ -0,0 +1,66 @@
|
||||||
|
package com.minelittlepony.unicopia.item;
|
||||||
|
|
||||||
|
import com.minelittlepony.unicopia.player.PlayerSpeciesList;
|
||||||
|
import com.minelittlepony.unicopia.spell.ICaster;
|
||||||
|
import com.minelittlepony.unicopia.tossable.ITossableItem;
|
||||||
|
|
||||||
|
import net.minecraft.block.material.Material;
|
||||||
|
import net.minecraft.block.state.IBlockState;
|
||||||
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.init.MobEffects;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.potion.PotionEffect;
|
||||||
|
import net.minecraft.util.ActionResult;
|
||||||
|
import net.minecraft.util.EnumActionResult;
|
||||||
|
import net.minecraft.util.EnumHand;
|
||||||
|
import net.minecraft.util.math.BlockPos;
|
||||||
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
|
public class ItemRottenTomato extends ItemTomato implements ITossableItem {
|
||||||
|
|
||||||
|
public ItemRottenTomato(String domain, String name, int heal, int sat) {
|
||||||
|
super(domain, name, heal, sat);
|
||||||
|
|
||||||
|
setDispenseable();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ActionResult<ItemStack> onItemRightClick(World world, EntityPlayer player, EnumHand hand) {
|
||||||
|
ItemStack itemstack = player.getHeldItem(hand);
|
||||||
|
|
||||||
|
if (canBeThrown(itemstack) && !player.canEat(false)) {
|
||||||
|
toss(world, itemstack, player);
|
||||||
|
|
||||||
|
return new ActionResult<ItemStack>(EnumActionResult.SUCCESS, itemstack);
|
||||||
|
}
|
||||||
|
|
||||||
|
return super.onItemRightClick(world, player, hand);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean isSickening(ItemStack stack, EntityPlayer player) {
|
||||||
|
return canBeThrown(stack)
|
||||||
|
&& !PlayerSpeciesList.instance().getPlayer(player).getPlayerSpecies().canUseEarth();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onFoodEaten(ItemStack stack, World worldIn, EntityPlayer player) {
|
||||||
|
if (isSickening(stack, player)) {
|
||||||
|
int duration = 7000;
|
||||||
|
|
||||||
|
PotionEffect effect = player.getActivePotionEffect(MobEffects.NAUSEA);
|
||||||
|
|
||||||
|
if (effect != null) {
|
||||||
|
duration += Math.max(0, effect.getDuration());
|
||||||
|
}
|
||||||
|
|
||||||
|
player.addPotionEffect(new PotionEffect(MobEffects.NAUSEA, duration, 4));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onImpact(ICaster<?> caster, BlockPos pos, IBlockState state) {
|
||||||
|
if (caster.isLocal() && state.getMaterial() == Material.GLASS) {
|
||||||
|
caster.getWorld().destroyBlock(pos, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -18,8 +18,6 @@ import com.minelittlepony.util.vector.VecHelper;
|
||||||
import net.minecraft.block.BlockDispenser;
|
import net.minecraft.block.BlockDispenser;
|
||||||
import net.minecraft.client.util.ITooltipFlag;
|
import net.minecraft.client.util.ITooltipFlag;
|
||||||
import net.minecraft.creativetab.CreativeTabs;
|
import net.minecraft.creativetab.CreativeTabs;
|
||||||
import net.minecraft.dispenser.BehaviorDefaultDispenseItem;
|
|
||||||
import net.minecraft.dispenser.IBehaviorDispenseItem;
|
|
||||||
import net.minecraft.dispenser.IBlockSource;
|
import net.minecraft.dispenser.IBlockSource;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
@ -35,35 +33,6 @@ import net.minecraft.util.NonNullList;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public class ItemSpell extends Item implements ICastable {
|
public class ItemSpell extends Item implements ICastable {
|
||||||
private static final IBehaviorDispenseItem dispenserBehavior = new BehaviorDefaultDispenseItem() {
|
|
||||||
@Override
|
|
||||||
protected ItemStack dispenseStack(IBlockSource source, ItemStack stack) {
|
|
||||||
|
|
||||||
IDispenceable effect = SpellRegistry.instance().getDispenseActionFrom(stack);
|
|
||||||
|
|
||||||
if (effect == null) {
|
|
||||||
return super.dispenseStack(source, stack);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (stack.getItem() instanceof ICastable) {
|
|
||||||
ICastable castable = (ICastable)stack.getItem();
|
|
||||||
|
|
||||||
SpellCastResult dispenceResult = castable.onDispenseSpell(source, stack, effect);
|
|
||||||
|
|
||||||
if (dispenceResult == SpellCastResult.DEFAULT) {
|
|
||||||
return super.dispenseStack(source, stack);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dispenceResult == SpellCastResult.PLACE) {
|
|
||||||
castable.castContainedSpell(source.getWorld(), source.getBlockPos(), stack, effect);
|
|
||||||
|
|
||||||
stack.shrink(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return stack;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
protected String translationKey;
|
protected String translationKey;
|
||||||
|
|
||||||
|
|
|
@ -1,105 +1,44 @@
|
||||||
package com.minelittlepony.unicopia.item;
|
package com.minelittlepony.unicopia.item;
|
||||||
|
|
||||||
import com.minelittlepony.unicopia.forgebullshit.IMultiItem;
|
import com.minelittlepony.unicopia.init.UItems;
|
||||||
import com.minelittlepony.unicopia.player.PlayerSpeciesList;
|
|
||||||
import com.minelittlepony.unicopia.spell.ICaster;
|
|
||||||
import com.minelittlepony.unicopia.tossable.ITossableItem;
|
|
||||||
|
|
||||||
import net.minecraft.block.material.Material;
|
|
||||||
import net.minecraft.block.state.IBlockState;
|
|
||||||
import net.minecraft.creativetab.CreativeTabs;
|
import net.minecraft.creativetab.CreativeTabs;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.init.MobEffects;
|
import net.minecraft.init.MobEffects;
|
||||||
import net.minecraft.item.ItemFood;
|
import net.minecraft.item.ItemFood;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.potion.PotionEffect;
|
import net.minecraft.potion.PotionEffect;
|
||||||
import net.minecraft.util.ActionResult;
|
|
||||||
import net.minecraft.util.EnumActionResult;
|
|
||||||
import net.minecraft.util.EnumHand;
|
|
||||||
import net.minecraft.util.NonNullList;
|
import net.minecraft.util.NonNullList;
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public class ItemTomato extends ItemFood implements ITossableItem, IMultiItem {
|
public class ItemTomato extends ItemFood {
|
||||||
|
|
||||||
private final String name;
|
|
||||||
|
|
||||||
public ItemTomato(String domain, String name, int heal, int sat) {
|
public ItemTomato(String domain, String name, int heal, int sat) {
|
||||||
super(heal, sat, false);
|
super(heal, sat, false);
|
||||||
|
|
||||||
this.name = name;
|
|
||||||
|
|
||||||
setTranslationKey(name);
|
setTranslationKey(name);
|
||||||
setRegistryName(domain, name);
|
setRegistryName(domain, name);
|
||||||
|
|
||||||
setDispenseable();
|
|
||||||
setHasSubtypes(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String[] getVariants() {
|
|
||||||
return new String[] {name, "rotten_" + name};
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void getSubItems(CreativeTabs tab, NonNullList<ItemStack> items) {
|
public void getSubItems(CreativeTabs tab, NonNullList<ItemStack> items) {
|
||||||
if (isInCreativeTab(tab)) {
|
if (this == UItems.tomato && isInCreativeTab(tab)) {
|
||||||
items.add(new ItemStack(this, 1, 0));
|
items.add(new ItemStack(this));
|
||||||
items.add(new ItemStack(this, 1, 1));
|
items.add(new ItemStack(UItems.rotten_tomato));
|
||||||
|
items.add(new ItemStack(UItems.cloudsdale_tomato));
|
||||||
|
items.add(new ItemStack(UItems.rotten_cloudsdale_tomato));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getTranslationKey(ItemStack stack) {
|
|
||||||
return super.getTranslationKey(stack) + (canBeThrown(stack) ? ".rotten" : "");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public ActionResult<ItemStack> onItemRightClick(World world, EntityPlayer player, EnumHand hand) {
|
|
||||||
ItemStack itemstack = player.getHeldItem(hand);
|
|
||||||
|
|
||||||
if (canBeThrown(itemstack) && !player.canEat(false)) {
|
|
||||||
toss(world, itemstack, player);
|
|
||||||
|
|
||||||
return new ActionResult<ItemStack>(EnumActionResult.SUCCESS, itemstack);
|
|
||||||
}
|
|
||||||
|
|
||||||
return super.onItemRightClick(world, player, hand);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean canBeThrown(ItemStack stack) {
|
|
||||||
return stack.getMetadata() > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected boolean isSickening(ItemStack stack, EntityPlayer player) {
|
|
||||||
return canBeThrown(stack)
|
|
||||||
&& !PlayerSpeciesList.instance().getPlayer(player).getPlayerSpecies().canUseEarth();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onFoodEaten(ItemStack stack, World worldIn, EntityPlayer player) {
|
protected void onFoodEaten(ItemStack stack, World worldIn, EntityPlayer player) {
|
||||||
|
|
||||||
PotionEffect effect = player.getActivePotionEffect(MobEffects.NAUSEA);
|
PotionEffect effect = player.getActivePotionEffect(MobEffects.NAUSEA);
|
||||||
|
|
||||||
if (isSickening(stack, player)) {
|
if (effect != null) {
|
||||||
int duration = 7000;
|
|
||||||
|
|
||||||
if (effect != null) {
|
|
||||||
duration += Math.max(0, effect.getDuration());
|
|
||||||
}
|
|
||||||
|
|
||||||
player.addPotionEffect(new PotionEffect(MobEffects.NAUSEA, duration, 4));
|
|
||||||
} else if (effect != null) {
|
|
||||||
player.removePotionEffect(MobEffects.NAUSEA);
|
player.removePotionEffect(MobEffects.NAUSEA);
|
||||||
}
|
}
|
||||||
|
|
||||||
super.onFoodEaten(stack, worldIn, player);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onImpact(ICaster<?> caster, BlockPos pos, IBlockState state) {
|
|
||||||
if (caster.isLocal() && state.getMaterial() == Material.GLASS) {
|
|
||||||
caster.getWorld().destroyBlock(pos, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,35 +0,0 @@
|
||||||
package com.minelittlepony.unicopia.tossable;
|
|
||||||
|
|
||||||
import net.minecraft.block.BlockDispenser;
|
|
||||||
import net.minecraft.dispenser.BehaviorDefaultDispenseItem;
|
|
||||||
import net.minecraft.dispenser.IBlockSource;
|
|
||||||
import net.minecraft.item.ItemStack;
|
|
||||||
import net.minecraft.util.EnumFacing;
|
|
||||||
|
|
||||||
class DispenserBehaviour extends BehaviorDefaultDispenseItem {
|
|
||||||
@Override
|
|
||||||
public ItemStack dispenseStack(IBlockSource source, ItemStack stack) {
|
|
||||||
ITossableItem tossable = (ITossableItem)stack.getItem();
|
|
||||||
|
|
||||||
if (tossable.canBeThrown(stack)) {
|
|
||||||
return shootStack(source, stack);
|
|
||||||
}
|
|
||||||
|
|
||||||
return super.dispenseStack(source, stack);
|
|
||||||
}
|
|
||||||
|
|
||||||
public ItemStack shootStack(IBlockSource source, ItemStack stack) {
|
|
||||||
return ((ITossableItem)stack.getItem()).toss(source.getWorld(),
|
|
||||||
BlockDispenser.getDispensePosition(source),
|
|
||||||
(EnumFacing)source.getBlockState().getValue(BlockDispenser.FACING),
|
|
||||||
stack, getProjectileInaccuracy(), getProjectileVelocity());
|
|
||||||
}
|
|
||||||
|
|
||||||
protected float getProjectileInaccuracy() {
|
|
||||||
return 6.0F;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected float getProjectileVelocity() {
|
|
||||||
return 1.1F;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,27 +1,36 @@
|
||||||
package com.minelittlepony.unicopia.tossable;
|
package com.minelittlepony.unicopia.tossable;
|
||||||
|
|
||||||
import com.minelittlepony.unicopia.entity.EntityProjectile;
|
import com.minelittlepony.unicopia.entity.EntityProjectile;
|
||||||
|
import com.minelittlepony.unicopia.item.IDispensable;
|
||||||
|
|
||||||
import net.minecraft.block.BlockDispenser;
|
import net.minecraft.block.BlockDispenser;
|
||||||
import net.minecraft.dispenser.IBehaviorDispenseItem;
|
import net.minecraft.dispenser.IBlockSource;
|
||||||
import net.minecraft.dispenser.IPosition;
|
import net.minecraft.dispenser.IPosition;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.Item;
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.stats.StatList;
|
import net.minecraft.stats.StatList;
|
||||||
|
import net.minecraft.util.ActionResult;
|
||||||
|
import net.minecraft.util.EnumActionResult;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.SoundCategory;
|
import net.minecraft.util.SoundCategory;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public interface ITossableItem extends ITossable<ItemStack> {
|
public interface ITossableItem extends ITossable<ItemStack>, IDispensable {
|
||||||
IBehaviorDispenseItem dispenserBehavior = new DispenserBehaviour();
|
|
||||||
|
|
||||||
boolean canBeThrown(ItemStack stack);
|
default boolean canBeThrown(ItemStack stack) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
default Item setDispenseable() {
|
@Override
|
||||||
BlockDispenser.DISPENSE_BEHAVIOR_REGISTRY.putObject((Item)(Object)this, dispenserBehavior);
|
default ActionResult<ItemStack> dispenseStack(IBlockSource source, ItemStack stack) {
|
||||||
|
|
||||||
return (Item)(Object)this;
|
if (canBeThrown(stack)) {
|
||||||
|
stack = toss(source.getWorld(), BlockDispenser.getDispensePosition(source), (EnumFacing)source.getBlockState().getValue(BlockDispenser.FACING), stack);
|
||||||
|
|
||||||
|
return new ActionResult<>(EnumActionResult.SUCCESS, stack);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new ActionResult<>(EnumActionResult.PASS, stack);
|
||||||
}
|
}
|
||||||
|
|
||||||
default void toss(World world, ItemStack itemstack, EntityPlayer player) {
|
default void toss(World world, ItemStack itemstack, EntityPlayer player) {
|
||||||
|
@ -44,13 +53,13 @@ public interface ITossableItem extends ITossable<ItemStack> {
|
||||||
player.addStat(StatList.getObjectUseStats(itemstack.getItem()));
|
player.addStat(StatList.getObjectUseStats(itemstack.getItem()));
|
||||||
}
|
}
|
||||||
|
|
||||||
default ItemStack toss(World world, IPosition pos, EnumFacing facing, ItemStack stack, float velocity, float inaccuracy) {
|
default ItemStack toss(World world, IPosition pos, EnumFacing facing, ItemStack stack) {
|
||||||
EntityProjectile iprojectile = new EntityProjectile(world, pos.getX(), pos.getY(), pos.getZ());
|
EntityProjectile iprojectile = new EntityProjectile(world, pos.getX(), pos.getY(), pos.getZ());
|
||||||
|
|
||||||
iprojectile.setItem(stack);
|
iprojectile.setItem(stack);
|
||||||
iprojectile.setThrowDamage(getThrowDamage(stack));
|
iprojectile.setThrowDamage(getThrowDamage(stack));
|
||||||
|
|
||||||
iprojectile.shoot(facing.getXOffset(), facing.getYOffset() + 0.1F, facing.getZOffset(), velocity, inaccuracy);
|
iprojectile.shoot(facing.getXOffset(), facing.getYOffset() + 0.1F, facing.getZOffset(), 1.1F, 6);
|
||||||
|
|
||||||
world.spawnEntity(iprojectile);
|
world.spawnEntity(iprojectile);
|
||||||
|
|
||||||
|
|
|
@ -29,9 +29,9 @@ tile.sugar_block.name=Block of Sugar
|
||||||
tile.enchanted_torch.name=Stone Lamp
|
tile.enchanted_torch.name=Stone Lamp
|
||||||
|
|
||||||
item.cloud_matter.name=Lump of Cloud
|
item.cloud_matter.name=Lump of Cloud
|
||||||
item.cloud.small.name=Bucking Bronco
|
item.racing_cloud_spawner.name=Racing Cloud
|
||||||
item.cloud.medium.name=Construction Cloud
|
item.construction_cloud_spawner.name=Construction Cloud
|
||||||
item.cloud.large.name=Wild Cloud
|
item.wild_cloud_spawner.name=Wild Cloud
|
||||||
|
|
||||||
item.mist_door.name=Cloud Door
|
item.mist_door.name=Cloud Door
|
||||||
item.library_door.name=Dutch Library Door
|
item.library_door.name=Dutch Library Door
|
||||||
|
@ -140,11 +140,11 @@ item.zap_apple.zap.name=Cooked Zap Apple
|
||||||
item.apple_seeds.name=Apple Seeds
|
item.apple_seeds.name=Apple Seeds
|
||||||
|
|
||||||
item.tomato.name=Tomato
|
item.tomato.name=Tomato
|
||||||
item.tomato.rotten.name=Rotten Tomato
|
item.rotten_tomato.name=Rotten Tomato
|
||||||
item.tomato_seeds.name=Tomato Seeds
|
item.tomato_seeds.name=Tomato Seeds
|
||||||
|
|
||||||
item.cloudsdale_tomato.name=Cloudsdale Tomato
|
item.cloudsdale_tomato.name=Cloudsdale Tomato
|
||||||
item.cloudsdale_tomato.rotten.name=Rotten Cloudsdale Tomato
|
item.rotten_cloudsdale_tomato.name=Rotten Cloudsdale Tomato
|
||||||
|
|
||||||
item.alfalfa_leaves.name=Alfalfa
|
item.alfalfa_leaves.name=Alfalfa
|
||||||
item.alfalfa_seeds.name=Grain
|
item.alfalfa_seeds.name=Grain
|
||||||
|
|
|
@ -13,5 +13,5 @@
|
||||||
{ "item": "unicopia:cloud_matter" }
|
{ "item": "unicopia:cloud_matter" }
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"result": { "item": "unicopia:cloud", "data": 1, "count": 1 }
|
"result": { "item": "unicopia:construction_cloud_spawner", "count": 1 }
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,5 +12,5 @@
|
||||||
{ "item": "unicopia:cloud_matter" }
|
{ "item": "unicopia:cloud_matter" }
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"result": { "item": "unicopia:cloud", "data": 0, "count": 1 }
|
"result": { "item": "unicopia:racing_cloud_spawner", "count": 1 }
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,5 +10,5 @@
|
||||||
{ "item": "unicopia:cloud_block" }
|
{ "item": "unicopia:cloud_block" }
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"result": { "item": "unicopia:cloud", "data": 2, "count": 1 }
|
"result": { "item": "unicopia:wild_cloud_spawner", "count": 1 }
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue