rewrite the ore processing to be even less code, buff compatability for agricultural automation
This commit is contained in:
2
TODO.md
2
TODO.md
@ -31,4 +31,4 @@
|
|||||||
# mods todo:
|
# mods todo:
|
||||||
[x] remove coins
|
[x] remove coins
|
||||||
[x] remove refined storage
|
[x] remove refined storage
|
||||||
[x] remove create additions
|
[x] remove create additions
|
||||||
|
@ -44,6 +44,7 @@
|
|||||||
"forge:bread/{material}",
|
"forge:bread/{material}",
|
||||||
"forge:tomato_sauces",
|
"forge:tomato_sauces",
|
||||||
"forge:bacon",
|
"forge:bacon",
|
||||||
|
"forge:raw_bacon",
|
||||||
"forge:cheeseburgers",
|
"forge:cheeseburgers",
|
||||||
"forge:hamburgers",
|
"forge:hamburgers",
|
||||||
"forge:string",
|
"forge:string",
|
||||||
@ -56,7 +57,8 @@
|
|||||||
"forge:rubber",
|
"forge:rubber",
|
||||||
"forge:cardboard",
|
"forge:cardboard",
|
||||||
"forge:chocolate",
|
"forge:chocolate",
|
||||||
"forge:pasta"
|
"forge:pasta",
|
||||||
|
"forge:salad_ingredients/{material}"
|
||||||
],
|
],
|
||||||
"materials": [
|
"materials": [
|
||||||
"aeternium",
|
"aeternium",
|
||||||
@ -191,6 +193,7 @@
|
|||||||
"forge:cardboard": ["dustrial_decor:cardboard", "create:cardboard"],
|
"forge:cardboard": ["dustrial_decor:cardboard", "create:cardboard"],
|
||||||
"thermal:crafting/dies": ["ae2:silicon_press", "ae2:engineering_processor_press", "ae2:calculation_processor_press", "ae2:logic_processor_press"],
|
"thermal:crafting/dies": ["ae2:silicon_press", "ae2:engineering_processor_press", "ae2:calculation_processor_press", "ae2:logic_processor_press"],
|
||||||
"forge:ingots/andesite_alloy": ["create:andesite_alloy"],
|
"forge:ingots/andesite_alloy": ["create:andesite_alloy"],
|
||||||
|
"forge:storage_blocks/andesite_alloy": ["create:andesite_alloy_block"],
|
||||||
"forge:rods/andesite_alloy": ["create:shaft"],
|
"forge:rods/andesite_alloy": ["create:shaft"],
|
||||||
"forge:gears/andesite_alloy": ["create:cogwheel"],
|
"forge:gears/andesite_alloy": ["create:cogwheel"],
|
||||||
"forge:flour/wheat": ["croptopia:flour"],
|
"forge:flour/wheat": ["croptopia:flour"],
|
||||||
@ -205,7 +208,9 @@
|
|||||||
"forge:storage_blocks/lapium": ["powder_power:block_lapium"],
|
"forge:storage_blocks/lapium": ["powder_power:block_lapium"],
|
||||||
"forge:storage_blocks/gemium": ["powder_power:block_gemium"],
|
"forge:storage_blocks/gemium": ["powder_power:block_gemium"],
|
||||||
"forge:storage_blocks/trilium": ["powder_power:block_trilium"],
|
"forge:storage_blocks/trilium": ["powder_power:block_trilium"],
|
||||||
"forge:storage_blocks/quadrilium": ["powder_power:block_quadrilium"]
|
"forge:storage_blocks/quadrilium": ["powder_power:block_quadrilium"],
|
||||||
|
"forge:limestone": ["quark:limestone", "alexcaves:limestone", "create:limestone"],
|
||||||
|
"create:stone_types/limestone": ["quark:limestone", "alexcaves:limestone"]
|
||||||
},
|
},
|
||||||
"tagOwnerships": {
|
"tagOwnerships": {
|
||||||
"forge:crops/bell_pepper": ["forge:crops/bellpepper"],
|
"forge:crops/bell_pepper": ["forge:crops/bellpepper"],
|
||||||
|
30
index.toml
30
index.toml
@ -14,7 +14,7 @@ hash = "a60442351eb4a2fb2c74d4a7c62fd25d32faca43c0f192a1c261c13db9a71551"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "config/almostunified/unify.json"
|
file = "config/almostunified/unify.json"
|
||||||
hash = "fe3dba76719ae817115e2c8b6b428fe790f8724e33148b55148e6769bf4026c3"
|
hash = "1dce776168f1f6fc1d6db33035fb8aa71275d900f2726f0e8edd8551aa892200"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "config/apotheosis/adventure.cfg"
|
file = "config/apotheosis/adventure.cfg"
|
||||||
@ -555,19 +555,19 @@ hash = "a5e02c71fd92029ea204f96d071c6b25f59d03b59f65199cb24f96a1858b3ed0"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/grist/agricultural.js"
|
file = "kubejs/server_scripts/grist/agricultural.js"
|
||||||
hash = "b9952f3bf6160c133cbec0e604e56a3a9107149a52097b65777d532e4194b726"
|
hash = "65145ba119d067f34a207496f295c8fd63673723c9504637872f27ff0f78c566"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/grist/build.js"
|
file = "kubejs/server_scripts/grist/build.js"
|
||||||
hash = "775f56a6fb7ef4a00416aaed596d6d9898dbb0febdd902de665a11ca1ec4640e"
|
hash = "0cf8fc13970c924bc2491d3bdc06f139786820fe02e49995264b6cec75b05107"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/grist/energetic.js"
|
file = "kubejs/server_scripts/grist/energetic.js"
|
||||||
hash = "b89a43e5216126b188a5771f9dd45bc43d9292c9bdc92cfb6de3108d09559afc"
|
hash = "bfa1cb2d1ed46b921592c129fee680945f60e3f103f3f8ef38eef274c737fd29"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/grist/intelligent.js"
|
file = "kubejs/server_scripts/grist/intelligent.js"
|
||||||
hash = "99ad461391b378426f76c40d34661ed7640cc30cc356c9eb52b60e70b4da6426"
|
hash = "c0b4918e65c898df79ef88916448259936a7b1e0d7cee62912ecf801df804757"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/grist/primordeal.js"
|
file = "kubejs/server_scripts/grist/primordeal.js"
|
||||||
@ -579,7 +579,7 @@ hash = "0863a1d0a2d67ea44bd174fbe19642e73a3f85aae6bdeb12599e61f174079f2b"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/init.js"
|
file = "kubejs/server_scripts/init.js"
|
||||||
hash = "d103c3bb61fe22aa1f4ab6d866b1b0d24c47c2aa55f74018eaf460702043a66e"
|
hash = "a3be46580f9dbc584536293dc6e9a6b76583bb47069ae00d2af75583766f0438"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/malloc-balance.js"
|
file = "kubejs/server_scripts/malloc-balance.js"
|
||||||
@ -587,7 +587,7 @@ hash = "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/ae2.js"
|
file = "kubejs/server_scripts/mods/ae2.js"
|
||||||
hash = "4dacad5d914c02db31c80e40d7edab7fee89a817444e2f75858209278f9be446"
|
hash = "b0fe6b78daf76938f90ba1cb76f79079c26b01e6ed612b151d81a5d839b580e9"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/apotheosis.js"
|
file = "kubejs/server_scripts/mods/apotheosis.js"
|
||||||
@ -627,11 +627,7 @@ hash = "4717847a6d54f56ed6919a1e2c3591fc73780973708e818a563753132bc7c15e"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/create.js"
|
file = "kubejs/server_scripts/mods/create.js"
|
||||||
hash = "2989241678e27da372401bb66e10b412697b563b2fb8185a380dc3f62cefcd82"
|
hash = "37b42afa67f643e56d3ff664cf5a9413d97bbff5fe42fc6ed84ef5cf06d7e320"
|
||||||
|
|
||||||
[[files]]
|
|
||||||
file = "kubejs/server_scripts/mods/create_enchantment_industry.js"
|
|
||||||
hash = "348f8ca4b328d6ef054d05914b3fffbf1b6813de776cfb44e6eac0ebd14c4c40"
|
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/create_jetpack.js"
|
file = "kubejs/server_scripts/mods/create_jetpack.js"
|
||||||
@ -647,7 +643,7 @@ hash = "99c87081cbcba79e032cf8c33c5bf9ff032e841da349c1fc720048711b064584"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/croptopia.js"
|
file = "kubejs/server_scripts/mods/croptopia.js"
|
||||||
hash = "26d4be6f4fdd3b276c214eaef8e467ecf12c8a25f61e0d4c30d08e6e395b4e66"
|
hash = "7d09c5eec356309a58d915dbe77e901e4c72679eae95657a5c0dd371b9c9e747"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/darkutils.js"
|
file = "kubejs/server_scripts/mods/darkutils.js"
|
||||||
@ -735,7 +731,7 @@ hash = "d37bfb9bc41aa46d0aa075dbe19a5eeb947b4ea3d8f13c03ac370cb00763d7a1"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/thermal.js"
|
file = "kubejs/server_scripts/mods/thermal.js"
|
||||||
hash = "b81ffc5905fe81de8d66015b0814714a8db8ecb6a4a2d927e600b328665c617a"
|
hash = "181bca8e5f6daabd6b42090276f48b823afec2fae37f0f3317fd76f9456a5c4e"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/torchmaster.js"
|
file = "kubejs/server_scripts/mods/torchmaster.js"
|
||||||
@ -743,7 +739,7 @@ hash = "9eed24eaac1d6016fc1d99bcb7259900e430afd674db47c52df89e5cdb6e1317"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/vinery.js"
|
file = "kubejs/server_scripts/mods/vinery.js"
|
||||||
hash = "208d9d49c612c84f57ee509ec02d4c44145b673caaa06fe451340dc30b8da5aa"
|
hash = "b24325803c78a586a2516a593456c43156b4e7b5d63a9388a3d7476fe06f5417"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/mods/waystones.js"
|
file = "kubejs/server_scripts/mods/waystones.js"
|
||||||
@ -755,7 +751,7 @@ hash = "4003082f31011049402ff31504a6db0f4fdd6c7076167109c66fa412286be462"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/ore-processing.js"
|
file = "kubejs/server_scripts/ore-processing.js"
|
||||||
hash = "bb085e326aa85a8c8e86aac25f1a2a2c7fe53ebacb74d5de44b34769c73dc3e1"
|
hash = "d6b083214ed67a511b60348e7955c69513ca9380b1aee351a47301eeef28ff60"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/server_scripts/progression/report.js"
|
file = "kubejs/server_scripts/progression/report.js"
|
||||||
@ -787,7 +783,7 @@ hash = "eda5964bf26b3ea17ab806944e79c16007e525da8f3ba4d6222dcbb0437f9f90"
|
|||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "kubejs/startup_scripts/rarities.js"
|
file = "kubejs/startup_scripts/rarities.js"
|
||||||
hash = "1d53f63b8caab6f49d80b953546eb12a85af70a549e7e6f9cdacfa27d76e8609"
|
hash = "c41670ee6003d8151508fe9a35931a42765390a126fc4c9afb285edffa153892"
|
||||||
|
|
||||||
[[files]]
|
[[files]]
|
||||||
file = "mods/ae2-things-forge.pw.toml"
|
file = "mods/ae2-things-forge.pw.toml"
|
||||||
|
@ -120,10 +120,10 @@ ServerEvents.recipes(event => {
|
|||||||
ingredients: [
|
ingredients: [
|
||||||
{item: 'kubejs:grist_primordeal_improved_block'},
|
{item: 'kubejs:grist_primordeal_improved_block'},
|
||||||
{tag: 'kubejs:grist/agricultural/improved'},
|
{tag: 'kubejs:grist/agricultural/improved'},
|
||||||
{item: 'kubejs:grist_primordeal_improved_block'},
|
{tag: 'forge:tomato_sauces'},
|
||||||
{tag: 'kubejs:grist/agricultural/improved'},
|
{item: 'minecraft:rotten_flesh'},
|
||||||
],
|
],
|
||||||
result: {item: 'kubejs:grist_agricultural_improved', count: 4}
|
result: {item: 'kubejs:grist_agricultural_improved_block'}
|
||||||
});
|
});
|
||||||
event.custom({
|
event.custom({
|
||||||
type: 'farmersdelight:cooking',
|
type: 'farmersdelight:cooking',
|
||||||
@ -137,7 +137,7 @@ ServerEvents.recipes(event => {
|
|||||||
{item: 'kubejs:grist_chutney'},
|
{item: 'kubejs:grist_chutney'},
|
||||||
{item: 'kubejs:grist_chutney'},
|
{item: 'kubejs:grist_chutney'},
|
||||||
],
|
],
|
||||||
result: {item: 'kubejs:grist_agricultural_improved'}
|
result: {item: 'kubejs:grist_agricultural_improved_block', count: 3}
|
||||||
});
|
});
|
||||||
event.shaped('kubejs:grist_treats', [
|
event.shaped('kubejs:grist_treats', [
|
||||||
'AAA',
|
'AAA',
|
||||||
@ -176,7 +176,7 @@ ServerEvents.recipes(event => {
|
|||||||
{item: 'candlelight:pasta_bolognese'},
|
{item: 'candlelight:pasta_bolognese'},
|
||||||
{item: 'collectorsreap:prawn_po_boy'},
|
{item: 'collectorsreap:prawn_po_boy'},
|
||||||
],
|
],
|
||||||
inputFluid: "{Amount:5000,FluidName:\"kubejs:grist_agricultural_improved_fluid\"}",
|
inputFluid: "{Amount:5000,FluidName:\"kubejs:grist_agricultural_basic_fluid\"}",
|
||||||
output: {
|
output: {
|
||||||
count: 1,
|
count: 1,
|
||||||
item: 'kubejs:grist_morsels'
|
item: 'kubejs:grist_morsels'
|
||||||
|
@ -101,13 +101,17 @@ ServerEvents.recipes(event => {
|
|||||||
result: [{item: 'kubejs:reinforced_grist_ingot'}]
|
result: [{item: 'kubejs:reinforced_grist_ingot'}]
|
||||||
});
|
});
|
||||||
|
|
||||||
event.custom({
|
/*event.custom({
|
||||||
type: "thermal:centrifuge",
|
type: "thermal:centrifuge",
|
||||||
ingredients: [
|
ingredients: [
|
||||||
{ item: 'kubejs:reinforced_grist_blend' },
|
{ item: 'kubejs:reinforced_grist_blend' },
|
||||||
],
|
],
|
||||||
result: [{item: 'kubejs:reinforced_grist_nugget', chance: 0.3}]
|
result: [{item: 'kubejs:build_grist_basic'}, {item: 'kubejs:reinforced_grist_nugget', chance: 0.3}]
|
||||||
});
|
});*/
|
||||||
|
event.recipes.thermal.centrifuge([
|
||||||
|
'8x kubejs:build_grist_basic',
|
||||||
|
Item.of('kubejs:reinforced_grist_nugget').withChance(0.3)
|
||||||
|
], 'kubejs:reinforced_grist_blend');
|
||||||
|
|
||||||
event.recipes.thermal.smelter(
|
event.recipes.thermal.smelter(
|
||||||
'kubejs:reinforced_grist_blend',
|
'kubejs:reinforced_grist_blend',
|
||||||
|
@ -55,11 +55,9 @@ ServerEvents.recipes(event => {
|
|||||||
blazing crystals require blaze powder plus either infused grist capacitors or improved grist
|
blazing crystals require blaze powder plus either infused grist capacitors or improved grist
|
||||||
*/
|
*/
|
||||||
event.recipes.powah.energizing([
|
event.recipes.powah.energizing([
|
||||||
'kubejs:grist_energetic_improved',
|
|
||||||
'kubejs:grist_energetic_improved',
|
'kubejs:grist_energetic_improved',
|
||||||
'kubejs:grist_primordeal_improved_block',
|
'kubejs:grist_primordeal_improved_block',
|
||||||
'kubejs:grist_primordeal_improved_block',
|
], 'kubejs:grist_energetic_improved_block',
|
||||||
], '4x kubejs:grist_energetic_improved',
|
|
||||||
20000
|
20000
|
||||||
);
|
);
|
||||||
event.recipes.powah.energizing([
|
event.recipes.powah.energizing([
|
||||||
@ -97,7 +95,7 @@ ServerEvents.recipes(event => {
|
|||||||
'kubejs:unstable_grist_capacitor',
|
'kubejs:unstable_grist_capacitor',
|
||||||
'kubejs:unstable_grist_capacitor',
|
'kubejs:unstable_grist_capacitor',
|
||||||
'kubejs:unstable_grist_capacitor',
|
'kubejs:unstable_grist_capacitor',
|
||||||
], 'kubejs:grist_energetic_improved',
|
], '3x kubejs:grist_energetic_improved_block',
|
||||||
50000
|
50000
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ ServerEvents.recipes(event => {
|
|||||||
quanta: 25,
|
quanta: 25,
|
||||||
arcana: -1
|
arcana: -1
|
||||||
},
|
},
|
||||||
result: Item.of('kubejs:grist_intelligent_basic_block', 2).toJson()
|
result: Item.of('kubejs:grist_intelligent_basic_block', 3).toJson()
|
||||||
});
|
});
|
||||||
|
|
||||||
event.shaped('kubejs:sacred_flesh', [
|
event.shaped('kubejs:sacred_flesh', [
|
||||||
@ -102,8 +102,8 @@ ServerEvents.recipes(event => {
|
|||||||
catalysts come from source gems crystalized with basic intelligent fluid and sacred flesh
|
catalysts come from source gems crystalized with basic intelligent fluid and sacred flesh
|
||||||
*/
|
*/
|
||||||
event.recipes.summoningrituals.altar("kubejs:grist_primordeal_improved")
|
event.recipes.summoningrituals.altar("kubejs:grist_primordeal_improved")
|
||||||
.itemOutput(Item.of('kubejs:grist_intelligent_improved_block'))
|
.itemOutput(Item.of('kubejs:grist_intelligent_improved_block', 3))
|
||||||
.input(Item.of('kubejs:grist_primordeal_improved_block', 2))
|
.input(Item.of('kubejs:grist_primordeal_improved_block', 1))
|
||||||
.input(Item.of('kubejs:grist_intelligent_improved', 1))
|
.input(Item.of('kubejs:grist_intelligent_improved', 1))
|
||||||
.blockBelow('ars_nouveau:arcane_core');
|
.blockBelow('ars_nouveau:arcane_core');
|
||||||
|
|
||||||
|
@ -1,40 +1,64 @@
|
|||||||
// priority: 0
|
// priority: 0
|
||||||
|
function Metal(name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
global.metalForm = (metal, tag, form, qty) => {
|
Metal.of = function(name) {
|
||||||
if (qty == undefined) {
|
return new Metal(name);
|
||||||
qty = 1;
|
}
|
||||||
}
|
|
||||||
let itemType = AlmostUnified.getPreferredItemForTag(`forge:${tag}/${metal}`);
|
Metal.prototype.formOf = function(form) {
|
||||||
|
let itemType = AlmostUnified.getPreferredItemForTag(`forge:${form}/${this.name}`);
|
||||||
if (itemType.id == 'minecraft:air') {
|
if (itemType.id == 'minecraft:air') {
|
||||||
console.log(`metals: ${metal} ${form} has unknown tag forge:${tag}/${metal}?`)
|
console.warn(`metals: #forge:${form}/${this.name} is not supported by AlmostUnified! Trying a vanilla hack...`);
|
||||||
let ret = Item.of(`alltheores:${metal}_${form}`);
|
itemType = Ingredient.of(`#forge:${form}/${this.name}`).getFirst();
|
||||||
if (ret.id == "minecraft:air") {
|
}
|
||||||
return Item.of(`thermal:${metal}_${form}`);
|
if (itemType.id == 'minecraft:air') {
|
||||||
}
|
console.warn(`metals: No metal items found in #forge:${form}/${this.name}`)
|
||||||
return ret;
|
} else {
|
||||||
|
console.log(`metals: Found ${itemType.id} for #forge:${form}/${this.name}`);
|
||||||
}
|
}
|
||||||
console.log(`metals: forge:${tag}/${metal} found`);
|
|
||||||
return itemType;
|
return itemType;
|
||||||
}
|
}
|
||||||
|
|
||||||
global.dustItem = (material, qty) => {
|
// Format is [property name, tag name]
|
||||||
return global.metalForm(material, 'dusts', 'dust', qty);
|
const forms = [
|
||||||
|
['ingot', 'ingots'],
|
||||||
|
['gear', 'gears'],
|
||||||
|
['rod', 'rods'],
|
||||||
|
['nugget', 'nuggets'],
|
||||||
|
['plate', 'plates'],
|
||||||
|
['dust', 'dusts']
|
||||||
|
];
|
||||||
|
|
||||||
|
for (const [prop_name, form_tag] of forms) {
|
||||||
|
Metal.prototype[prop_name] = function() {
|
||||||
|
return this.formOf(form_tag);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
global.ingotItem = (material, qty) => {
|
global.metalForm = (metal, tag) => {
|
||||||
return global.metalForm(material, 'ingots', 'ingot', qty);
|
return (new Metal(metal)).formOf(tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
global.plateItem = (material, qty) => {
|
global.dustItem = (material) => {
|
||||||
return global.metalForm(material, 'plates', 'plate', qty);
|
return global.metalForm(material, 'dusts');
|
||||||
}
|
}
|
||||||
|
|
||||||
global.gearItem = (material, qty) => {
|
global.ingotItem = (material) => {
|
||||||
return global.metalForm(material, 'gears', 'gear', qty);
|
return global.metalForm(material, 'ingots');
|
||||||
}
|
}
|
||||||
|
|
||||||
global.nuggetItem = (material, qty) => {
|
global.plateItem = (material) => {
|
||||||
return global.metalForm(material, 'nuggets', 'nugget', qty);
|
return global.metalForm(material, 'plates');
|
||||||
|
}
|
||||||
|
|
||||||
|
global.gearItem = (material) => {
|
||||||
|
return global.metalForm(material, 'gears');
|
||||||
|
}
|
||||||
|
|
||||||
|
global.nuggetItem = (material) => {
|
||||||
|
return global.metalForm(material, 'nuggets');
|
||||||
}
|
}
|
||||||
|
|
||||||
global.replaceInputs = (evt, filter, replaceMap) => {
|
global.replaceInputs = (evt, filter, replaceMap) => {
|
||||||
|
@ -137,4 +137,95 @@ ServerEvents.recipes(event => {
|
|||||||
'minecraft:netherite_ingot',
|
'minecraft:netherite_ingot',
|
||||||
'#kubejs:grist/intelligent/radiant'
|
'#kubejs:grist/intelligent/radiant'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Nerf the storage components a little bit
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:cell_component_1k'},
|
||||||
|
'minecraft:redstone',
|
||||||
|
'#kubejs:grist/intelligent/basic'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:cell_component_4k'},
|
||||||
|
'minecraft:redstone',
|
||||||
|
'#kubejs:grist/intelligent/basic'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:cell_component_16k'},
|
||||||
|
'minecraft:glowstone',
|
||||||
|
'#kubejs:grist/intelligent/basic/block'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:cell_component_64k'},
|
||||||
|
'minecraft:glowstone',
|
||||||
|
'#kubejs:grist/intelligent/improved'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:cell_component_256k'},
|
||||||
|
'ae2:quartz_glass',
|
||||||
|
'#kubejs:grist/intelligent/improved/block'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Spatial IO is gated behind radiant build grist
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:spatial_cell_component_2'},
|
||||||
|
'minecraft:glowstone_dust',
|
||||||
|
'#kubejs:grist/build/radiant'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:spatial_cell_component_16'},
|
||||||
|
'minecraft:glowstone_dust',
|
||||||
|
'#kubejs:grist/build/radiant'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:spatial_cell_component_128'},
|
||||||
|
'minecraft:glowstone_dust',
|
||||||
|
'#kubejs:grist/build/radiant'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Item cells should require build grist
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:item_cell_housing'},
|
||||||
|
'minecraft:redstone',
|
||||||
|
'#kubejs:grist/build/basic'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:item_cell_housing'},
|
||||||
|
'minecraft:iron_ingot',
|
||||||
|
'#forge:plates/invar'
|
||||||
|
);
|
||||||
|
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:basic_card'},
|
||||||
|
'minecraft:iron_ingot',
|
||||||
|
'#forge:plates/silver'
|
||||||
|
);
|
||||||
|
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:basic_card'},
|
||||||
|
'minecraft:gold_ingot',
|
||||||
|
'#forge:plates/gold'
|
||||||
|
);
|
||||||
|
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:basic_card'},
|
||||||
|
'minecraft:redstone',
|
||||||
|
'#kubejs:grist/intelligent/basic'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Advanced card is an upgrade from the basic card
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:advanced_card'},
|
||||||
|
'minecraft:redstone',
|
||||||
|
'ae2:basic_card'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:advanced_card'},
|
||||||
|
'minecraft:iron_ingot',
|
||||||
|
'#forge:plates/invar'
|
||||||
|
);
|
||||||
|
event.replaceInput(
|
||||||
|
{output: 'ae2:advanced_card'},
|
||||||
|
'minecraft:diamond',
|
||||||
|
'#kubejs:grist/intelligent/basic/block'
|
||||||
|
);
|
||||||
});
|
});
|
@ -103,4 +103,10 @@ ServerEvents.recipes(event => {
|
|||||||
'B': 'create:item_vault',
|
'B': 'create:item_vault',
|
||||||
'C': '#kubejs:grist/intelligent/basic',
|
'C': '#kubejs:grist/intelligent/basic',
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Gate the symmetry wand behind build grist
|
||||||
|
event.replaceInput({output: 'create:wand_of_symmetry'},
|
||||||
|
'#forge:ender_pearls',
|
||||||
|
'#kubejs:grist/build/improved'
|
||||||
|
);
|
||||||
});
|
});
|
@ -1,34 +0,0 @@
|
|||||||
ServerEvents.recipes(event => {
|
|
||||||
event.remove({output: 'create_enchantment_industry:disenchanter'});
|
|
||||||
event.remove({output: 'create_enchantment_industry:printer'});
|
|
||||||
|
|
||||||
event.recipes.ars_nouveau.enchanting_apparatus(
|
|
||||||
[
|
|
||||||
'create:item_drain',
|
|
||||||
'#kubejs:grist/intelligent/improved'
|
|
||||||
],
|
|
||||||
'create_enchantment_industry:disenchanter'
|
|
||||||
);
|
|
||||||
|
|
||||||
event.recipes.ars_nouveau.enchanting_apparatus(
|
|
||||||
[
|
|
||||||
'#kubejs:grist/intelligent/improved',
|
|
||||||
'#kubejs:grist/build/improved'
|
|
||||||
],
|
|
||||||
'create:item_drain',
|
|
||||||
'create_enchantment_industry:disenchanter',
|
|
||||||
2000
|
|
||||||
);
|
|
||||||
|
|
||||||
event.recipes.ars_nouveau.enchanting_apparatus(
|
|
||||||
[
|
|
||||||
'#kubejs:grist/intelligent/improved',
|
|
||||||
'#kubejs:grist/build/improved',
|
|
||||||
'minecraft:book',
|
|
||||||
'minecraft:book'
|
|
||||||
],
|
|
||||||
'create:spout',
|
|
||||||
'create_enchantment_industry:printer',
|
|
||||||
2000
|
|
||||||
);
|
|
||||||
});
|
|
@ -33,4 +33,22 @@ ServerEvents.recipes(event => {
|
|||||||
'#forge:tomato_sauces'
|
'#forge:tomato_sauces'
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// There is a recipe that uses the skillet, but very different ingredients
|
||||||
|
event.remove({id: 'croptopia:cheeseburger'});
|
||||||
|
|
||||||
|
// Allow the apple pie to be automated in create, and use other eggs
|
||||||
|
event.replaceInput({output: 'croptopia:apple_pie'},
|
||||||
|
'minecraft:egg',
|
||||||
|
'#forge:eggs'
|
||||||
|
);
|
||||||
|
event.recipes.create.mixing(
|
||||||
|
'croptopia:apple_pie', [
|
||||||
|
'minecraft:apple',
|
||||||
|
'minecraft:sugar',
|
||||||
|
'#forge:eggs',
|
||||||
|
'#forge:flour',
|
||||||
|
'#forge:dough'
|
||||||
|
]
|
||||||
|
).heated();
|
||||||
});
|
});
|
@ -1,5 +1,9 @@
|
|||||||
ServerEvents.recipes(event => {
|
ServerEvents.recipes(event => {
|
||||||
|
|
||||||
|
// Completely remove the thermal cheese wheel, it gets confusing
|
||||||
|
event.remove({output: 'thermal:cheese_wheel'});
|
||||||
|
event.remove({input: 'thermal:cheese_wheel'});
|
||||||
|
|
||||||
// Sawdust for energy, of course.
|
// Sawdust for energy, of course.
|
||||||
event.recipes.thermal.stirling_fuel('thermal:sawdust').energy(500)
|
event.recipes.thermal.stirling_fuel('thermal:sawdust').energy(500)
|
||||||
|
|
||||||
|
@ -13,4 +13,24 @@ ServerEvents.recipes(event => {
|
|||||||
let _nv = ['crimson', 'warped'].forEach(variety => {
|
let _nv = ['crimson', 'warped'].forEach(variety => {
|
||||||
makeJuice(`${variety}_grapejuice`, `${variety}_grape`, `${variety}_grape_seeds`);
|
makeJuice(`${variety}_grapejuice`, `${variety}_grape`, `${variety}_grape_seeds`);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
event.replaceInput({output: 'candlelight:tomato_soup'},
|
||||||
|
'#forge:tomatoes',
|
||||||
|
'#forge:tomato_sauces'
|
||||||
|
);
|
||||||
|
event.recipes.create.mixing('candlelight:tomato_soup', [
|
||||||
|
'#forge:tomato_sauces',
|
||||||
|
'minecraft:sugar',
|
||||||
|
'#candellight:all_effects'
|
||||||
|
]).heated();
|
||||||
|
event.recipes.create.mixing('candlelight:tomato_soup', [
|
||||||
|
Fluid.of('create_central_kitchen:tomato_sauce', 250),
|
||||||
|
'minecraft:sugar',
|
||||||
|
'#candlelight:all_effects'
|
||||||
|
]).heated();
|
||||||
|
event.recipes.create.mixing('candlelight:bolognese', [
|
||||||
|
'#candlelight:red_effect',
|
||||||
|
'#forge:cooked_beef',
|
||||||
|
'candlelight:tomato_soup'
|
||||||
|
]).heated();
|
||||||
});
|
});
|
@ -1,3 +1,4 @@
|
|||||||
|
// FIXME: Cannot process alltheores:raw_nickel
|
||||||
ServerEvents.recipes(event => {
|
ServerEvents.recipes(event => {
|
||||||
// Metal tiers:
|
// Metal tiers:
|
||||||
// Copper, iron, tin, nickel, gold, zinc, brass, invar, bronze - Pre-basic build tier, the only ores that don't require a pulverizer or smelter to process
|
// Copper, iron, tin, nickel, gold, zinc, brass, invar, bronze - Pre-basic build tier, the only ores that don't require a pulverizer or smelter to process
|
||||||
@ -13,20 +14,54 @@ ServerEvents.recipes(event => {
|
|||||||
// invar, gold, silver, electrum, signalum, lead, steel - Gated behind gear die
|
// invar, gold, silver, electrum, signalum, lead, steel - Gated behind gear die
|
||||||
// lumium, enderium, other alloys - Gated behind heavy duty gear die
|
// lumium, enderium, other alloys - Gated behind heavy duty gear die
|
||||||
|
|
||||||
let metalForm = (metal, tag, form) => {
|
let rawForms = (metal) => {
|
||||||
let itemType = AlmostUnified.getPreferredItemForTag(`forge:${tag}/${metal}`);
|
let ret = null;
|
||||||
if (itemType.id == 'minecraft:air') {
|
AlmostUnified.getItemIds(`forge:raw_materials/${metal}`).forEach(id => {
|
||||||
console.log(`metals: ${metal} ${form} has unknown tag forge:${tag}/${metal}?`)
|
if (ret == null) {
|
||||||
let ret = Item.of(`alltheores:${metal}_${form}`);
|
ret = Ingredient.of(id);
|
||||||
if (ret.id == "minecraft:air") {
|
} else {
|
||||||
return Item.of(`thermal:${metal}_${form}`);
|
ret = ret.or(id);
|
||||||
}
|
}
|
||||||
return ret;
|
});
|
||||||
}
|
return ret;
|
||||||
console.log(`metals: forge:${tag}/${metal} found`);
|
|
||||||
return itemType;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let metalForm = global.metalForm;
|
||||||
|
|
||||||
|
let alloyIngredients = (forms, ingredients) => {
|
||||||
|
let real_ingredients = [];
|
||||||
|
for (const ingredient of ingredients.slice(1)) {
|
||||||
|
let real_item = Item.of(ingredient);
|
||||||
|
if (real_item.id == 'minecraft:air') {
|
||||||
|
let real_ingredient = null;
|
||||||
|
for (const form of forms) {
|
||||||
|
let parts = ingredient.split(' ');
|
||||||
|
if (parts.length == 1) {
|
||||||
|
real_item = metalForm(parts[0], form);
|
||||||
|
} else {
|
||||||
|
real_item = metalForm(parts[1], form).withCount(parts[0].split('x')[0]);
|
||||||
|
}
|
||||||
|
if (real_item.id == 'minecraft:air') {
|
||||||
|
console.error(`Unknown or invalid alloy ${form} ingredient: ${ingredient}`);
|
||||||
|
} else {
|
||||||
|
if (real_ingredient == null) {
|
||||||
|
real_ingredient = Ingredient.of(real_item);
|
||||||
|
} else {
|
||||||
|
real_ingredient = real_ingredient.or(real_item);
|
||||||
|
}
|
||||||
|
//real_ingredients.push(real_item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//console.error(`Ingredients: ${real_ingredients}`);
|
||||||
|
//real_ingredients.push(Ingredient.apply(null, real_ingredients));
|
||||||
|
real_ingredients.push(real_ingredient);
|
||||||
|
} else {
|
||||||
|
real_ingredients.push(real_item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return real_ingredients;
|
||||||
|
};
|
||||||
|
|
||||||
// Progression
|
// Progression
|
||||||
// Vanilla age -> Ore hammer for crushing tin to make andesite alloy
|
// Vanilla age -> Ore hammer for crushing tin to make andesite alloy
|
||||||
// Andesite age -> Mixer from andesite allow allows creating early alloys: bronze, brass, invar, constantan
|
// Andesite age -> Mixer from andesite allow allows creating early alloys: bronze, brass, invar, constantan
|
||||||
@ -98,7 +133,6 @@ ServerEvents.recipes(event => {
|
|||||||
},
|
},
|
||||||
// Andesite age: Iron pickaxe to mine, crushing wheels to crush, then the crushed ore is smelted normally. Alloys require the create mixer. Ore washing to double crushed ore is unlocked, but fans require invar instead of iron. Gears can be crafted on a crafting table
|
// Andesite age: Iron pickaxe to mine, crushing wheels to crush, then the crushed ore is smelted normally. Alloys require the create mixer. Ore washing to double crushed ore is unlocked, but fans require invar instead of iron. Gears can be crafted on a crafting table
|
||||||
andesite: {
|
andesite: {
|
||||||
silver: [],
|
|
||||||
aluminum: [],
|
aluminum: [],
|
||||||
lead: [],
|
lead: [],
|
||||||
rose_gold: [2, 'copper', 'gold'],
|
rose_gold: [2, 'copper', 'gold'],
|
||||||
@ -108,6 +142,7 @@ ServerEvents.recipes(event => {
|
|||||||
},
|
},
|
||||||
// Mechanical/grist age: Ores require diamond pick, crushed in the pulverizer, and crushed ore is smelted normally. Alloys require the induction furnace. 4x ore centrifuge is unlocked after creating a constantan gear on the crafting table. Other gears require the press.
|
// Mechanical/grist age: Ores require diamond pick, crushed in the pulverizer, and crushed ore is smelted normally. Alloys require the induction furnace. 4x ore centrifuge is unlocked after creating a constantan gear on the crafting table. Other gears require the press.
|
||||||
mechanical: {
|
mechanical: {
|
||||||
|
silver: [],
|
||||||
nickel: [],
|
nickel: [],
|
||||||
invar: [3, '2x iron', 'nickel'],
|
invar: [3, '2x iron', 'nickel'],
|
||||||
electrum: [2, 'gold', 'silver'],
|
electrum: [2, 'gold', 'silver'],
|
||||||
@ -140,9 +175,12 @@ ServerEvents.recipes(event => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Basic rules for all materials
|
// Basic rules for all materials
|
||||||
for (const [key, metals] of Object.entries(progression)) {
|
for (const [tier, metals] of Object.entries(progression)) {
|
||||||
for (const [metal, ingredients] of Object.entries(metals)) {
|
for (const [metal, ingredients] of Object.entries(metals)) {
|
||||||
|
console.log(`Running ore processing for ${metal}...`);
|
||||||
|
|
||||||
let rawType = metalForm(metal, 'raw_materials', 'ore');
|
let rawType = metalForm(metal, 'raw_materials', 'ore');
|
||||||
|
let rawIngredients = rawForms(metal);
|
||||||
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
||||||
|
|
||||||
let dustType = metalForm(metal, 'dusts', 'dust');
|
let dustType = metalForm(metal, 'dusts', 'dust');
|
||||||
@ -155,8 +193,6 @@ ServerEvents.recipes(event => {
|
|||||||
let gearType = metalForm(metal, 'gears', 'gear');
|
let gearType = metalForm(metal, 'gears', 'gear');
|
||||||
let rodType = metalForm(metal, 'rods', 'rod');
|
let rodType = metalForm(metal, 'rods', 'rod');
|
||||||
|
|
||||||
console.log(`Wiping out stock ore processing for ${metal}...`);
|
|
||||||
|
|
||||||
// Wipe out all the stock recipes
|
// Wipe out all the stock recipes
|
||||||
event.remove({output: gearType});
|
event.remove({output: gearType});
|
||||||
event.remove({output: dustType});
|
event.remove({output: dustType});
|
||||||
@ -168,93 +204,105 @@ ServerEvents.recipes(event => {
|
|||||||
event.remove({output: nuggetType});
|
event.remove({output: nuggetType});
|
||||||
event.remove({output: crushedType});
|
event.remove({output: crushedType});
|
||||||
event.remove({input: crushedType});
|
event.remove({input: crushedType});
|
||||||
|
console.warn(`Removing ${metal} ingot recipes for ${ingotType.id}`);
|
||||||
|
|
||||||
// All dusts and crushed ores can be smelted to ingots, and dusts can be created from crushing ingots
|
let ingotSources = [];
|
||||||
|
|
||||||
|
// All forms can be crushed back into dust
|
||||||
if (dustType.id != 'minecraft:air') {
|
if (dustType.id != 'minecraft:air') {
|
||||||
event.smelting(ingotType, dustType);
|
let dustSource = null;
|
||||||
event.shapeless(dustType, [ingotType, '#alltheores:ore_hammers']);
|
[gearType, rodType, plateType, ingotType].forEach(form => {
|
||||||
event.recipes.create.crushing(dustType, ingotType);
|
if (form.id != 'minecraft:air') {
|
||||||
event.recipes.create.milling(dustType, ingotType);
|
if (dustSource == null) {
|
||||||
|
dustSource = Ingredient.of(form);
|
||||||
|
} else {
|
||||||
|
dustSource = dustSource.or(form);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
event.shapeless(dustType, [dustSource, '#alltheores:ore_hammers']);
|
||||||
|
event.recipes.create.crushing(dustType, dustSource);
|
||||||
|
event.recipes.create.milling(dustType, dustSource);
|
||||||
|
event.recipes.thermal.pulverizer(dustType, dustSource);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Plates can always be smelted back into their original ingot, and crushed back into dust
|
// All forms, including crushed ores, can be smelted back into an ingot
|
||||||
|
if (ingotType.id != 'minecraft:air') {
|
||||||
|
let ingotSource = null;
|
||||||
|
[gearType, rodType, plateType, dustType, crushedType].forEach(form => {
|
||||||
|
if (form.id != 'minecraft:air') {
|
||||||
|
if (ingotSource == null) {
|
||||||
|
ingotSource = Ingredient.of(form);
|
||||||
|
} else {
|
||||||
|
ingotSource = ingotSource.or(form);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (ingotSource != null) {
|
||||||
|
event.smelting(ingotType, ingotSource);
|
||||||
|
} else {
|
||||||
|
console.error(`Unable to generate ${metal} ingot smelting from derivatives`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gears and ingots can be pressed into a plate
|
||||||
if (plateType.id != 'minecraft:air') {
|
if (plateType.id != 'minecraft:air') {
|
||||||
event.smelting(ingotType, plateType);
|
let plateSource = null;
|
||||||
// 1 plate = 1 ingot in presses
|
[gearType, ingotType].forEach(form => {
|
||||||
event.recipes.thermal.press(plateType, [ingotType]);
|
if (form.id != 'minecraft:air') {
|
||||||
event.recipes.create.pressing([plateType], [ingotType]);
|
if (plateSource == null) {
|
||||||
event.recipes.create.crushing(dustType, plateType);
|
plateSource = Ingredient.of(form);
|
||||||
event.recipes.create.milling(dustType, plateType);
|
} else {
|
||||||
event.recipes.thermal.pulverizer(dustType, plateType);
|
plateSource = plateSource.or(form);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// Gears can also be crushed back into dust
|
})
|
||||||
if (gearType.id != 'minecraft:air') {
|
event.recipes.thermal.press(plateType, plateSource);
|
||||||
event.recipes.create.crushing(dustType, gearType);
|
event.recipes.create.pressing(plateType, plateSource);
|
||||||
event.recipes.create.milling(dustType, gearType);
|
|
||||||
event.recipes.thermal.pulverizer(dustType, gearType);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Same for rods
|
|
||||||
if (rodType.id != 'minecraft:air') {
|
|
||||||
event.recipes.create.crushing(dustType, rodType);
|
|
||||||
event.recipes.create.milling(dustType, rodType);
|
|
||||||
event.recipes.thermal.pulverizer(dustType, rodType);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 4 ingots = 1 gear in the press
|
// 4 ingots = 1 gear in the press
|
||||||
if (gearType.id != 'minecraft:air') {
|
if (gearType.id != 'minecraft:air') {
|
||||||
event.recipes.thermal.press(gearType, [ingotType.withCount(4), 'thermal:press_gear_die']);
|
event.recipes.thermal.press(gearType, [ingotType.withCount(4), 'thermal:press_gear_die']).id(`kubejs:${metal}_gear_in_thermal_press`);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 9 Nuggets == 1 ingot, for every material
|
// 9 Nuggets == 1 ingot, for every material
|
||||||
if (nuggetType.id != 'minecraft:air') {
|
if (nuggetType.id != 'minecraft:air') {
|
||||||
event.shapeless(ingotType, [nuggetType.withCount(9)]);
|
event.shapeless(ingotType, [nuggetType.withCount(9)]).id(`kubejs:${metal}_ingot_from_nuggets`);
|
||||||
event.shapeless(nuggetType.withCount(9), [ingotType]);
|
event.shapeless(nuggetType.withCount(9), [ingotType]).id(`kubejs:${metal}_nuggets_from_ingot`);
|
||||||
|
event.recipes.thermal.press(ingotType, [nuggetType.withCount(9), 'thermal:press_packing_3x3_die']).id(`kubejs:${metal}_ingot_from_nuggets_in_thermal_press`);
|
||||||
|
event.recipes.thermal.press(nuggetType.withCount(9), [ingotType, 'thermal:press_unpacking_die']).id(`kubejs:${metal}_nuggets_from_ingot_in_thermal_press`);
|
||||||
}
|
}
|
||||||
// 9 ore = 1 ore block
|
// 9 ore = 1 ore block
|
||||||
if (rawType.id != 'minecraft:air') {
|
if (rawIngredients != null) {
|
||||||
event.shapeless(rawBlockType, [rawType.withCount(9)]);
|
event.shapeless(rawBlockType, [rawIngredients.withCount(9)]).id(`kubejs:${metal}_ore_block_from_ore`);
|
||||||
event.shapeless(rawType.withCount(9), [rawBlockType]);
|
event.shapeless(rawType.withCount(9), [rawBlockType]).id(`kubejs:${metal}_ore_from_ore_block`);
|
||||||
|
event.recipes.thermal.press(rawBlockType, [rawIngredients.withCount(9), 'thermal:press_packing_3x3_die']).id(`kubejs:${metal}_ore_block_from_ore_in_thermal_press`);
|
||||||
|
event.recipes.thermal.press(rawType.withCount(9), [rawBlockType, 'thermal:press_unpacking_die']).id(`kubejs:${metal}_ore_from_ore_block_in_thermal_press`);
|
||||||
}
|
}
|
||||||
// 9 ingots = 1 block
|
// 9 ingots = 1 block
|
||||||
if (blockType.id != 'minecraft:air') {
|
if (blockType.id != 'minecraft:air') {
|
||||||
event.shapeless(blockType, [ingotType.withCount(9)]);
|
event.shapeless(blockType, [ingotType.withCount(9)]).id(`kubejs:${metal}_block_from_ingots`);
|
||||||
event.shapeless(ingotType.withCount(9), [blockType]);
|
event.shapeless(ingotType.withCount(9), [blockType]).id(`kubejs:${metal}_ingots_from_block`);
|
||||||
|
event.recipes.thermal.press(blockType, [ingotType.withCount(9), 'thermal:press_packing_3x3_die']).id(`kubejs:${metal}_block_from_ingots_in_thermal_press`);
|
||||||
|
event.recipes.thermal.press(ingotType.withCount(9), [blockType, 'thermal:press_unpacking_die']).id(`kubejs:${metal}_ingots_from_block_in_thermal_press`);
|
||||||
}
|
}
|
||||||
|
|
||||||
// All alloys can be created in the thermal smelter, or a superheated create mixer
|
// All alloys can be created in the thermal smelter, or a superheated create mixer
|
||||||
if (ingredients.length > 0) {
|
if (ingredients.length > 0) {
|
||||||
for (const form of ['ingots', 'dusts']) {
|
let real_ingredients = alloyIngredients(['ingots', 'dusts'], ingredients);
|
||||||
let real_ingredients = [];
|
|
||||||
for (const ingredient of ingredients.slice(1)) {
|
|
||||||
let real_item = Item.of(ingredient);
|
|
||||||
if (real_item.id == 'minecraft:air') {
|
|
||||||
let parts = ingredient.split(' ');
|
|
||||||
if (parts.length == 1) {
|
|
||||||
real_item = metalForm(parts[0], form);
|
|
||||||
} else {
|
|
||||||
real_item = metalForm(parts[1], form).withCount(parts[0].split('x')[0]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (real_item.id == 'minecraft:air') {
|
if (real_ingredients.length == 0) {
|
||||||
console.error(`Unknown or invalid ${metal} alloy ingredient: ${ingredient}`);
|
console.error(`Unable to create ingots from ${form} for ${metal}!`);
|
||||||
}
|
} else {
|
||||||
real_ingredients.push(real_item);
|
// If we have 3 or fewer ingredients, we can create it in the 3-slot thermal smelter
|
||||||
}
|
if (real_ingredients.length <= 3) {
|
||||||
|
event.recipes.thermal.smelter(ingotType.withCount(ingredients[0]), real_ingredients);
|
||||||
if (real_ingredients.length == 0) {
|
event.recipes.create.mixing(ingotType.withCount(ingredients[0]), real_ingredients).heated();
|
||||||
console.error(`Unable to create ingots from ${form} for ${metal}!`);
|
|
||||||
} else {
|
} else {
|
||||||
// If we have 3 or fewer ingredients, we can create it in the 3-slot thermal smelter
|
// Materials with 4 or more require superheating, and can only be made in the mixer
|
||||||
if (real_ingredients.length <= 3) {
|
event.recipes.create.mixing(ingotType.withCount(ingredients[0]), real_ingredients).superheated();
|
||||||
event.recipes.thermal.smelter(ingotType.withCount(ingredients[0]), real_ingredients);
|
|
||||||
event.recipes.create.mixing(ingotType.withCount(ingredients[0]), real_ingredients).heated();
|
|
||||||
} else {
|
|
||||||
// Materials with 4 or more require superheating, and can only be made in the mixer
|
|
||||||
event.recipes.create.mixing(ingotType.withCount(ingredients[0]), real_ingredients).superheated();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -285,7 +333,7 @@ ServerEvents.recipes(event => {
|
|||||||
// Vanilla tier: Ores need an ore hammer, and alloys can be crafted on the crafting table
|
// Vanilla tier: Ores need an ore hammer, and alloys can be crafted on the crafting table
|
||||||
for (const tier of ['primitive', 'vanilla']) {
|
for (const tier of ['primitive', 'vanilla']) {
|
||||||
for (const [metal, ingredients] of Object.entries(progression[tier])) {
|
for (const [metal, ingredients] of Object.entries(progression[tier])) {
|
||||||
let rawType = metalForm(metal, 'raw_materials', 'ore');
|
let rawIngredients = rawForms(metal);
|
||||||
let dustType = metalForm(metal, 'dusts', 'dust');
|
let dustType = metalForm(metal, 'dusts', 'dust');
|
||||||
let ingotType = metalForm(metal, 'ingots', 'ingot');
|
let ingotType = metalForm(metal, 'ingots', 'ingot');
|
||||||
let rawBlockType = metalForm(`raw_${metal}`, 'storage_blocks', 'block');
|
let rawBlockType = metalForm(`raw_${metal}`, 'storage_blocks', 'block');
|
||||||
@ -293,51 +341,32 @@ ServerEvents.recipes(event => {
|
|||||||
console.log(`Building vanilla processing for ${metal}...`);
|
console.log(`Building vanilla processing for ${metal}...`);
|
||||||
|
|
||||||
// Crush raw ore into dust with an ore hammer, in crafting table and in the deployer
|
// Crush raw ore into dust with an ore hammer, in crafting table and in the deployer
|
||||||
if (rawType.id != 'minecraft:air') {
|
if (rawIngredients != null) {
|
||||||
event.shapeless(dustType, [rawType, '#alltheores:ore_hammers']);
|
event.shapeless(dustType, [rawIngredients, '#alltheores:ore_hammers']);
|
||||||
event.shapeless(dustType.withCount(9), [rawBlockType, '#alltheores:ore_hammers']);
|
event.shapeless(dustType.withCount(9), [rawBlockType, '#alltheores:ore_hammers']);
|
||||||
event.recipes.create.deploying([dustType], [rawType, '#alltheores:ore_hammers']).keepHeldItem();
|
event.recipes.create.deploying([dustType], [rawIngredients, '#alltheores:ore_hammers']).keepHeldItem();
|
||||||
event.recipes.create.deploying([dustType.withCount(9)], [rawBlockType, '#alltheores:ore_hammers']).keepHeldItem();
|
event.recipes.create.deploying([dustType.withCount(9)], [rawBlockType, '#alltheores:ore_hammers']).keepHeldItem();
|
||||||
} else {
|
} else {
|
||||||
console.warn(`No ${metal} ore hammer smashing available!`);
|
console.log(`No ${metal} ore hammer smashing available due to missing raw form!`);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: alloy ingredients
|
let real_ingredients = alloyIngredients(['ingots', 'dusts'], ingredients);
|
||||||
for (const form of ['ingots', 'dusts']) {
|
|
||||||
let real_ingredients = [];
|
|
||||||
for (const ingredient of ingredients.slice(1)) {
|
|
||||||
let real_item = Item.of(ingredient);
|
|
||||||
if (real_item.id == 'minecraft:air') {
|
|
||||||
let parts = ingredient.split(' ');
|
|
||||||
if (parts.length == 1) {
|
|
||||||
real_item = metalForm(parts[0], form);
|
|
||||||
} else {
|
|
||||||
real_item = metalForm(parts[1], form).withCount(parts[0].split('x')[0]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (real_item.id == 'minecraft:air') {
|
|
||||||
console.error(`Unknown or invalid ${metal} alloy ingredient: ${ingredient}`);
|
|
||||||
} else {
|
|
||||||
real_ingredients.push(real_item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (real_ingredients.length > 0 && ingotType.id != 'minecraft:air') {
|
if (real_ingredients.length > 0 && ingotType.id != 'minecraft:air') {
|
||||||
event.shapeless(ingotType.withCount(ingredients[0]), real_ingredients);
|
event.shapeless(ingotType.withCount(ingredients[0]), real_ingredients);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Andesite alloy is the progression item, as it unlocks most of the next tier of create
|
// Andesite alloy is the progression item, as it unlocks most of the next tier of create
|
||||||
event.shapeless('create:andesite_alloy', [global.dustItem('tin'), '2x minecraft:andesite']);
|
//event.shapeless('create:andesite_alloy', [global.dustItem('tin'), '2x minecraft:andesite']);
|
||||||
|
|
||||||
let xpNugget = Item.of('create:experience_nugget');
|
let xpNugget = Item.of('create:experience_nugget');
|
||||||
|
|
||||||
// Andesite age: Crushing wheels to crush, then the crushed ore is smelted normally. Alloys require the create mixer. Ore washing to double crushed ore is unlocked, but fans require invar instead of iron. Gears can be crafted on a crafting table
|
// Andesite age: Crushing wheels to crush, then the crushed ore is smelted normally. Alloys require the create mixer. Ore washing to double crushed ore is unlocked, but fans require invar instead of iron. Gears can be crafted on a crafting table
|
||||||
for (const tier of ['primitive', 'vanilla', 'andesite']) {
|
for (const tier of ['primitive', 'vanilla', 'andesite']) {
|
||||||
for (const [metal, ingredients] of Object.entries(progression[tier])) {
|
for (const [metal, ingredients] of Object.entries(progression[tier])) {
|
||||||
let rawType = metalForm(metal, 'raw_materials', 'ore');
|
let rawIngredients = rawForms(metal);
|
||||||
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
||||||
let dustType = metalForm(metal, 'dusts', 'dust');
|
let dustType = metalForm(metal, 'dusts', 'dust');
|
||||||
let ingotType = metalForm(metal, 'ingots', 'ingot');
|
let ingotType = metalForm(metal, 'ingots', 'ingot');
|
||||||
@ -347,11 +376,11 @@ ServerEvents.recipes(event => {
|
|||||||
|
|
||||||
console.log(`Building andesite processing for ${metal}...`);
|
console.log(`Building andesite processing for ${metal}...`);
|
||||||
|
|
||||||
if (rawType.id != 'minecraft:air') {
|
if (rawIngredients != null) {
|
||||||
if (crushedType.id != 'minecraft:air') {
|
if (crushedType.id != 'minecraft:air') {
|
||||||
event.recipes.create.crushing([crushedType.withCount(2), xpNugget.withCount(2).withChance(0.75)], rawType);
|
event.recipes.create.crushing([crushedType.withCount(2), xpNugget.withCount(2).withChance(0.75)], rawIngredients);
|
||||||
event.recipes.create.crushing([crushedType.withCount(18), xpNugget.withCount(18).withChance(0.75)], rawBlockType);
|
event.recipes.create.crushing([crushedType.withCount(18), xpNugget.withCount(18).withChance(0.75)], rawBlockType);
|
||||||
event.recipes.create.milling([crushedType.withCount(2)], rawType);
|
event.recipes.create.milling([crushedType.withCount(2)], rawIngredients);
|
||||||
event.recipes.create.milling([crushedType.withCount(18)], rawBlockType);
|
event.recipes.create.milling([crushedType.withCount(18)], rawBlockType);
|
||||||
event.smelting(ingotType, crushedType);
|
event.smelting(ingotType, crushedType);
|
||||||
|
|
||||||
@ -384,29 +413,10 @@ ServerEvents.recipes(event => {
|
|||||||
console.warn(`No ${metal} plates available!`);
|
console.warn(`No ${metal} plates available!`);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: alloy ingredients
|
let real_ingredients = alloyIngredients(['ingots', 'dusts'], ingredients);
|
||||||
for (const form of ['ingots', 'dusts']) {
|
|
||||||
let real_ingredients = [];
|
|
||||||
for (const ingredient of ingredients.slice(1)) {
|
|
||||||
let real_item = Item.of(ingredient);
|
|
||||||
if (real_item.id == 'minecraft:air') {
|
|
||||||
let parts = ingredient.split(' ');
|
|
||||||
if (parts.length == 1) {
|
|
||||||
real_item = metalForm(parts[0], form);
|
|
||||||
} else {
|
|
||||||
real_item = metalForm(parts[1], form).withCount(parts[0].split('x')[0]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (real_item.id == 'minecraft:air') {
|
|
||||||
console.error(`Unknown or invalid ${metal} alloy ingredient: ${ingredient}`);
|
|
||||||
}
|
|
||||||
real_ingredients.push(real_item);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (real_ingredients.length > 0) {
|
if (real_ingredients.length > 0) {
|
||||||
event.recipes.create.mixing(ingotType.withCount(ingredients[0]), real_ingredients).heated();
|
event.recipes.create.mixing(ingotType.withCount(ingredients[0]), real_ingredients).heated();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -420,45 +430,24 @@ ServerEvents.recipes(event => {
|
|||||||
// Mechanical/grist age: Ores require diamond pick, crushed in the pulverizer, and crushed ore is smelted normally. Alloys require blending dusts in a heated mixer, then smelting the blend. 4x ore centrifuge is unlocked after creating a constantan gear on the crafting table. Other gears require the press.
|
// Mechanical/grist age: Ores require diamond pick, crushed in the pulverizer, and crushed ore is smelted normally. Alloys require blending dusts in a heated mixer, then smelting the blend. 4x ore centrifuge is unlocked after creating a constantan gear on the crafting table. Other gears require the press.
|
||||||
for (const tier of ['primitive', 'vanilla', 'andesite', 'mechanical']) {
|
for (const tier of ['primitive', 'vanilla', 'andesite', 'mechanical']) {
|
||||||
for (const [metal, ingredients] of Object.entries(progression[tier])) {
|
for (const [metal, ingredients] of Object.entries(progression[tier])) {
|
||||||
let rawType = metalForm(metal, 'raw_materials', 'ore');
|
|
||||||
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
||||||
let dustType = metalForm(metal, 'dusts', 'dust');
|
let dustType = metalForm(metal, 'dusts', 'dust');
|
||||||
let ingotType = metalForm(metal, 'ingots', 'ingot');
|
let ingotType = metalForm(metal, 'ingots', 'ingot');
|
||||||
|
|
||||||
console.log(`Building mechanical processing for ${metal}...`);
|
console.log(`Building mechanical processing for ${metal}...`);
|
||||||
|
|
||||||
if (rawType.id != 'minecraft:air') {
|
if (crushedType.id != 'minecraft:air') {
|
||||||
if (crushedType.id != 'minecraft:air') {
|
// Crushed ores are created in the industrial tier code, but mechanical tier and below are the only ones that don't need a centrifuge first
|
||||||
// Crushed ores are created in the industrial tier code, but mechanical tier and below are the only ones that don't need a centrifuge first
|
// This allows Nickel to be processed into a constantan gear, which unlocks the centrifuge
|
||||||
// This allows Nickel to be processed into a constantan gear, which unlocks the centrifuge
|
event.smelting(ingotType, [crushedType]);
|
||||||
event.smelting(ingotType, [crushedType]);
|
} else {
|
||||||
} else {
|
console.error(`No ${metal} ore pulverizing available! Falling back to dust-based processing line`);
|
||||||
console.error(`No ${metal} ore pulverizing available! Falling back to dust-based processing line`);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const form of ['dusts']) {
|
let real_ingredients = alloyIngredients(['dusts'], ingredients);
|
||||||
let real_ingredients = [];
|
|
||||||
for (const ingredient of ingredients.slice(1)) {
|
|
||||||
let real_item = Item.of(ingredient);
|
|
||||||
if (real_item.id == 'minecraft:air') {
|
|
||||||
let parts = ingredient.split(' ');
|
|
||||||
if (parts.length == 1) {
|
|
||||||
real_item = metalForm(parts[0], form);
|
|
||||||
} else {
|
|
||||||
real_item = metalForm(parts[1], form).withCount(parts[0].split('x')[0]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (real_item.id == 'minecraft:air') {
|
if (real_ingredients.length > 0) {
|
||||||
console.error(`Unknown or invalid ${metal} alloy ingredient: ${ingredient}`);
|
event.recipes.create.mixing(dustType.withCount(ingredients[0]), real_ingredients).heated();
|
||||||
}
|
|
||||||
real_ingredients.push(real_item);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (real_ingredients.length > 0) {
|
|
||||||
event.recipes.create.mixing(dustType.withCount(ingredients[0]), real_ingredients).heated();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -467,13 +456,13 @@ ServerEvents.recipes(event => {
|
|||||||
// Industrial age: Ores require centrifuging, alloys require basic grists, gears can only be made with a gear die
|
// Industrial age: Ores require centrifuging, alloys require basic grists, gears can only be made with a gear die
|
||||||
for (const tier of ['primitive', 'vanilla', 'andesite', 'mechanical', 'industrial']) {
|
for (const tier of ['primitive', 'vanilla', 'andesite', 'mechanical', 'industrial']) {
|
||||||
for (const [metal, ingredients] of Object.entries(progression[tier])) {
|
for (const [metal, ingredients] of Object.entries(progression[tier])) {
|
||||||
let rawType = metalForm(metal, 'raw_materials', 'ore');
|
let rawIngredients = rawForms(metal);
|
||||||
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
||||||
let dustType = metalForm(metal, 'dusts', 'dust');
|
let dustType = metalForm(metal, 'dusts', 'dust');
|
||||||
let rawBlockType = metalForm(`raw_${metal}`, 'storage_blocks', 'block');
|
let rawBlockType = metalForm(`raw_${metal}`, 'storage_blocks', 'block');
|
||||||
if (rawType.id != 'minecraft:air') {
|
if (rawIngredients != null) {
|
||||||
if (crushedType.id != 'minecraft:air') {
|
if (crushedType.id != 'minecraft:air') {
|
||||||
event.recipes.thermal.pulverizer([crushedType.withCount(4), crushedType.withChance(0.25), xpNugget.withCount(4).withChance(0.75)], rawType);
|
event.recipes.thermal.pulverizer([crushedType.withCount(4), crushedType.withChance(0.25), xpNugget.withCount(4).withChance(0.75)], rawIngredients);
|
||||||
event.recipes.thermal.pulverizer([crushedType.withCount(4 * 9), crushedType.withChance(0.25), xpNugget.withCount(4 * 9).withChance(0.75)], rawBlockType);
|
event.recipes.thermal.pulverizer([crushedType.withCount(4 * 9), crushedType.withChance(0.25), xpNugget.withCount(4 * 9).withChance(0.75)], rawBlockType);
|
||||||
event.recipes.thermal.centrifuge([dustType.withCount(4), dustType.withChance(0.25)], crushedType);
|
event.recipes.thermal.centrifuge([dustType.withCount(4), dustType.withChance(0.25)], crushedType);
|
||||||
} else {
|
} else {
|
||||||
@ -482,263 +471,45 @@ ServerEvents.recipes(event => {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Generate clay from centrifuing ash or gravel
|
||||||
|
event.recipes.thermal.centrifuge([
|
||||||
|
Item.of('minecraft:clay_ball').withChance(1.05),
|
||||||
|
Item.of('minecraft:clay_ball').withChance(0.25)],
|
||||||
|
'supplementaries:ash_brick'
|
||||||
|
);
|
||||||
|
event.recipes.thermal.centrifuge([
|
||||||
|
Item.of('minecraft:clay_ball').withChance(1.75),
|
||||||
|
Item.of('minecraft:clay_ball').withChance(0.85)],
|
||||||
|
'minecraft:gravel'
|
||||||
|
);
|
||||||
|
// Let quartz dust be created in the crafting table with a hammer
|
||||||
|
event.shapeless('thermal:quartz_dust',
|
||||||
|
['minecraft:quartz', '#alltheores:ore_hammers']
|
||||||
|
).id('kubejs:quartz_dust_crushing');
|
||||||
|
|
||||||
|
// Fix up the diamond gear recipe, which somehow has two duplicates
|
||||||
|
event.remove({output: 'thermal:diamond_gear'});
|
||||||
|
event.shaped('thermal:diamond_gear', [
|
||||||
|
' A ',
|
||||||
|
'ABA',
|
||||||
|
' A '
|
||||||
|
], {
|
||||||
|
'A': 'minecraft:diamond',
|
||||||
|
'B': '#kubejs:grist/build/basic'
|
||||||
|
});
|
||||||
|
|
||||||
|
//event.recipes.create.crushing(dustType, dustSource);
|
||||||
|
event.recipes.create.milling('create:powdered_obsidian', 'minecraft:obsidian');
|
||||||
});
|
});
|
||||||
|
|
||||||
function foobar() {
|
function shpaes() {
|
||||||
event.shapeless('thermal:quartz_dust', ['8x minecraft:granite', '#alltheores:ore_hammers']).id('kubejs:quartz_dust_from_granit_crushing_manual_only');
|
event.shapeless('thermal:quartz_dust', ['8x minecraft:granite', '#alltheores:ore_hammers']).id('kubejs:quartz_dust_from_granit_crushing_manual_only');
|
||||||
event.shapeless('thermal:quartz_dust', ['minecraft:quartz', '#alltheores:ore_hammers']).id('kubejs:quartz_dust_crushing_manual_only');
|
event.shapeless('thermal:quartz_dust', ['minecraft:quartz', '#alltheores:ore_hammers']).id('kubejs:quartz_dust_crushing_manual_only');
|
||||||
|
|
||||||
// All metals can be processed in the pulverizer/crusher, make plates in the press, and make gears with the die
|
|
||||||
{
|
|
||||||
let _ = ['copper', 'rose_gold', 'aluminum', 'constantan', 'iron', 'tin', 'nickel', 'gold', 'zinc', 'brass', 'invar', 'bronze', 'silver', 'platinum', 'lead', 'iridium', 'osmium', 'lumium', 'enderium', 'electrum', 'signalum', 'steel', 'uranium'].forEach(metal => {
|
|
||||||
console.log(`Setting up Tier 3 ${metal} processing...`);
|
|
||||||
|
|
||||||
let gearType = metalForm(metal, 'gears', 'gear');
|
|
||||||
let dustType = metalForm(metal, 'dusts', 'dust');
|
|
||||||
let plateType = metalForm(metal, 'plates', 'plate');
|
|
||||||
let ingotType = metalForm(metal, 'ingots', 'ingot');
|
|
||||||
let rawType = metalForm(metal, 'raw_materials', 'ore');
|
|
||||||
let blockType = metalForm(`raw_${metal}`, 'storage_blocks', 'block');
|
|
||||||
let crushedType = Item.of(`create:crushed_raw_${metal}`);
|
|
||||||
|
|
||||||
event.remove({output: gearType});
|
|
||||||
event.remove({output: plateType});
|
|
||||||
|
|
||||||
event.remove({input: `#forge:ores/${metal}`});
|
|
||||||
event.remove({input: `#forge:raw_materials/${metal}`});
|
|
||||||
|
|
||||||
// By default, you can't make any blends in the crafting table.
|
|
||||||
event.remove({output: dustType, type: 'minecraft:crafting'});
|
|
||||||
event.remove({output: ingotType, input: 'minecraft:fire_charge'});
|
|
||||||
|
|
||||||
// Remove the default conversion of ingot to nuggets from create
|
|
||||||
event.remove({input: ingotType, type: 'create:crushing'});
|
|
||||||
|
|
||||||
// And completely eliminate the default refining line with create crushed ores
|
|
||||||
if (crushedType.id != 'minecraft:air') {
|
|
||||||
event.remove({input: crushedType});
|
|
||||||
event.remove({output: crushedType});
|
|
||||||
} else {
|
|
||||||
console.log(`metals: Missing create:crushed_raw_${metal}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
event.remove({id: `alltheores:${metal}_dust_from_alloy_blending`});
|
|
||||||
|
|
||||||
console.log(`crushing ${rawType.toJson()} ${dustType.toJson()}`);
|
|
||||||
if (rawType.id != "minecraft:air") {
|
|
||||||
event.custom({
|
|
||||||
type: "thermal:pulverizer",
|
|
||||||
ingredients: [
|
|
||||||
{tag: `forge:raw_materials/${metal}`}
|
|
||||||
],
|
|
||||||
result: [
|
|
||||||
{item: dustType.id, chance: 1.05},
|
|
||||||
{item: dustType.id, chance: 0.25}
|
|
||||||
],
|
|
||||||
experience: 0.5
|
|
||||||
});
|
|
||||||
|
|
||||||
if (crushedType.id != 'minecraft:air') {
|
|
||||||
event.custom({
|
|
||||||
type: "create:crushing",
|
|
||||||
ingredients: [
|
|
||||||
{tag: `forge:raw_materials/${metal}`}
|
|
||||||
],
|
|
||||||
results: [
|
|
||||||
{item: crushedType.id, chance: 1},
|
|
||||||
{item: crushedType.id, chance: 0.25},
|
|
||||||
{item: dustType.id, chance: 0.05},
|
|
||||||
{item: 'create:experience_nugget', count: 2, chance: 0.75}
|
|
||||||
],
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (blockType.id != "minecraft:air") {
|
|
||||||
event.custom({
|
|
||||||
type: "thermal:pulverizer",
|
|
||||||
ingredients: [
|
|
||||||
{tag: `forge:storage_blocks/raw_${metal}`}
|
|
||||||
],
|
|
||||||
result: [
|
|
||||||
{item: dustType.id, count: 9, chance: 1},
|
|
||||||
{item: dustType.id, count: 9, chance: 0.25}
|
|
||||||
],
|
|
||||||
experience: 0.5
|
|
||||||
});
|
|
||||||
|
|
||||||
if (crushedType.id != 'minecraft:air') {
|
|
||||||
event.custom({
|
|
||||||
type: "create:crushing",
|
|
||||||
ingredients: [
|
|
||||||
{tag: `forge:storage_blocks/raw_${metal}`}
|
|
||||||
],
|
|
||||||
results: [
|
|
||||||
{item: crushedType.id, count: 9, chance: 1},
|
|
||||||
{item: crushedType.id, count: 9, chance: 0.25},
|
|
||||||
{item: dustType.id, count: 9, chance: 0.05},
|
|
||||||
{item: 'create:experience_nugget', count: 2 * 9, chance: 0.75}
|
|
||||||
],
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set up the parallel create-based ore washing line
|
|
||||||
if (crushedType.id != 'minecraft:air') {
|
|
||||||
event.custom({
|
|
||||||
type: "create:splashing",
|
|
||||||
ingredients: [
|
|
||||||
{item: crushedType.id }
|
|
||||||
],
|
|
||||||
results: [
|
|
||||||
{item: dustType.id, count: 2, chance: 1},
|
|
||||||
{item: dustType.id, chance: 0.25},
|
|
||||||
{item: dustType.id, chance: 0.05},
|
|
||||||
],
|
|
||||||
});
|
|
||||||
|
|
||||||
event.custom({
|
|
||||||
type: "thermal:centrifuge",
|
|
||||||
ingredients: [
|
|
||||||
{item: crushedType.id }
|
|
||||||
],
|
|
||||||
result: [
|
|
||||||
{item: dustType.id, count: 3, chance: 3.0},
|
|
||||||
{item: dustType.id, chance: 0.75},
|
|
||||||
{item: "twigs:pebble", chance: 0.05}
|
|
||||||
],
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 1 dust = 1 ingot
|
|
||||||
event.custom({
|
|
||||||
type: "thermal:pulverizer",
|
|
||||||
ingredients: [
|
|
||||||
ingotType.toJson()
|
|
||||||
],
|
|
||||||
result: [
|
|
||||||
dustType.toJson()
|
|
||||||
],
|
|
||||||
});
|
|
||||||
|
|
||||||
event.custom({
|
|
||||||
type: "create:crushing",
|
|
||||||
ingredients: [
|
|
||||||
ingotType.toJson()
|
|
||||||
],
|
|
||||||
results: [
|
|
||||||
dustType.toJson()
|
|
||||||
],
|
|
||||||
});
|
|
||||||
|
|
||||||
// 4 ingots = 1 gear
|
|
||||||
event.custom({
|
|
||||||
type: "thermal:press",
|
|
||||||
ingredients: [
|
|
||||||
ingotType.withCount(4).toJson(),
|
|
||||||
{ item: "thermal:press_gear_die" }
|
|
||||||
],
|
|
||||||
result: [gearType.toJson()]
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1 ingot = 1 plate
|
|
||||||
event.custom({
|
|
||||||
type: "thermal:press",
|
|
||||||
ingredients: [
|
|
||||||
ingotType.toJson(),
|
|
||||||
],
|
|
||||||
result: [plateType.toJson()]
|
|
||||||
});
|
|
||||||
event.custom({
|
|
||||||
type: "create:pressing",
|
|
||||||
ingredients: [
|
|
||||||
ingotType.toJson(),
|
|
||||||
],
|
|
||||||
results: [plateType.toJson()]
|
|
||||||
});
|
|
||||||
});}
|
|
||||||
|
|
||||||
// But only these metals can be processed without a machine
|
|
||||||
{let _ = ['copper', 'iron', 'tin', 'nickel', 'zinc', 'brass', 'bronze', 'lead', 'aluminum'].forEach(metal => {
|
|
||||||
console.log(`Setting up ${metal} manual processing...`);
|
|
||||||
let gearID = metalForm(metal, 'gears', 'gear');
|
|
||||||
let plateID = metalForm(metal, 'plates', 'plate');
|
|
||||||
let dustID = metalForm(metal, 'dusts', 'dust');
|
|
||||||
event.shaped(gearID, [
|
|
||||||
' A ',
|
|
||||||
'ABA',
|
|
||||||
' A '
|
|
||||||
], {
|
|
||||||
'A': global.ingotItem(metal),
|
|
||||||
'B': '#forge:gems'
|
|
||||||
});
|
|
||||||
event.shapeless(plateID, [global.ingotItem(metal, 2), '#alltheores:ore_hammers']).id(`kubejs:plate_crushing_${metal}_manual_only`);
|
|
||||||
event.shapeless(dustID, [global.ingotItem(metal), '#alltheores:ore_hammers']).id(`kubejs:ore_crushing_${metal}_manual_only`);
|
|
||||||
});}
|
|
||||||
|
|
||||||
// And only these ores can be hammered or crushed
|
|
||||||
{let _ = ['copper', 'iron', 'tin', 'nickel', 'zinc', 'lead', 'aluminum', 'gold'].forEach(ore => {
|
|
||||||
console.log(`Setting up ${ore} hammering...`);
|
|
||||||
let dustType = metalForm(ore, 'dusts', 'dust');
|
|
||||||
event.shapeless(dustType.withCount(2), [`#forge:raw_materials/${ore}`, '#alltheores:ore_hammers']).id(`kubejs:ore_crushing_2_${ore}_manual_only`);
|
|
||||||
event.shapeless(dustType.withCount(2 * 9), [`#forge:storage_blocks/raw_${ore}`, '#alltheores:ore_hammers']).id(`kubejs:ore_block_crushing_${ore}_manual_only`);
|
|
||||||
});}
|
|
||||||
|
|
||||||
// And only copper can be smelted without pulverizing
|
// And only copper can be smelted without pulverizing
|
||||||
event.smelting(global.ingotItem('copper'), metalForm('copper', 'raw_materials', 'ore'));
|
event.smelting(global.ingotItem('copper'), metalForm('copper', 'raw_materials', 'ore'));
|
||||||
|
|
||||||
console.log(`Setting up blends...`);
|
|
||||||
// These are the only blends you can make by hand, aka pre-smelter alloys
|
|
||||||
// FIXME: Remove the hammer from the create mixer
|
|
||||||
event.shapeless(Item.of(metalForm('bronze', 'dusts', 'dust').withCount(4)), [
|
|
||||||
global.dustItem('tin', 2),
|
|
||||||
global.dustItem('copper', 2),
|
|
||||||
'#alltheores:ore_hammers'
|
|
||||||
]).id('kubejs:bronze_mixing_manual_only');
|
|
||||||
event.custom({
|
|
||||||
type: "create:mixing",
|
|
||||||
ingredients: [
|
|
||||||
global.dustItem('tin', 2),
|
|
||||||
global.dustItem('copper', 2),
|
|
||||||
],
|
|
||||||
results: [global.dustItem('tin', 4)]
|
|
||||||
});
|
|
||||||
|
|
||||||
event.shapeless(Item.of(metalForm('brass', 'dusts', 'dust').withCount(4)), [
|
|
||||||
global.dustItem('copper', 3),
|
|
||||||
global.dustItem('zinc', 1),
|
|
||||||
'#alltheores:ore_hammers'
|
|
||||||
]).id(`kubejs:brass_mixing_manual_only`);
|
|
||||||
event.custom({
|
|
||||||
type: "create:mixing",
|
|
||||||
ingredients: [
|
|
||||||
global.dustItem('copper', 3),
|
|
||||||
global.dustItem('zinc', 1),
|
|
||||||
],
|
|
||||||
results: [global.dustItem('brass', 4)]
|
|
||||||
});
|
|
||||||
|
|
||||||
event.shapeless(Item.of(metalForm('invar', 'dusts', 'dust').withCount(4)), [
|
|
||||||
global.dustItem('iron', 2),
|
|
||||||
global.dustItem('nickel', 2),
|
|
||||||
'#alltheores:ore_hammers'
|
|
||||||
]).id('kubejs:invar_mixing_manual_only');
|
|
||||||
event.custom({
|
|
||||||
type: "create:mixing",
|
|
||||||
ingredients: [
|
|
||||||
global.dustItem('iron', 2),
|
|
||||||
global.dustItem('nickel', 2),
|
|
||||||
],
|
|
||||||
results: [global.dustItem('invar', 4)]
|
|
||||||
});
|
|
||||||
|
|
||||||
// Constantan dust consumes your first build grist, and it unlocks the basic grist production line
|
|
||||||
event.shapeless(Item.of(metalForm('constantan', 'dusts', 'dust').withCount(4)),[
|
|
||||||
global.ingotItem('nickel', 2),
|
|
||||||
global.ingotItem('copper', 2),
|
|
||||||
'#kubejs:grist/build/basic',
|
|
||||||
'#alltheores:ore_hammers'
|
|
||||||
]).id('kubejs:constantan_dust_mixing_manual_only');
|
|
||||||
// Constantan is the only metal you can't work on the bench except for gears
|
// Constantan is the only metal you can't work on the bench except for gears
|
||||||
event.shaped('thermal:constantan_gear', [
|
event.shaped('thermal:constantan_gear', [
|
||||||
' A ',
|
' A ',
|
||||||
@ -757,7 +528,7 @@ function foobar() {
|
|||||||
'A': 'minecraft:diamond',
|
'A': 'minecraft:diamond',
|
||||||
'B': 'minecraft:crying_obsidian'
|
'B': 'minecraft:crying_obsidian'
|
||||||
});
|
});
|
||||||
|
|
||||||
// Lapis can be pulverized and hammered.
|
// Lapis can be pulverized and hammered.
|
||||||
event.remove({output: 'thermal:lapis_dust', type: 'thermal:pulverizer'});
|
event.remove({output: 'thermal:lapis_dust', type: 'thermal:pulverizer'});
|
||||||
event.custom({
|
event.custom({
|
||||||
|
@ -67,6 +67,7 @@ RarityJSEvents.register(event => {
|
|||||||
event.setRarity('create:windmill_bearing', 'kubejs:energetic_grist');
|
event.setRarity('create:windmill_bearing', 'kubejs:energetic_grist');
|
||||||
event.setRarity('immersive_aircraft:boiler', 'kubejs:energetic_grist');
|
event.setRarity('immersive_aircraft:boiler', 'kubejs:energetic_grist');
|
||||||
event.setRarity('iron_furnaces:augment_factory', 'kubejs:energetic_grist');
|
event.setRarity('iron_furnaces:augment_factory', 'kubejs:energetic_grist');
|
||||||
|
// "$INST_JAVA" -jar packwiz-installer-bootstrap.jar https://gitea.malloc.hackerbots.net/tdfischer/malloc-s4/raw/branch/main/pack.toml
|
||||||
|
|
||||||
event.setRarityByMod('thermal', 'kubejs:build_grist');
|
event.setRarityByMod('thermal', 'kubejs:build_grist');
|
||||||
event.setRarityByMod('ironfurnaces', 'kubejs:build_grist');
|
event.setRarityByMod('ironfurnaces', 'kubejs:build_grist');
|
||||||
|
@ -6,7 +6,7 @@ pack-format = "packwiz:1.1.0"
|
|||||||
[index]
|
[index]
|
||||||
file = "index.toml"
|
file = "index.toml"
|
||||||
hash-format = "sha256"
|
hash-format = "sha256"
|
||||||
hash = "418a99b12d8d5d98b7a47ac72586c2833cf08315486e9ba0575a24cf0c5c1467"
|
hash = "ff8003c9cacc6a7708f6ae87c1e8387a7673749b5608bc95198bf51426d8bf25"
|
||||||
|
|
||||||
[versions]
|
[versions]
|
||||||
forge = "47.4.0"
|
forge = "47.4.0"
|
||||||
|
Reference in New Issue
Block a user