aboutsummaryrefslogtreecommitdiff
path: root/src/Java/gtPlusPlus/xmod/gregtech/loaders/misc/WoodCentrifuging.java
blob: 2d7cd1b73b8ee64c3afabcb89ead2fb6df9033aa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package gtPlusPlus.xmod.gregtech.loaders.misc;

import java.util.ArrayList;

import gregtech.api.enums.GT_Values;
import gregtech.api.enums.ItemList;
import gregtech.api.enums.Materials;
import gregtech.api.enums.OrePrefixes;
import gregtech.api.util.GT_ModHandler;
import gregtech.api.util.GT_OreDictUnificator;
import gregtech.api.util.GT_Recipe;
import gregtech.api.util.GT_Utility;
import gtPlusPlus.api.objects.Logger;
import gtPlusPlus.core.util.minecraft.ItemUtils;
import net.minecraft.item.ItemStack;
import net.minecraftforge.oredict.OreDictionary;

public class WoodCentrifuging {

	private static final ArrayList<ItemStack> aLogData;
	private static final ArrayList<ItemStack> aRubberLogs;
	private static final ArrayList<ItemStack> aRubberLogs2;
	
	static {
		aLogData = OreDictionary.getOres("logWood");
		aRubberLogs = OreDictionary.getOres("logRubber");
		aRubberLogs2 = OreDictionary.getOres("woodRubber");
	}
	
	private static boolean isNormalLog(ItemStack aStack) {
		if (aLogData.contains(aStack) & !isRubberLog(aStack)) {
			return true;
		}
		return false;
	}
	
	private static boolean isRubberLog(ItemStack aStack) {
		if (aRubberLogs.contains(aStack)) {
			return true;
		}
		else if (aRubberLogs2.contains(aStack)) {
			return true;
		}		
		return false;
	}
	

	private static boolean addCentrifugeRecipe(ItemStack aStack) {
		if (isNormalLog(aStack)) {
			return addNormalLogCentrifugeRecipe(aStack);
		}
		else if (isRubberLog(aStack)) {
			return addRubberLogCentrifugeRecipe(aStack);			
		}
		return false;
	}

	private static boolean addNormalLogCentrifugeRecipe(ItemStack aStack) {
		GT_Recipe aFoundRecipe = GT_Recipe.GT_Recipe_Map.sCentrifugeRecipes.findRecipe(null, false, gregtech.api.enums.GT_Values.V[1], null, new ItemStack[]{aStack});
		if (aFoundRecipe == null && GT_Values.RA.addCentrifugeRecipe(GT_Utility.copyAmount(1L, aStack), null, null, Materials.Methane.getGas(60L), GT_Values.NI, GT_Values.NI, GT_Values.NI, GT_Values.NI, GT_Values.NI, GT_Values.NI, null, 200, 20)) {
			Logger.INFO("Added methane extraction for "+ItemUtils.getItemName(aStack));	
			return true;
		}
		return false;
	}
	private static boolean addRubberLogCentrifugeRecipe(ItemStack aStack) {
		GT_Recipe aFoundRecipe = GT_Recipe.GT_Recipe_Map.sCentrifugeRecipes.findRecipe(null, false, gregtech.api.enums.GT_Values.V[1], null, new ItemStack[]{aStack});
		if (aFoundRecipe == null && GT_Values.RA.addCentrifugeRecipe(GT_Utility.copyAmount(1L, aStack), null, null, Materials.Methane.getGas(60L), ItemList.IC2_Resin.get(1L, new Object[0]), GT_ModHandler.getIC2Item("plantBall", 1L), GT_OreDictUnificator.get(OrePrefixes.dust, Materials.Carbon, 1L), GT_OreDictUnificator.get(OrePrefixes.dust, Materials.Wood, 1L), null, null, new int[] { 5000, 3750, 2500, 2500 }, 200, 20)) {
			Logger.INFO("Added rubber plant based methane extraction for "+ItemUtils.getItemName(aStack));	
			return true;
		}
		return false;
	}
	
	public static void processLogsForMethane() {
		//Try use all woods found, fix/add methane extraction.
		if (!aLogData.isEmpty()) {
			Logger.INFO("Fixing Methane output of centrifuged logs.");
			for (ItemStack stack : aLogData) {				
				addCentrifugeRecipe(stack);
			}			
		}		
	}

}