Skip to content

Commit

Permalink
Fix few bugs with fix/diplomats.lua and fix/merchants.lua
Browse files Browse the repository at this point in the history
  • Loading branch information
warmist committed May 8, 2016
1 parent acac839 commit dde7d15
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 31 deletions.
38 changes: 22 additions & 16 deletions scripts/fix/diplomats.lua
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,14 @@ This was vanilla behaviour until ``0.31.12``, in which the "bug" was "fixed".
=end]]


function update_pos(pos, ent)
pos = df.entity_position:new()
function update_pos(ent)
local pos = df.entity_position:new()
ent.positions.own:insert('#', pos)

pos.code = "DIPLOMAT"
pos.id = ent.positions.next_position_id + 1
ent.positions.next_position_id = ent.positions.next_position_id + 1

pos.flags.DO_NOT_CULL = true
pos.flags.MENIAL_WORK_EXEMPTION = true
pos.flags.SLEEP_PRETENSION = true
Expand All @@ -42,52 +44,56 @@ end



checked = 0
fixed = 0
local checked = 0
local fixed = 0

for _,ent in pairs(df.global.world.entities.all) do
if ent.type == 0 and ent.entity_raw.flags.TREE_CAP_DIPLOMACY then
if ent.type == df.historical_entity_type.Civilization and ent.entity_raw.flags.TREE_CAP_DIPLOMACY then
checked = checked + 1

update = true
local found_position
-- see if we need to add a new position or modify an existing one
for _,pos in pairs(ent.positions.own) do
if pos.responsibilities.MAKE_INTRODUCTIONS and
pos.responsibilities.MAKE_PEACE_AGREEMENTS and
pos.responsibilities.MAKE_TOPIC_AGREEMENTS then
-- a diplomat position exists with the proper responsibilities - skip to the end
update = false
found_position=pos
break
end
-- Diplomat position already exists, but has the wrong options - modify it instead of creating a new one
if pos.code == "DIPLOMAT" then break end
pos = nil
if pos.code == "DIPLOMAT" then
found_position=pos
break
end
end
if update then
-- either there's no diplomat, or there is one and it's got the wrong responsibilities
if not pos then
pos = add_guild_rep(pos, ent)
if not found_position then
found_position = add_guild_rep( ent )
end
-- assign responsibilities
pos.responsibilities.MAKE_INTRODUCTIONS = true
pos.responsibilities.MAKE_PEACE_AGREEMENTS = true
pos.responsibilities.MAKE_TOPIC_AGREEMENTS = true
found_position.responsibilities.MAKE_INTRODUCTIONS = true
found_position.responsibilities.MAKE_PEACE_AGREEMENTS = true
found_position.responsibilities.MAKE_TOPIC_AGREEMENTS = true
end
-- make sure the diplomat position, whether we created it or not, is set up for proper assignment
assign = true
local assign = true
for _,p in pairs(ent.positions.assignments) do
if p.position_id == pos.id then -- it is - nothing more to do here
if p.position_id == found_position.id then -- it is - nothing more to do here
assign = false
break
end
end
if assign then -- it isn't - set it up
asn = df.entity_position_assignment:new()
local asn = df.entity_position_assignment:new()
ent.positions.assignments:insert('#', asn);

asn.id = ent.positions.next_assignment_id
ent.positions.next_assignment_id = asn.id + 1
asn.position_id = pos.id
asn.position_id = found_position.id
asn.flags:resize(math.max(32, #asn.flags)) -- make room for 32 flags
asn.flags[0] = true -- and set the first one
end
Expand Down
39 changes: 24 additions & 15 deletions scripts/fix/merchants.lua
Original file line number Diff line number Diff line change
Expand Up @@ -8,16 +8,17 @@ allowing them to make trade agreements. This was the default behaviour in
``0.28.181.40d`` and earlier.
=end]]
checked = 0
fixed = 0

function add_guild_rep(pos, ent)

function add_guild_rep(ent)
-- there was no guild rep - create it
pos = df.entity_position:new()
local pos = df.entity_position:new()
ent.positions.own:insert('#', pos)

pos.code = "GUILD_REPRESENTATIVE"
pos.id = ent.positions.next_position_id + 1
ent.positions.next_position_id = ent.positions.next_position_id + 1

pos.flags.DO_NOT_CULL = true
pos.flags.MENIAL_WORK_EXEMPTION = true
pos.flags.SLEEP_PRETENSION = true
Expand All @@ -38,51 +39,59 @@ function add_guild_rep(pos, ent)
pos.color[0] = 7
pos.color[1] = 0
pos.color[2] = 1

return pos
end

local checked = 0
local fixed = 0

for _,ent in pairs(df.global.world.entities.all) do
if ent.type == 0 and ent.entity_raw.flags.MERCHANT_NOBILITY then
if ent.type == df.historical_entity_type.Civilization and ent.entity_raw.flags.MERCHANT_NOBILITY then
checked = checked + 1

update = true
-- see if we need to add a new position or modify an existing one
local found_position
for _,pos in pairs(ent.positions.own) do
if pos.responsibilities.TRADE then
if pos.responsibilities.TRADE and pos.responsibilities.ESTABLISH_COLONY_TRADE_AGREEMENTS then
-- a guild rep exists with the proper responsibilities - skip to the end
update = false
found_position=pos
break
end
-- Guild Representative position already exists, but has the wrong options - modify it instead of creating a new one
if pos.code == "GUILD_REPRESENTATIVE" then break end
pos = nil
if pos.code == "GUILD_REPRESENTATIVE" then
found_position=pos
break
end
end
if update then
-- either there's no guild rep, or there is one and it's got the wrong responsibilities
if not pos then
pos = add_guild_rep(pos, ent)
if not found_position then
found_position = add_guild_rep(ent)
end
-- assign responsibilities
pos.responsibilities.ESTABLISH_COLONY_TRADE_AGREEMENTS = true
found_position.responsibilities.ESTABLISH_COLONY_TRADE_AGREEMENTS = true
found_position.responsibilities.TRADE=true
end

-- make sure the guild rep position, whether we created it or not, is set up for proper assignment
assign = true
local assign = true
for _,p in pairs(ent.positions.assignments) do
if p.position_id == pos.id then -- it is - nothing more to do here
if p.position_id == found_position.id then -- it is - nothing more to do here
assign = false
break
end
end
if assign then
-- it isn't - set it up
asn = df.entity_position_assignment:new()
local asn = df.entity_position_assignment:new()
ent.positions.assignments:insert('#', asn)

asn.id = ent.positions.next_assignment_id
ent.positions.next_assignment_id = asn.id + 1
asn.position_id = pos.id
asn.position_id = found_position.id
asn.flags:resize(math.max(32, #asn.flags)) -- make room for 32 flags
asn.flags[0] = true -- and set the first one
end
Expand Down

0 comments on commit dde7d15

Please sign in to comment.