aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/gregtech/loaders/oreprocessing
diff options
context:
space:
mode:
authorNotAPenguin <michiel.vandeginste@gmail.com>2024-08-03 23:21:44 +0200
committerGitHub <noreply@github.com>2024-08-03 23:21:44 +0200
commitb65ace37de4f585b8089ad413ee877b792da11ca (patch)
tree2e0445785c5008df15151f729da148fb70dbc21d /src/main/java/gregtech/loaders/oreprocessing
parente180e49fc6305f71b1f1b18141b946f794a7012b (diff)
downloadGT5-Unofficial-b65ace37de4f585b8089ad413ee877b792da11ca.tar.gz
GT5-Unofficial-b65ace37de4f585b8089ad413ee877b792da11ca.tar.bz2
GT5-Unofficial-b65ace37de4f585b8089ad413ee877b792da11ca.zip
Waterline rework (#2577)
* Add barebones PurificationPlant class * Make simple 3x3 structure to form purification plant * Add base purification unit class and dummy sifter unit MTE * Make sifter unit form * Fix accidental wildcard import * Implement basic linking of units to controller using data stick * Make linking more robust, save bidirectional links, add scanner output * add linking range, error message and unregister old controller when re-linking * Add link status of purification units to waila body * Disable maintenance issues on purification plant units * spotless * Check structure of linked purification units in main controller * Remove all star imports * Small refactor to avoid updating status from main controller * spotless * Attempt to document current code * Convert some comments to javadoc * Implement basic processing cycle, sync it with linked purification units * Make water purification plant drain power * Calculate power drain from active units and remove controller power drain * spotless * Add very barebones recipemap * Fix recipemap name in lang file * spotless * Fix purification unit recipemap name * spotless * more sane amount of max fluid outputs * add some item outputs to sifter unit * Very simple recipe processing, may be buggy * spotless * Implement recipe failure * Implement void protection for purification units * spotless * buff item output odds slightly * Add WIP grade 1 structure * spotless * Store base success chance in recipe metadata and display it in NEI * Fill sifter plant with water * Add comment * Allow construction sifter unit in survival * Implement water boost * Fix water boost allowing output chance to go over 100% * Implement failed recipes outputting lower tier water * Fix typo * Fix deformed purification unit still drawing power * Slightly refactor recipe check so base class can read result * Create empty ModularUI container for purification plant * The great gui struggle part 1 * More gui struggles, we have a button now * Adjust button text and size * gui wars: the rise of the sync * gui wars: a new hope * fix the sync * is pengu old enough to know exceeder? * Fix being able to link the same unit multiple times * Sync status string to client * Sign sifter with my name * Show status somewhat properly * Adjust sifter base chance and structure * Fully implement sifter unit * More tooltip refactoring * Add structure info to sifter tooltip. * nitpicking tooltips * Adding sound to Purification Plant Main Unit. * fix star imports * Add basic coagulator unit, add recipemap for it * Write coagulator tooltip * comma nitpicking * more tooltip work * small refactor to purification plant controller * start work on custom recipemap frontend * Fully implement coagulator * Update structure requirements in tooltips * Move controller text in structure tooltips to be consistent * fix NPE on world load * Add base ph adjustment unit MTE * Add info to main controller and energy hatch check * Fixing tooltip of Main Controller & Energy/Exotic Hatch check. * Create full pH adjustment structure * disallow any voiding on purification unit * Small custom RecipeMap frontend for ph adjustment * Generate random initial pH value * Implement inserting NaOH and HCl to adjust pH * Add easter egg * Implement pH sensor hatch * Properly consume HCl and round pH value to 2 digits * Write ph adjustment unit tooltip * Tooltip nitpicking * Try to fix some structurelib hints * More trying to fix hints * Add industrial strength concrete casing block * Add water loop sound to the game * Document random initial pH in tooltip * Add glass material base * Fix spotless formatting in Textures docs because I cannot take it anymore * Add glass texture * Try adding transparent glass * Transparent glass working * Create pH resistant glass and update pH structure to use it * Create full structure for main purification plant * Create custom water purification casing block * Properly balance ferrous wastewater reprocessing and reduce input by a factor 10 * Add pH factor to NEI tooltip and fix coagulator structure * Structure tooltip for Purification Plant base * Add GT_Block_Glass2 and properly set maxMeta * Add Tinted Industrial Glass blocks * Fix BlockCasing9 not showing custom tooltip * Register tinted glass as EV glass * Add sterile water plant casing and revert tooltip change * Mention required water in sifter tooltip * Add more textures and casings * Add more textures, sounds and add structure info for pH adjustment * Rename sifter unit to clarifier * Rename coagulation unit to flocculation unit * Add activated carbon line * Fix unintended activated carbon recipe * Add activated carbon filter * Add polyaluminium chloride + solution * Add new custom textures by @BlueHero233 * Wip recipe page with new background for flocculation * Fix flocculation background image mostly * Finally aligned the slots * angery mumbles * Finish flocculation recipe page * All the recipe pages! * Add new reworked textures * Fix ph adjustment being t3 instead of t4 * Fix invisible casing * apply chembalance to polyaluminium chloride properly * Fix ferrous wastewater -> flocculation waste liquid * Move flocculation to grade 3 * create ozonation unit with placeholder blocks * add new blocks for ozonation with placeholder textures * Add water to ozonation structure * Create ozone gas material * Add ozone recipe * Add textures for ozone unit * Add sound loop for ozonation * fix * implement ozonation mechanics * Finalize ozonation tooltip * Create dummy plasma heater multi * Update textures for plasma heater * Add grade 5 recipemap * Add hatches to plasma heater multi * Add basic plasma heating unit variables * Implement plasma heating unit mechanics * Add plasma heater tooltip * Add structure info to plasma heater tooltip * fix ozonation tooltip, add frontend * Fix positioning on ozonation tooltip and fix plasma heater crash * Add UV treatment MTE and structure without textures * Revert accidental addition of debug dependencies * Add initial version of uv unit textures * update naquadria casing, add water color gradient * Some minor cleanup and added docs * Create lens housing bus * Add lens bus to UV treatment unit * Add lens indicator hatch * Merge GT_MetaGeneratedItem_03.java * Add lens indicator hatch * Add the lens cycle, uv treatment recipe map and fix eut of flocculation recipe * Implement lens swapping mechanic * Clean up first lens swap * Fix uv recipemap lang and move lens cycle to recipe * Write uv treatment tooltip * Add sounds for uv and plasma steps * Create empty degasifier class * Create temporary debug structure for degasifier * set temp casing index for degasifier * create degasifier control hatch * create slightly less temporary but still temporary structure for degasifier * Start impl of degasifier * fix fluid consumption and nbt loading of degasifier * Degasifier implementation should work now * Rename and reformat some things and start work on degasser tooltiop * give last bit much lower chance of being on to avoid cheesing * Finish degasifier tooltip * Integrate some deleno lore * hopefully fix all moved casing meta ids after merge * Create finalized degasser structure * Integrate more deleno lore * Add even more lore * Create placeholder particle catalysts and fetch particle items from gt++ * Fix wrong casing and recipemap localization * Create parallel config menu * refactor purification recipecheck slightly * implement parallel amount on water i/o and power * add tooltip info about parallel config * fix text * update block names in structure tooltips * create structure tooltip for degasser * create textureless quark catalyst items * add the purple glass * fix lore typos * fix some casing indices * remove concrete floor from water plant and reword tooltip * fix main plant structure and add placeholder structure for t8 step * fix structurecheck for main plant and add random catalyst generation for t8 * implement basic mechanics for particle extractor (wip) * Create plasma heater frontend * implement final mechanics and bugfixes for particle extractor * add recipes for re-aligning quark catalysts * add simple recipes for catalyst alignment * initial replacement of purified water in engraver recipes * add purified water to all wafer cutting recipes * fix purified water amounts * buff quark cyclotron recipe again * extract t8 unit casings into their own icons * Write initial tooltip for t8 module * add purified water to mask recipes * Add recipe comparator to show low tier purified water recipes first * add min casing check to waterline multis * buff ozone production * update t8 structure * make purified water optional again for naq wafers * Fix blockrenderer for purification plant * fix nei previews * fix nei * really fix nei this time * add t8 lore * fix hatch recipe locking blocking automation on some steps * try to solve weirdness with grade 3 recipe * fix issues with recipecheck * fix missing null check * make ph sensor use a strict inequality check * fix min casings on t5 * significantly nerf purified water usage for beamline masks * disable void protection for waterline * small adjustments to t6 unit * more small adjustments to t6 unit to prevent easy automation cheese * fix degasser redstone output and missing return statement * remove water QFT catalyst recipes --------- Co-authored-by: Tianyou Mei <meitianyou94@gmail.com> Co-authored-by: OlliedeLeeuw <ollie.riemersma@xs4all.nl> Co-authored-by: Ollie_de_Leeuw <154506304+OlliedeLeeuw@users.noreply.github.com> Co-authored-by: Martin Robertz <dream-master@gmx.net>
Diffstat (limited to 'src/main/java/gregtech/loaders/oreprocessing')
-rw-r--r--src/main/java/gregtech/loaders/oreprocessing/ProcessingCrafting.java65
1 files changed, 33 insertions, 32 deletions
diff --git a/src/main/java/gregtech/loaders/oreprocessing/ProcessingCrafting.java b/src/main/java/gregtech/loaders/oreprocessing/ProcessingCrafting.java
index 438da254a2..200ce743c9 100644
--- a/src/main/java/gregtech/loaders/oreprocessing/ProcessingCrafting.java
+++ b/src/main/java/gregtech/loaders/oreprocessing/ProcessingCrafting.java
@@ -8,6 +8,7 @@ import static gregtech.api.recipe.RecipeMaps.laserEngraverRecipes;
import static gregtech.api.util.GT_RecipeBuilder.MINUTES;
import static gregtech.api.util.GT_RecipeBuilder.SECONDS;
import static gregtech.api.util.GT_RecipeBuilder.TICKS;
+import static gregtech.api.util.GT_RecipeConstants.WaferEngravingRecipes;
import net.minecraft.init.Blocks;
import net.minecraft.item.ItemStack;
@@ -83,7 +84,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(60 * SECONDS)
.eut(TierEU.RECIPE_HV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer3.get(1), GT_Utility.copyAmount(0, aStack))
@@ -91,7 +92,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(40 * SECONDS)
.eut(TierEU.RECIPE_EV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer5.get(1), GT_Utility.copyAmount(0, aStack))
@@ -99,7 +100,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(2 * MINUTES)
.eut(TierEU.RECIPE_UV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
}
case "craftingLensYellow" -> {
@@ -127,7 +128,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.itemOutputs(ItemList.Circuit_Wafer_LPIC.get(1))
.duration(40 * SECONDS)
.eut(TierEU.RECIPE_MV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer2.get(1), GT_Utility.copyAmount(0, aStack))
@@ -135,7 +136,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(30 * SECONDS)
.eut(TierEU.RECIPE_HV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer3.get(1), GT_Utility.copyAmount(0, aStack))
@@ -143,7 +144,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(45 * SECONDS)
.eut(TierEU.RECIPE_EV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer4.get(1), GT_Utility.copyAmount(0, aStack))
@@ -151,7 +152,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(30 * SECONDS)
.eut(TierEU.RECIPE_IV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer5.get(1), GT_Utility.copyAmount(0, aStack))
@@ -159,7 +160,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(15 * SECONDS)
.eut(TierEU.RECIPE_LuV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
}
case "craftingLensOrange" -> {
@@ -168,28 +169,28 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.itemOutputs(ItemList.Circuit_Wafer_Simple_SoC.get(1))
.duration(15 * SECONDS)
.eut(64)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer2.get(1), GT_Utility.copyAmount(0, aStack))
.itemOutputs(ItemList.Circuit_Wafer_Simple_SoC.get(4))
.duration(15 * SECONDS)
.eut(256)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer3.get(1), GT_Utility.copyAmount(0, aStack))
.itemOutputs(ItemList.Circuit_Wafer_Simple_SoC.get(16))
.duration(15 * SECONDS)
.eut(1024)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer4.get(1), GT_Utility.copyAmount(0, aStack))
.itemOutputs(ItemList.Circuit_Wafer_Simple_SoC.get(64))
.duration(15 * SECONDS)
.eut(4096)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
}
case "craftingLensCyan" -> {
@@ -217,7 +218,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.itemOutputs(ItemList.Circuit_Wafer_Ram.get(1))
.duration(60 * SECONDS)
.eut(TierEU.RECIPE_MV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer2.get(1), GT_Utility.copyAmount(0, aStack))
@@ -225,7 +226,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(45 * SECONDS)
.eut(TierEU.RECIPE_HV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer3.get(1), GT_Utility.copyAmount(0, aStack))
@@ -233,7 +234,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(30 * SECONDS)
.eut(TierEU.RECIPE_EV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer4.get(1), GT_Utility.copyAmount(0, aStack))
@@ -241,7 +242,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(15 * SECONDS)
.eut(TierEU.RECIPE_IV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer5.get(1), GT_Utility.copyAmount(0, aStack))
@@ -249,7 +250,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(7 * SECONDS + 10 * TICKS)
.eut(TierEU.RECIPE_LuV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
}
case "craftingLensRed" -> {
@@ -277,7 +278,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.itemOutputs(ItemList.Circuit_Wafer_ILC.get(1))
.duration(60 * SECONDS)
.eut(TierEU.RECIPE_MV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer2.get(1), GT_Utility.copyAmount(0, aStack))
@@ -285,7 +286,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(45 * SECONDS)
.eut(TierEU.RECIPE_HV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer3.get(1), GT_Utility.copyAmount(0, aStack))
@@ -293,7 +294,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(30 * SECONDS)
.eut(TierEU.RECIPE_EV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer4.get(1), GT_Utility.copyAmount(0, aStack))
@@ -301,7 +302,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(1 * MINUTES + 30 * SECONDS)
.eut(TierEU.RECIPE_LuV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer5.get(1), GT_Utility.copyAmount(0, aStack))
@@ -309,7 +310,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(1 * MINUTES + 15 * SECONDS)
.eut(TierEU.RECIPE_ZPM)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
}
case "craftingLensGreen" -> {
@@ -335,14 +336,14 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.itemOutputs(ItemList.Circuit_Wafer_ULPIC.get(2))
.duration(30 * SECONDS)
.eut(30)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer2.get(1), GT_Utility.copyAmount(0, aStack))
.itemOutputs(ItemList.Circuit_Wafer_ULPIC.get(8))
.duration(30 * SECONDS)
.eut(TierEU.RECIPE_MV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer3.get(1), GT_Utility.copyAmount(0, aStack))
@@ -350,7 +351,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(1 * MINUTES + 30 * SECONDS)
.eut(TierEU.RECIPE_EV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer4.get(1), GT_Utility.copyAmount(0, aStack))
@@ -358,7 +359,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(1 * MINUTES + 15 * SECONDS)
.eut(TierEU.RECIPE_IV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer5.get(1), GT_Utility.copyAmount(0, aStack))
@@ -366,7 +367,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(60 * SECONDS)
.eut(TierEU.RECIPE_LuV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
}
case "craftingLensWhite" -> {
@@ -424,7 +425,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(60 * SECONDS)
.eut(TierEU.RECIPE_MV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer2.get(1), GT_Utility.copyAmount(0, aStack))
@@ -432,7 +433,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(45 * SECONDS)
.eut(TierEU.RECIPE_HV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer3.get(1), GT_Utility.copyAmount(0, aStack))
@@ -440,7 +441,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(30 * SECONDS)
.eut(TierEU.RECIPE_EV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer4.get(1), GT_Utility.copyAmount(0, aStack))
@@ -448,7 +449,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(15 * SECONDS)
.eut(TierEU.RECIPE_IV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
GT_Values.RA.stdBuilder()
.itemInputs(ItemList.Circuit_Silicon_Wafer5.get(1), GT_Utility.copyAmount(0, aStack))
@@ -456,7 +457,7 @@ public class ProcessingCrafting implements gregtech.api.interfaces.IOreRecipeReg
.requiresCleanRoom()
.duration(7 * SECONDS + 10 * TICKS)
.eut(TierEU.RECIPE_LuV)
- .addTo(laserEngraverRecipes);
+ .addTo(WaferEngravingRecipes);
}
}