2013-12-27 23:59:59 +01:00
|
|
|
package appeng.core.features.registries;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.Map.Entry;
|
|
|
|
|
2014-02-09 02:34:52 +01:00
|
|
|
import net.minecraft.init.Blocks;
|
|
|
|
import net.minecraft.init.Items;
|
2013-12-27 23:59:59 +01:00
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import appeng.api.features.IGrinderEntry;
|
|
|
|
import appeng.api.features.IGrinderRegistry;
|
|
|
|
import appeng.core.AELog;
|
2014-02-09 06:08:27 +01:00
|
|
|
import appeng.core.AEConfig;
|
2013-12-27 23:59:59 +01:00
|
|
|
import appeng.core.features.registries.entries.AppEngGrinderRecipe;
|
|
|
|
import appeng.recipes.ores.IOreListener;
|
|
|
|
import appeng.recipes.ores.OreDictionaryHandler;
|
|
|
|
import appeng.util.Platform;
|
|
|
|
|
|
|
|
public class GrinderRecipeManager implements IGrinderRegistry, IOreListener
|
|
|
|
{
|
|
|
|
|
|
|
|
public List<IGrinderEntry> RecipeList;
|
|
|
|
|
|
|
|
private ItemStack copy(ItemStack is)
|
|
|
|
{
|
|
|
|
if ( is != null )
|
|
|
|
return is.copy();
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public GrinderRecipeManager() {
|
|
|
|
RecipeList = new ArrayList();
|
|
|
|
|
2014-02-09 02:34:52 +01:00
|
|
|
addOre( "Coal", new ItemStack( Items.coal ) );
|
|
|
|
addOre( "Charcoal", new ItemStack( Items.coal, 1, 1 ) );
|
2014-01-30 03:47:55 +01:00
|
|
|
|
2014-02-09 02:34:52 +01:00
|
|
|
addOre( "NetherQuartz", new ItemStack( Blocks.quartz_ore ) );
|
|
|
|
addIngot( "NetherQuartz", new ItemStack( Items.quartz ) );
|
2014-01-30 03:47:55 +01:00
|
|
|
|
2014-02-09 02:34:52 +01:00
|
|
|
addOre( "Gold", new ItemStack( Blocks.gold_ore ) );
|
|
|
|
addIngot( "Gold", new ItemStack( Items.gold_ingot ) );
|
2014-01-30 03:47:55 +01:00
|
|
|
|
2014-02-09 02:34:52 +01:00
|
|
|
addOre( "Iron", new ItemStack( Blocks.iron_ore ) );
|
|
|
|
addIngot( "Iron", new ItemStack( Items.iron_ingot ) );
|
2014-01-30 03:47:55 +01:00
|
|
|
|
2014-02-09 02:34:52 +01:00
|
|
|
addOre( "Obsidian", new ItemStack( Blocks.obsidian ) );
|
|
|
|
addIngot( "Ender", new ItemStack( Items.ender_pearl ) );
|
2014-01-30 03:47:55 +01:00
|
|
|
|
2014-02-09 02:34:52 +01:00
|
|
|
addIngot( "Wheat", new ItemStack( Items.wheat ) );
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
OreDictionaryHandler.instance.observe( this );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public List<IGrinderEntry> getRecipes()
|
|
|
|
{
|
|
|
|
log( "API - getRecipes" );
|
|
|
|
return RecipeList;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void addRecipe(ItemStack in, ItemStack out, int cost)
|
|
|
|
{
|
|
|
|
if ( in == null || out == null )
|
|
|
|
{
|
|
|
|
log( "Invalid Grinder Recipe Specified." );
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-01-30 03:47:55 +01:00
|
|
|
log( "Allow Grinding of " + Platform.getItemDisplayName( in ) + " to " + Platform.getItemDisplayName( out ) + " for " + cost );
|
2013-12-27 23:59:59 +01:00
|
|
|
RecipeList.add( new AppEngGrinderRecipe( copy( in ), copy( out ), cost ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void addRecipe(ItemStack in, ItemStack out, ItemStack optional, float chance, int cost)
|
|
|
|
{
|
|
|
|
if ( in == null || (optional == null && out == null) )
|
|
|
|
{
|
|
|
|
log( "Invalid Grinder Recipe Specified." );
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-01-30 03:47:55 +01:00
|
|
|
log( "Allow Grinding of " + Platform.getItemDisplayName( in ) + " to " + Platform.getItemDisplayName( out ) + " with optional "
|
|
|
|
+ Platform.getItemDisplayName( optional ) + " for " + cost );
|
2013-12-27 23:59:59 +01:00
|
|
|
RecipeList.add( new AppEngGrinderRecipe( copy( in ), copy( out ), copy( optional ), chance, cost ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public IGrinderEntry getRecipeForInput(ItemStack input)
|
|
|
|
{
|
|
|
|
log( "Looking up recipe for " + Platform.getItemDisplayName( input ) );
|
|
|
|
if ( input != null )
|
|
|
|
{
|
|
|
|
for (IGrinderEntry r : RecipeList)
|
|
|
|
{
|
|
|
|
if ( Platform.isSameItem( input, r.getInput() ) )
|
|
|
|
{
|
|
|
|
log( "Recipe for " + input.getUnlocalizedName() + " found " + Platform.getItemDisplayName( r.getOutput() ) );
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
log( "Count not find recipe for " + Platform.getItemDisplayName( input ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void log(String o)
|
|
|
|
{
|
|
|
|
AELog.grinder( o );
|
|
|
|
}
|
|
|
|
|
|
|
|
private int getDustToOreRatio(String name)
|
|
|
|
{
|
|
|
|
if ( name.equals( "Obsidian" ) )
|
|
|
|
return 1;
|
|
|
|
if ( name.equals( "Charcoal" ) )
|
|
|
|
return 1;
|
|
|
|
if ( name.equals( "Coal" ) )
|
|
|
|
return 1;
|
|
|
|
return 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
public Map<ItemStack, String> Ores = new HashMap<ItemStack, String>();
|
|
|
|
public Map<ItemStack, String> Ingots = new HashMap<ItemStack, String>();
|
|
|
|
public Map<String, ItemStack> Dusts = new HashMap<String, ItemStack>();
|
|
|
|
|
|
|
|
private void addOre(String name, ItemStack item)
|
|
|
|
{
|
|
|
|
if ( item == null )
|
|
|
|
return;
|
|
|
|
log( "Adding Ore - " + name + " : " + Platform.getItemDisplayName( item ) );
|
|
|
|
|
|
|
|
Ores.put( item, name );
|
|
|
|
|
|
|
|
if ( Dusts.containsKey( name ) )
|
|
|
|
{
|
|
|
|
ItemStack is = Dusts.get( name ).copy();
|
|
|
|
int ratio = getDustToOreRatio( name );
|
|
|
|
if ( ratio > 1 )
|
|
|
|
{
|
|
|
|
ItemStack extra = is.copy();
|
|
|
|
extra.stackSize = ratio - 1;
|
2014-02-09 06:08:27 +01:00
|
|
|
addRecipe( item, is, extra, (float) (AEConfig.instance.oreDoublePercentage / 100.0), 8 );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
addRecipe( item, is, 8 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void addIngot(String name, ItemStack item)
|
|
|
|
{
|
|
|
|
if ( item == null )
|
|
|
|
return;
|
|
|
|
log( "Adding Ingot - " + name + " : " + Platform.getItemDisplayName( item ) );
|
|
|
|
|
|
|
|
Ingots.put( item, name );
|
|
|
|
|
|
|
|
if ( Dusts.containsKey( name ) )
|
|
|
|
{
|
|
|
|
addRecipe( item, Dusts.get( name ), 4 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void addDust(String name, ItemStack item)
|
|
|
|
{
|
|
|
|
if ( item == null )
|
|
|
|
return;
|
|
|
|
if ( Dusts.containsKey( name ) )
|
|
|
|
{
|
|
|
|
log( "Rejecting Dust - " + name + " : " + Platform.getItemDisplayName( item ) );
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
log( "Adding Dust - " + name + " : " + Platform.getItemDisplayName( item ) );
|
|
|
|
|
|
|
|
Dusts.put( name, item );
|
|
|
|
|
|
|
|
for (Entry<ItemStack, String> d : Ores.entrySet())
|
|
|
|
if ( name.equals( d.getValue() ) )
|
|
|
|
{
|
|
|
|
ItemStack is = item.copy();
|
|
|
|
is.stackSize = 1;
|
|
|
|
int ratio = getDustToOreRatio( name );
|
|
|
|
if ( ratio > 1 )
|
|
|
|
{
|
|
|
|
ItemStack extra = is.copy();
|
|
|
|
extra.stackSize = ratio - 1;
|
2014-02-09 06:08:27 +01:00
|
|
|
addRecipe( d.getKey(), is, extra, (float) (AEConfig.instance.oreDoublePercentage / 100.0), 8 );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
addRecipe( d.getKey(), is, 8 );
|
|
|
|
}
|
|
|
|
|
|
|
|
for (Entry<ItemStack, String> d : Ingots.entrySet())
|
|
|
|
if ( name.equals( d.getValue() ) )
|
|
|
|
addRecipe( d.getKey(), item, 4 );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void oreRegistered(String Name, ItemStack item)
|
|
|
|
{
|
2014-01-30 03:47:55 +01:00
|
|
|
if ( Name.startsWith( "ore" ) || Name.startsWith( "crystal" ) || Name.startsWith( "ingot" ) || Name.startsWith( "dust" ) )
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
2014-02-09 06:08:27 +01:00
|
|
|
for (String ore : AEConfig.instance.grinderOres)
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
|
|
|
if ( Name.equals( "ore" + ore ) )
|
|
|
|
{
|
|
|
|
addOre( ore, item );
|
|
|
|
}
|
2014-01-30 03:47:55 +01:00
|
|
|
else if ( Name.equals( "crystal" + ore ) )
|
|
|
|
{
|
|
|
|
addIngot( ore, item );
|
|
|
|
}
|
2013-12-27 23:59:59 +01:00
|
|
|
else if ( Name.equals( "ingot" + ore ) )
|
|
|
|
{
|
|
|
|
addIngot( ore, item );
|
|
|
|
}
|
|
|
|
else if ( Name.equals( "dust" + ore ) )
|
|
|
|
{
|
|
|
|
addDust( ore, item );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|