This commit is contained in:
2023-09-19 00:05:54 +09:00
parent ccfcae18d8
commit b53ee80136
15 changed files with 203 additions and 33 deletions

View File

@@ -2,12 +2,14 @@ local items = require 'config'
for k, v in pairs(items['setting']) do for k, v in pairs(items['setting']) do
for k2=1, #v.effect do for k2=1, #v.effect do
if items[v.effect[k2]] ~= nil then
if settings.startup[k].value < items[v.effect[k2]].min then if settings.startup[k].value < items[v.effect[k2]].min then
items[v.effect[k2]].enabled = false items[v.effect[k2]].enabled = false
end end
items[v.effect[k2]][v.type] = settings.startup[k].value items[v.effect[k2]][v.type] = settings.startup[k].value
end end
end
end end
for k, v in pairs(items) do for k, v in pairs(items) do

View File

@@ -165,15 +165,16 @@ local function ET(source, tier)
end end
end end
for k, v in pairs(items['setting']) do for k, v in pairs(items['setting']) do
for k2=1, #v.effect do for k2=1, #v.effect do
if items[v.effect[k2]] ~= nil then
if settings.startup[k].value < items[v.effect[k2]].min then if settings.startup[k].value < items[v.effect[k2]].min then
items[v.effect[k2]].enabled = false items[v.effect[k2]].enabled = false
end end
items[v.effect[k2]][v.type] = settings.startup[k].value items[v.effect[k2]][v.type] = settings.startup[k].value
end end
end
end end
for k, v in pairs(items) do for k, v in pairs(items) do

View File

@@ -1,6 +1,6 @@
{ {
"name": "PHI-EN", "name": "PHI-EN",
"version": "1.3.5", "version": "1.3.6",
"factorio_version": "1.1", "factorio_version": "1.1",
"date": "2023-09-19", "date": "2023-09-19",
"title": "Phidias Energy", "title": "Phidias Energy",

View File

@@ -178,12 +178,14 @@ end
for k, v in pairs(items['setting']) do for k, v in pairs(items['setting']) do
for k2=1, #v.effect do for k2=1, #v.effect do
if items[v.effect[k2]] ~= nil then
if settings.startup[k].value < items[v.effect[k2]].min then if settings.startup[k].value < items[v.effect[k2]].min then
items[v.effect[k2]].enabled = false items[v.effect[k2]].enabled = false
end end
items[v.effect[k2]][v.type] = settings.startup[k].value items[v.effect[k2]][v.type] = settings.startup[k].value
end end
end
end end
for k, v in pairs(items) do for k, v in pairs(items) do

View File

@@ -1,6 +1,6 @@
{ {
"name": "PHI-EQ", "name": "PHI-EQ",
"version": "1.2.1", "version": "1.2.2",
"factorio_version": "1.1", "factorio_version": "1.1",
"date": "2023-09-19", "date": "2023-09-19",
"title": "Phidias Equipment", "title": "Phidias Equipment",

View File

@@ -1,4 +1,34 @@
local items = { local items = {
['setting'] = {
['PHI-MB-ASSEMBLING-TIER'] = {
type = 'max',
effect = {'assembling-machine'}
},
['PHI-MB-FURNACE-TIER'] = {
type = 'max',
effect = {'electric-furnace', 'electric-filter-furnace', 'industrial-furnace'}
},
['PHI-MB-OIL-TIER'] = {
type = 'max',
effect = {'oil-refinery', 'chemical-plant', 'fuel-processor', 'se-fuel-refinery'}
},
['PHI-MB-CENTRIFUGE-TIER'] = {
type = 'max',
effect = {'centrifuge'}
},
['PHI-MB-LAB-TIER'] = {
type = 'max',
effect = {'lab'}
},
['PHI-MB-MINING-TIER'] = {
type = 'max',
effect = {'electric-mining-drill', 'pumpjack', 'area-mining-drill'}
},
['PHI-MB-SE-ASSEMBLING-TIER'] = {
type = 'max',
effect = {'se-space-assembling-machine', 'se-space-manufactory', 'se-casting-machine', 'se-pulveriser', 'se-lifesupport-facility'}
}
},
['assembling-machine'] = { ['assembling-machine'] = {
enabled = true, enabled = true,
stage = 1, stage = 1,

View File

@@ -1,5 +1,18 @@
local items = require 'config' local items = require 'config'
for k, v in pairs(items['setting']) do
for k2=1, #v.effect do
if items[v.effect[k2]] ~= nil then
if settings.startup[k].value < items[v.effect[k2]].min then
items[v.effect[k2]].enabled = false
end
items[v.effect[k2]][v.type] = settings.startup[k].value
end
end
end
-- entity -- entity
local function EE(source, tier) local function EE(source, tier)
local item = table.deepcopy(data.raw[source.type][source.ref_name]) local item = table.deepcopy(data.raw[source.type][source.ref_name])
@@ -82,6 +95,25 @@ for _, v in pairs(items) do
end end
end end
for k, v in pairs(items) do
if k ~= 'setting' then
if v.enabled then
data.raw[v.type][v.ref_name].fast_replaceable_group = v.type
if v.max > 2 then
data.raw[v.type][v.name .. '-' .. 2].fast_replaceable_group = data.raw[v.type][v.ref_name].fast_replaceable_group
end
if v.max > v.min then
for j=v.min + 1, v.max do
data.raw[v.type][v.name .. '-' .. j].fast_replaceable_group = data.raw[v.type][v.name .. '-' .. (j - 1)].fast_replaceable_group
end
end
end
end
end
--[[
-- assembling machine -- assembling machine
data.raw['assembling-machine']['assembling-machine-4'].fast_replaceable_group = data.raw['assembling-machine']['assembling-machine-3'].fast_replaceable_group data.raw['assembling-machine']['assembling-machine-4'].fast_replaceable_group = data.raw['assembling-machine']['assembling-machine-3'].fast_replaceable_group
data.raw['assembling-machine']['assembling-machine-5'].fast_replaceable_group = data.raw['assembling-machine']['assembling-machine-4'].fast_replaceable_group data.raw['assembling-machine']['assembling-machine-5'].fast_replaceable_group = data.raw['assembling-machine']['assembling-machine-4'].fast_replaceable_group
@@ -184,3 +216,4 @@ if mods['space-exploration'] then
data.raw['assembling-machine']['se-fuel-refinery-2'].fast_replaceable_group = data.raw['assembling-machine']['se-fuel-refinery'].fast_replaceable_group data.raw['assembling-machine']['se-fuel-refinery-2'].fast_replaceable_group = data.raw['assembling-machine']['se-fuel-refinery'].fast_replaceable_group
data.raw['assembling-machine']['se-fuel-refinery-3'].fast_replaceable_group = data.raw['assembling-machine']['se-fuel-refinery-2'].fast_replaceable_group data.raw['assembling-machine']['se-fuel-refinery-3'].fast_replaceable_group = data.raw['assembling-machine']['se-fuel-refinery-2'].fast_replaceable_group
end end
]]

View File

@@ -85,7 +85,20 @@ local function ET(source, tier)
table.insert(data.raw.technology[source.tech].effects, {type='unlock-recipe', recipe=source.name .. '-' .. tier}) table.insert(data.raw.technology[source.tech].effects, {type='unlock-recipe', recipe=source.name .. '-' .. tier})
end end
for _, v in pairs(items) do for k, v in pairs(items['setting']) do
for k2=1, #v.effect do
if items[v.effect[k2]] ~= nil then
if settings.startup[k].value < items[v.effect[k2]].min then
items[v.effect[k2]].enabled = false
end
items[v.effect[k2]][v.type] = settings.startup[k].value
end
end
end
for k, v in pairs(items) do
if k ~= 'setting' then
if v.enabled then if v.enabled then
if v.stage == 1 then if v.stage == 1 then
for j=v.min, v.max, 1 do for j=v.min, v.max, 1 do
@@ -96,4 +109,5 @@ for _, v in pairs(items) do
end end
end end
end end
end
end end

View File

@@ -1,8 +1,8 @@
{ {
"name": "PHI-MB", "name": "PHI-MB",
"version": "1.0.15", "version": "1.1.0",
"factorio_version": "1.1", "factorio_version": "1.1",
"date": "2023-05-09", "date": "2023-09-19",
"title": "Phidias Megabase", "title": "Phidias Megabase",
"author": "PHIDIAS0303", "author": "PHIDIAS0303",
"contributers": "", "contributers": "",

View File

@@ -111,3 +111,12 @@ se-lifesupport-facility-2=Sustaining life in more hostile environments.
se-lifesupport-facility-3=Sustaining life in more hostile environments. se-lifesupport-facility-3=Sustaining life in more hostile environments.
se-fuel-refinery-2=An automated fuel processing structure. se-fuel-refinery-2=An automated fuel processing structure.
se-fuel-refinery-3=An automated fuel processing structure. se-fuel-refinery-3=An automated fuel processing structure.
[mod-setting-name]
PHI-MB-ASSEMBLING-TIER=Assembling machine
PHI-MB-FURNACE-TIER=Electric furnace
PHI-MB-OIL-TIER=Oil refinery
PHI-MB-CENTRIFUGE-TIER=Centrifuge
PHI-MB-LAB-TIER=Lab
PHI-MB-MINING-TIER=Electric mining drill
PHI-MB-SE-ASSEMBLING-TIER=Space assembling machine

View File

@@ -111,3 +111,12 @@ se-lifesupport-facility-2=過酷な環境での生存を支えます。
se-lifesupport-facility-3=過酷な環境での生存を支えます。 se-lifesupport-facility-3=過酷な環境での生存を支えます。
se-fuel-refinery-2=燃料を自動で製作します。 se-fuel-refinery-2=燃料を自動で製作します。
se-fuel-refinery-3=燃料を自動で製作します。 se-fuel-refinery-3=燃料を自動で製作します。
[mod-setting-name]
PHI-MB-ASSEMBLING-TIER=組立機
PHI-MB-FURNACE-TIER=電気炉
PHI-MB-OIL-TIER=原油精製所
PHI-MB-CENTRIFUGE-TIER=遠心分離機
PHI-MB-LAB-TIER=研究所
PHI-MB-MINING-TIER=電動掘削機
PHI-MB-SE-ASSEMBLING-TIER=宇宙組立機

View File

@@ -111,3 +111,12 @@ se-lifesupport-facility-2=在更加惡劣的環境中支持生命。
se-lifesupport-facility-3=在更加惡劣的環境中支持生命。 se-lifesupport-facility-3=在更加惡劣的環境中支持生命。
se-fuel-refinery-2=一種自動的原油精煉建築物。 se-fuel-refinery-2=一種自動的原油精煉建築物。
se-fuel-refinery-3=一種自動的原油精煉建築物。 se-fuel-refinery-3=一種自動的原油精煉建築物。
[mod-setting-name]
PHI-MB-ASSEMBLING-TIER=組裝機
PHI-MB-FURNACE-TIER=電爐
PHI-MB-OIL-TIER=煉油廠
PHI-MB-CENTRIFUGE-TIER=離心機
PHI-MB-LAB-TIER=實驗室
PHI-MB-MINING-TIER=電能採礦機
PHI-MB-SE-ASSEMBLING-TIER=太空組裝機

View File

@@ -111,3 +111,12 @@ se-lifesupport-facility-2=在更加惡劣的環境中支持生命。
se-lifesupport-facility-3=在更加惡劣的環境中支持生命。 se-lifesupport-facility-3=在更加惡劣的環境中支持生命。
se-fuel-refinery-2=一種自動的原油精煉建築物。 se-fuel-refinery-2=一種自動的原油精煉建築物。
se-fuel-refinery-3=一種自動的原油精煉建築物。 se-fuel-refinery-3=一種自動的原油精煉建築物。
[mod-setting-name]
PHI-MB-ASSEMBLING-TIER=組裝機
PHI-MB-FURNACE-TIER=電爐
PHI-MB-OIL-TIER=煉油廠
PHI-MB-CENTRIFUGE-TIER=離心機
PHI-MB-LAB-TIER=實驗室
PHI-MB-MINING-TIER=電能採礦機
PHI-MB-SE-ASSEMBLING-TIER=太空組裝機

View File

@@ -4,7 +4,8 @@ for _, force in pairs(game.forces) do
local technologies = force.technologies local technologies = force.technologies
local recipes = force.recipes local recipes = force.recipes
for _, v in pairs(items) do for k, v in pairs(items) do
if k ~= 'setting' then
if v.enabled then if v.enabled then
if technologies[v.tech] ~= nil then if technologies[v.tech] ~= nil then
if technologies[v.tech].researched then if technologies[v.tech].researched then
@@ -16,4 +17,5 @@ for _, force in pairs(game.forces) do
end end
end end
end end
end
end end

50
PHI-MB/settings.lua Normal file
View File

@@ -0,0 +1,50 @@
data:extend({{
type = 'int-setting',
name = 'PHI-MB-ASSEMBLING-TIER',
setting_type = 'startup',
default_value = 5,
allowed_values = {3, 4, 5},
order = 'A1'
}, {
type = 'int-setting',
name = 'PHI-MB-FURNACE-TIER',
setting_type = 'startup',
default_value = 3,
allowed_values = {1, 2, 3},
order = 'A2'
}, {
type = 'int-setting',
name = 'PHI-MB-OIL-TIER',
setting_type = 'startup',
default_value = 3,
allowed_values = {1, 2, 3},
order = 'A3'
}, {
type = 'int-setting',
name = 'PHI-MB-CENTRIFUGE-TIER',
setting_type = 'startup',
default_value = 3,
allowed_values = {1, 2, 3},
order = 'A4'
}, {
type = 'int-setting',
name = 'PHI-MB-LAB-TIER',
setting_type = 'startup',
default_value = 3,
allowed_values = {1, 2, 3},
order = 'A5'
}, {
type = 'int-setting',
name = 'PHI-MB-MINING-TIER',
setting_type = 'startup',
default_value = 3,
allowed_values = {1, 2, 3},
order = 'A6'
}, {
type = 'int-setting',
name = 'PHI-MB-SE-ASSEMBLING-TIER',
setting_type = 'startup',
default_value = 3,
allowed_values = {1, 2, 3},
order = 'A7'
}})