From 854802e939248c72435fbd70fe7d62515d7c2099 Mon Sep 17 00:00:00 2001 From: PHIDIAS Date: Wed, 19 Apr 2023 00:43:12 +0900 Subject: [PATCH] Update data.lua --- PHI-MB/data.lua | 152 ++++++++++++++++++++++++++---------------------- 1 file changed, 83 insertions(+), 69 deletions(-) diff --git a/PHI-MB/data.lua b/PHI-MB/data.lua index d1b8905..b48d1c5 100644 --- a/PHI-MB/data.lua +++ b/PHI-MB/data.lua @@ -1,60 +1,81 @@ local alpha_order = {'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm'} local graphics_location = '__PHI-MB__/graphics/' -local items = {'assembling-machine', 'electric-furnace', 'oil-refinery', 'chemical-plant', 'centrifuge', 'lab'} - -local item_min = { - ['assembling-machine'] = 4, - ['electric-furnace'] = 2, - ['oil-refinery'] = 2, - ['chemical-plant'] = 2, - ['centrifuge'] = 2, - ['lab'] = 2 -} - -local item_max = { - ['assembling-machine'] = 5, - ['electric-furnace'] = 3, - ['oil-refinery'] = 3, - ['chemical-plant'] = 3, - ['centrifuge'] = 3, - ['lab'] = 3 +local items = { + ['assembling-machine'] = { + enabled = true, + type = 'assembling-machine', + name = 'assembling-machine', + tech = 'automation-3', + min = 4, + max = 5 + }, + ['electric-furnace'] = { + enabled = true, + type = 'furnace', + name = 'electric-furnace', + tech = 'advanced-material-processing-2', + min = 2, + max = 3 + }, + ['oil-refinery'] = { + enabled = true, + type = 'assembling-machine', + name = 'oil-refinery', + tech = 'oil-processing', + min = 2, + max = 3 + }, + ['chemical-plant'] = { + enabled = true, + type = 'assembling-machine', + name = 'chemical-plant', + tech = 'oil-processing', + min = 2, + max = 3 + }, + ['centrifuge'] = { + enabled = true, + type = 'electric-furnace', + name = 'centrifuge', + tech = 'uranium-processing', + min = 2, + max = 3 + }, + ['lab'] = { + enabled = true, + type = 'lab', + name = 'lab', + tech = 'automation', + min = 2, + max = 3 + } } -- entity local function EE(source, tier) - local item - - if source == 'assembling-machine' then - item = table.deepcopy(data.raw['assembling-machine']['assembling-machine-3']) - elseif source == 'electric-furnace' then - item = table.deepcopy(data.raw['furnace']['electric-furnace']) - elseif source == 'lab' then - item = table.deepcopy(data.raw['lab']['lab']) - else - item = table.deepcopy(data.raw['assembling-machine'][source]) - end + local item = table.deepcopy(data.raw[source.type][source.name]) - item.name = source .. '-' .. tier - item.minable.result = source .. '-' .. tier - item.max_health = item.max_health * (2 ^ (tier - item_min[source] + 1)) + item.name = source.name .. '-' .. tier + item.minable.result = source.name .. '-' .. tier + item.max_health = item.max_health * (2 ^ (tier - source.min + 1)) - if source == 'lab' then - item.researching_speed = item.researching_speed * (2 ^ (tier - item_min[source] + 1)) + if source.type == 'lab' then + item.researching_speed = item.researching_speed * (2 ^ (tier - source.min + 1)) else - item.crafting_speed = item.crafting_speed * (2 ^ (tier - item_min[source] + 1)) - item.energy_source.emissions_per_minute = item.energy_source.emissions_per_minute * (2 ^ (tier - item_min[source] + 1)) + item.crafting_speed = item.crafting_speed * (2 ^ (tier - source.min + 1)) + item.energy_source.emissions_per_minute = item.energy_source.emissions_per_minute * (2 ^ (tier - source.min + 1)) end - item.energy_usage = tonumber(string.match(item.energy_usage, '%d+')) * (2 ^ (tier - item_min[source] + 1)) .. 'kW' + item.energy_usage = tonumber(string.match(item.energy_usage, '%d+')) * (2 ^ (tier - source.min + 1)) .. 'kW' -- item.animation.layers[1].filename = graphics_location .. source .. '-e.png' -- item.animation.layers[1].hr_version.filename = graphics_location .. source ..'-eh.png' -- item.icon = graphics_location .. source .. '-i.png' -- item.icon_size = 64 -- item.icon_mipmaps = 4 - if (tier <= item_max[source] - 1) then - item.next_upgrade = source .. '-' .. (tier + 1) + if (tier <= source.max - 1) then + item.next_upgrade = source.name .. '-' .. (tier + 1) end data:extend({item}) @@ -64,14 +85,14 @@ end local function EI(source, tier) local item - if source == 'assembling-machine' then + if source.name == 'assembling-machine' then item = table.deepcopy(data.raw.item['assembling-machine-3']) else - item = table.deepcopy(data.raw.item[source]) + item = table.deepcopy(data.raw.item[source.name]) end - item.name = source .. '-' .. tier - item.place_result = source .. '-' .. tier + item.name = source.name .. '-' .. tier + item.place_result = source.name .. '-' .. tier -- item.icons = {{icon = graphics_location .. source .. '-i.png', icon_mipmaps = 4, icon_size = 64}} item.order = item.order .. tier data:extend({item}) @@ -79,43 +100,36 @@ end -- recipe local function ER(source, tier) - local na = source + local na = source.name - if (tier >= 3) then + if source.min == tier then + na = source.name + elseif (tier >= 2) then na = na .. '-' .. (tier - 1) end data:extend({{ type = 'recipe', - name = source .. '-' .. tier, + name = source.name .. '-' .. tier, energy_required = 2, enabled = false, ingredients = {{na, 2}}, - result = source .. '-' .. tier, + result = source.name .. '-' .. tier, }}) end -for i=1, #items, 1 do - for j=item_min[items[i]], item_max[items[i]], 1 do - EE(items[i], j) - EI(items[i], j) - ER(items[i], j) - end +-- tech +local function ET(source, tier) + table.insert(data.raw.technology[source.tech].effects, {type='unlock-recipe', recipe=source.name .. '-' .. tier}) end -table.insert(data.raw.technology['automation-3'].effects, {type='unlock-recipe', recipe='assembling-machine-4'}) -table.insert(data.raw.technology['automation-3'].effects, {type='unlock-recipe', recipe='assembling-machine-5'}) - -table.insert(data.raw.technology['advanced-material-processing-2'].effects, {type='unlock-recipe', recipe='electric-furnace-2'}) -table.insert(data.raw.technology['advanced-material-processing-2'].effects, {type='unlock-recipe', recipe='electric-furnace-3'}) - -table.insert(data.raw.technology['oil-processing'].effects, {type='unlock-recipe', recipe='oil-refinery-2'}) -table.insert(data.raw.technology['oil-processing'].effects, {type='unlock-recipe', recipe='oil-refinery-3'}) -table.insert(data.raw.technology['oil-processing'].effects, {type='unlock-recipe', recipe='chemical-plant-2'}) -table.insert(data.raw.technology['oil-processing'].effects, {type='unlock-recipe', recipe='chemical-plant-3'}) - -table.insert(data.raw.technology['uranium-processing'].effects, {type='unlock-recipe', recipe='centrifuge-2'}) -table.insert(data.raw.technology['uranium-processing'].effects, {type='unlock-recipe', recipe='centrifuge-3'}) - -table.insert(data.raw.technology['automation'].effects, {type='unlock-recipe', recipe='lab-2'}) -table.insert(data.raw.technology['automation'].effects, {type='unlock-recipe', recipe='lab-3'}) +for _, v in pairs(items) do + if v.enabled then + for j=v.min, v.max, 1 do + EE(v, j) + EI(v, j) + ER(v, j) + ET(v, j) + end + end +end \ No newline at end of file