diff --git a/res/de/strings.xml b/res/de/strings.xml index aea55a6a9..3b7b88f43 100644 --- a/res/de/strings.xml +++ b/res/de/strings.xml @@ -2200,9 +2200,6 @@ <string name="LERNEN"> <text locale="de">LERNEN</text> </string> - <string name="LIEFERE"> - <text locale="de">LIEFERE</text> - </string> <string name="MACHEN"> <text locale="de">MACHEN</text> </string> @@ -6980,6 +6977,81 @@ <text locale="en">guards the region</text> </string> + <string name="unit_hungers"> + <text locale="de">hungert</text> + <text locale="en">hungry</text> + </string> + + <string name="smod_far"> + <text locale="de">Fernzauber</text> + <text locale="en">far</text> + </string> + + <string name="smod_sea"> + <text locale="de">Seezauber</text> + <text locale="en">sea</text> + </string> + + <string name="smod_ship"> + <text locale="de">Schiffszauber</text> + <text locale="en">ship</text> + </string> + + <string name="smod_nofamiliar"> + <text locale="de">Magier exklusiv</text> + <text locale="en">magicians only</text> + </string> + + <string name="smod_none"> + <text locale="de">Keine</text> + <text locale="en">none</text> + </string> + + <string name="faction_help_one"> + <text locale="de">Wir helfen der Partei</text> + <text locale="en">We are helping the faction</text> + </string> + + <string name="faction_help_many"> + <text locale="de">Wir helfen den Parteien</text> + <text locale="en">We are helping the factions</text> + </string> + + <string name="group_help_one"> + <text locale="de">hilft der Partei</text> + <text locale="en">is helping the faction</text> + </string> + + <string name="group_help_many"> + <text locale="de">hilft den Parteien</text> + <text locale="en">is helping the factions</text> + </string> + + <string name="has_moved_one"> + <text locale="de">hat die Region durchquert</text> + <text locale="en">has traveled through the region</text> + </string> + + <string name="has_moved_many"> + <text locale="de">haben die Region durchquert</text> + <text locale="en">have traveled through the region</text> + </string> + + <string name="see_travel"> + <text locale="de">durchgereist</text> + <text locale="en">travel</text> + </string> + + <string name="see_neighbour"> + <text locale="de">benachbart</text> + <text locale="en">neighbour</text> + </string> + + <string name="see_lighthouse"> + <text locale="de">vom Turm erblickt</text> + <text locale="en">from lighthouse</text> + </string> + <string name="list_and"> <text locale="de"> und </text> <text locale="en"> and </text> diff --git a/scripts/tests/bindings.lua b/scripts/tests/bindings.lua index eb81b21f6..189d34769 100755 --- a/scripts/tests/bindings.lua +++ b/scripts/tests/bindings.lua @@ -23,10 +23,36 @@ function test_process() assert_equal("function", _G.type(eressea.process.set_prefix)) assert_equal("function", _G.type(eressea.process.set_stealth)) assert_equal("function", _G.type(eressea.process.set_status)) - assert_equal("function", _G.type(eressea.process.set_description)) + assert_equal("function", _G.type(eressea.process.set_name)) assert_equal("function", _G.type(eressea.process.set_group)) assert_equal("function", _G.type(eressea.process.set_origin)) assert_equal("function", _G.type(eressea.process.quit)) + assert_equal("function", _G.type(eressea.process.study)) + assert_equal("function", _G.type(eressea.process.movement)) + assert_equal("function", _G.type(eressea.process.use)) + assert_equal("function", _G.type(eressea.process.battle)) + assert_equal("function", _G.type(eressea.process.siege)) + assert_equal("function", _G.type(eressea.process.leave)) + assert_equal("function", _G.type(eressea.process.promote)) + assert_equal("function", _G.type(eressea.process.renumber)) + assert_equal("function", _G.type(eressea.process.restack)) + assert_equal("function", _G.type(eressea.process.set_spells)) + assert_equal("function", _G.type(eressea.process.set_help)) + assert_equal("function", _G.type(eressea.process.contact)) + assert_equal("function", _G.type(eressea.process.enter)) + assert_equal("function", _G.type(eressea.process.magic)) + assert_equal("function", _G.type(eressea.process.give_control)) + assert_equal("function", _G.type(eressea.process.regeneration)) + assert_equal("function", _G.type(eressea.process.guard_on)) + assert_equal("function", _G.type(eressea.process.guard_off)) + assert_equal("function", _G.type(eressea.process.explain)) + assert_equal("function", _G.type(eressea.process.messages)) + assert_equal("function", _G.type(eressea.process.reserve)) + assert_equal("function", _G.type(eressea.process.claim)) + assert_equal("function", _G.type(eressea.process.follow)) + assert_equal("function", _G.type(eressea.process.alliance)) + assert_equal("function", _G.type(eressea.process.idle)) + assert_equal("function", _G.type(eressea.process.set_default)) end function test_settings() diff --git a/scripts/tests/common.lua b/scripts/tests/common.lua index b1b69c211..e6b3b8f4a 100755 --- a/scripts/tests/common.lua +++ b/scripts/tests/common.lua @@ -44,18 +44,7 @@ function setup() eressea.settings.set("nmr.timeout", "0") eressea.settings.set("NewbieImmunity", "0") eressea.settings.set("rules.economy.food", "4") -end - -function DISABLE_test_eventbus_fire() - local r = region.create(0, 0, "plain") - local f = faction.create("noreply@eressea.de", "human", "de") - local u = unit.create(f, r) - - function compare_f(u, event, f) - assert_equal(u.faction, f) - end - eventbus.register(u, "weird", compare_f) - eventbus.fire(u, "weird", f) + eressea.settings.set("rules.encounters", "0") end function test_fleeing_units_can_be_transported() @@ -579,6 +568,73 @@ function test_config() assert_not_equal(nil, config.locales) end +local function _test_create_laen() + local r = region.create(0,0, "mountain") + local f1 = faction.create("noreply@eressea.de", "human", "de") + local u1 = unit.create(f1, r, 1) + + -- TODO this is a stupid way to create a laen region + for i = 1, 10000 do + r = region.create(i,0, "mountain") + if r:get_resource("laen") > 2 then + break + end + end + assert(r:get_resource("laen")>2, "could not run test properly, please try again") + + return r, u1 +end + +function test_laen1() + local r, u1 = _test_create_laen() + + u1:add_item("money", 1000) + u1:set_skill("mining", 14) + u1:clear_orders() + u1:add_order("MACHEN Laen") + + process_orders() + assert_equal(0, u1:get_item("laen")) +end + +function test_laen2() + local r, u1 = _test_create_laen() + + u1:add_item("money", 1000) + u1:set_skill("mining", 15) + u1:clear_orders() + u1:add_order("MACHEN Laen") + + local b = building.create(r, "mine") + b.size = 10 + u1.building = b + local laen = r:get_resource("laen") + + process_orders() + assert_equal(2, u1:get_item("laen")) + assert_equal(laen - 2, r:get_resource("laen")) +end + +function test_mine() + local r = region.create(0,0, "mountain") + local f1 = faction.create("noreply@eressea.de", "human", "de") + local u1 = unit.create(f1, r, 1) + + u1:add_item("money", 1000) + u1:set_skill("mining", 1) + u1:clear_orders() + u1:add_order("MACHEN Eisen") + + local b = building.create(r, "mine") + b.size = 10 + u1.building = b + local iron = r:get_resource("iron") + + process_orders() + assert_equal(2, u1:get_item("iron")) -- skill +1 + assert_equal(iron - 1, r:get_resource("iron")) -- only 1/2 is taken away +end + function test_guard_resources() -- this is not quite http://bugs.eressea.de/view.php?id=1756 local r = region.create(0,0, "mountain") @@ -601,12 +657,13 @@ function test_guard_resources() process_orders() local iron = u2:get_item("iron") + assert_true(iron > 0) process_orders() assert_equal(iron, u2:get_item("iron")) end local function is_flag_set(flags, flag) - return math.mod(flags, flag*2) - math.mod(flags, flag) == flag; + return math.fmod(flags, flag*2) - math.fmod(flags, flag) == flag; end function test_hero_hero_transfer() @@ -815,7 +872,7 @@ end local function find_in_report(f, pattern, extension) extension = extension or "nr" local filename = config.reportpath .. "/" .. get_turn() .. "-" .. itoa36(f.id) .. "." .. extension - local report = io.open(filename, 'rt'); + local report = io.open(filename, 'r'); assert_not_nil(report) t = report:read("*all") report:close() @@ -897,6 +954,8 @@ function setup() eressea.free_game() eressea.write_game("free.dat") eressea.settings.set("rules.economy.food", "4") -- FOOD_IS_FREE + eressea.settings.set("rules.encounters", "0") + eressea.settings.set("rules.move.owner_leave", "0") end function test_parser() @@ -905,7 +964,7 @@ function test_parser() local u = unit.create(f, r, 1) local filename = config.basepath .. "/data/orders.txt" - local file = io.open(filename, "w+") + local file = io.open(filename, "w") assert_not_nil(file) file:write('ERESSEA ' .. itoa36(f.id) .. ' "' .. f.password .. '"\n') file:write('EINHEIT ' .. itoa36(u.id) .. "\n") @@ -968,7 +1027,7 @@ function test_bug_1814() local u = unit.create(f, r, 1) local filename = config.basepath .. "/data/1814.txt" - local file = io.open(filename, "w+") + local file = io.open(filename, "w") file:write('ERESSEA ' .. itoa36(f.id) .. ' "' .. f.password .. '"\n') file:write('EINHEIT ' .. itoa36(u.id) .. "\n") file:write("; parse error follows: '\n") @@ -989,11 +1048,11 @@ function test_bug_1679() local u = unit.create(f, r, 1) local filename = config.basepath .. "/data/1679.txt" - local file = io.open(filename, "w+") + local file = io.open(filename, "w") file:write('ERESSEA ' .. itoa36(f.id) .. ' "' .. f.password .. '"\n') file:write('EINHEIT ' .. itoa36(u.id) .. "\n") - file:write("NACH W\n") file:write("ARBEITEN\n") + file:write("NACH W\n") file:close() eressea.read_orders(filename) @@ -1001,7 +1060,7 @@ function test_bug_1679() init_reports() write_report(f) assert_true(find_in_report(f, "Die Einheit kann keine weiteren langen Befehle", "cr")) - assert_true(find_in_report(f, "entdeckt, dass es keinen Weg nach Westen gibt")) + assert_false(find_in_report(f, "entdeckt, dass es keinen Weg nach Westen gibt")) end function test_building_unique0() @@ -1144,7 +1203,12 @@ function test_bug_1875_use_help() assert_equal(0, u:get_item("peasantblood")) assert_equal(0, r:get_resource("peasant")) + assert_equal(0, r:get_resource("peasant")) assert_equal(0, u2:get_potion("peasantblood")) -- first unit helps this unit + if 98~=u:get_potion("peasantblood") then + print(get_turn(), f, u) + write_reports() + end assert_equal(98, u:get_potion("peasantblood")) -- unit uses one peasantblood effect end @@ -1176,3 +1240,97 @@ function test_bug_1875_use_own_first() assert_equal(99, u:get_potion("peasantblood")) -- unit uses one peasantblood effect assert_equal(99, u2:get_potion("peasantblood")) -- u2 uses its own effect before u's end + + +function test_bug_1879_follow_unit() + local r = region.create(0, 0, "plain") + local r1 = region.create(1, 0, "plain") + local f = faction.create("noreply@eressea.de", "human", "de") + local u1, u2 = two_units(r, f, f) + u1:clear_orders() + u1:set_skill("magic", 10) + u1:add_order("ZAUBERE STUFE 1 Kleine Fl�che") + u1:add_order("FOLGEN EINHEIT " .. itoa36(u2.id)) + u2:clear_orders() + u2:add_order("NACH o") + process_orders() + assert_equal(u1.region.id, r1.id) + assert_equal(u2.region.id, r1.id) +end + +function test_bug_1870_leave_enter_e2() + local r = region.create(0, 0, "plain") + local f = faction.create("noreply@eressea.de", "human", "de") + local u1, u2 = two_units(r, f, f) + local mine = building.create(r, "mine") + mine.size = 10 + u1.building = mine + + local b = building.create(r, "castle") + b.size = 10 + u2.building = b + + u1:clear_orders() + u1:add_order("LERNEN Burgenbau ") + u1:add_order("BETRETEN BURG " .. itoa36(b.id)) + + eressea.settings.set("rules.move.owner_leave", "0") + process_orders() + assert_equal(u1.building.id, b.id) +end + +function test_bug_1870_leave_enter_e3() + local r = region.create(0, 0, "plain") + local f = faction.create("noreply@eressea.de", "human", "de") + local u1, u2 = two_units(r, f, f) + local mine = building.create(r, "mine") + mine.size = 10 + u1.building = mine + + local b = building.create(r, "castle") + b.size = 10 + u2.building = b + + u1:clear_orders() + u1:add_order("LERNEN Burgenbau ") + u1:add_order("BETRETEN BURG " .. itoa36(b.id)) + + eressea.settings.set("rules.move.owner_leave", "1") + process_orders() + assert_equal(u1.building.id, mine.id) +end + +function test_bug_1795_limit() + local r = region.create(0, 0, "plain") + local f = faction.create("noreply@eressea.de", "human", "de") + local u1 = one_unit(r,f) + u1:add_item("money", 100000000) + u1:add_order("REKRUTIEREN 9999") + r:set_resource("peasant", 2000) -- no fractional growth! + local peasants = r:get_resource("peasant") + local limit,frac = math.modf(peasants/40) -- one day this should be a parameter + local growth = peasants * 0.001 + + process_orders() + + assert_equal(limit+1, u1.number, u1.number .. "!=" .. (limit+1)) + assert_equal(peasants+growth-limit, r:get_resource("peasant")) +end + +function test_bug_1795_demons() + local r = region.create(0, 0, "plain") + local f = faction.create("noreply@eressea.de", "demon", "de") + local u1 = one_unit(r,f) + r:set_resource("peasant", 2000) + local peasants = r:get_resource("peasant") + local limit,frac = math.modf(peasants/40) + local growth = peasants * 0.001 + + u1:add_item("money", 100000000) + u1:add_order("REKRUTIEREN 9999") + + process_orders() + + assert_equal(limit+1, u1.number, u1.number .. "!=" .. (limit+1)) + assert_equal(peasants+growth, r:get_resource("peasant")) +end diff --git a/scripts/tests/orders.lua b/scripts/tests/orders.lua index 2fc1e5b77..a2e568525 100755 --- a/scripts/tests/orders.lua +++ b/scripts/tests/orders.lua @@ -2,6 +2,8 @@ require "lunit" local _G = _G local eressea = eressea +local default_ship = config.ships[1] +local default_building = config.buildings[1] module("tests.orders", lunit.testcase) @@ -12,7 +14,7 @@ function setup() r = _G.region.create(0, 0, "mountain") f = _G.faction.create("noreply@eressea.de", "human", "de") u = _G.unit.create(f, r, 1) - u:clear_orders() + u:clear_orders() eressea.settings.set("rules.economy.food", "4") eressea.settings.set("nmr.removenewbie", "0") eressea.settings.set("nmr.timeout", "0") @@ -20,88 +22,245 @@ function setup() end function test_learn() - u:add_order("LERNEN Hiebwaffen") - _G.process_orders() - assert_not_equal(0, u:get_skill("melee")) + u:add_order("LERNEN Hiebwaffen") + _G.process_orders() + assert_not_equal(0, u:get_skill("melee")) end function test_give() - local u2 = _G.unit.create(f, r, 1) - u:add_item("money", 10) - u:add_order("GIB " .. u2.id .. "5 SILBER") - _G.process_orders() - assert_not_equal(5, u:get_item("money")) - assert_not_equal(5, u2:get_item("money")) + local u2 = _G.unit.create(f, r, 1) + u:add_item("money", 10) + u:add_order("GIB " .. u2.id .. "5 SILBER") + _G.process_orders() + assert_not_equal(5, u:get_item("money")) + assert_not_equal(5, u2:get_item("money")) end function test_make_temp() - u:add_order("MACHE TEMP 123 'Herpderp'") - u:add_order("// this comment will be copied") - u:add_order("ENDE") - eressea.process.make_temp() + u:add_order("MACHE TEMP 123 'Herpderp'") + u:add_order("// this comment will be copied") + u:add_order("ENDE") + eressea.process.make_temp() - for x in f.units do - if x.name == 'Herpderp' then u=x end - end - assert_equal('Herpderp', u.name) - assert_equal(0, u.number) - local c = 0 - for o in u.orders do - assert_equal('// this comment will be copied', o) - c = c + 1 - end - assert_equal(1, c) + for x in f.units do + if x.name == 'Herpderp' then u=x end + end + assert_equal('Herpderp', u.name) + assert_equal(0, u.number) + local c = 0 + for o in u.orders do + assert_equal('// this comment will be copied', o) + c = c + 1 + end + assert_equal(1, c) end function test_give_temp() - u.number = 2 - u:add_order("GIB TEMP 123 1 PERSON") - u:add_order("MACHE TEMP 123 'Herpderp'") - u:add_order("ENDE") - _G.process_orders() - assert_equal(1, u.number) + u.number = 2 + u:add_order("GIB TEMP 123 1 PERSON") + u:add_order("MACHE TEMP 123 'Herpderp'") + u:add_order("ENDE") + _G.process_orders() + assert_equal(1, u.number) - for x in f.units do - if x.name == 'Herpderp' then u=x end - end - assert_equal('Herpderp', u.name) - assert_equal(1, u.number) + for x in f.units do + if x.name == 'Herpderp' then u=x end + end + assert_equal('Herpderp', u.name) + assert_equal(1, u.number) end function test_process_settings() - f.options = 0 - u:add_order("EMAIL herp@derp.com") - u:add_order("BANNER 'Herpderp'") - u:add_order("PASSWORT 'HerpDerp'") - u:add_order("OPTION AUSWERTUNG") - eressea.process.settings() - assert_equal("herp@derp.com", f.email) - assert_equal("Herpderp", f.info) - assert_equal("HerpDerp", f.password) - assert_equal(1, f.options) + f.options = 0 + u:add_order("EMAIL herp@derp.com") + u:add_order("BANNER 'Herpderp'") + u:add_order("PASSWORT 'HerpDerp'") + u:add_order("OPTION AUSWERTUNG") + eressea.process.settings() + assert_equal("herp@derp.com", f.email) + assert_equal("Herpderp", f.info) + assert_equal("HerpDerp", f.password) + assert_equal(1, f.options) end function test_process_group() - u:add_order("GRUPPE herp") - eressea.process.set_group() - assert_equal('herp', u.group) + u:add_order("GRUPPE herp") + eressea.process.set_group() + assert_equal('herp', u.group) end function test_process_origin() - u:add_order("URSPRUNG 1 2") - eressea.process.set_origin() - x, y = u.faction:get_origin() - assert_equal(1, x) - assert_equal(2, y) + u:add_order("URSPRUNG 1 2") + eressea.process.set_origin() + x, y = u.faction:get_origin() + assert_equal(1, x) + assert_equal(2, y) end function test_process_quit() - fno = f.id - u:add_order("STIRB '" .. u.faction.password .. "'") - assert_not_equal(nil, _G.get_faction(fno)) - eressea.process.quit() - eressea.write_game('test.dat') - eressea.free_game() - eressea.read_game('test.dat') - assert_equal(nil, _G.get_faction(fno)) + fno = f.id + u:add_order("STIRB '" .. u.faction.password .. "'") + assert_not_equal(nil, _G.get_faction(fno)) + eressea.process.quit() + eressea.write_game('test.dat') + eressea.free_game() + eressea.read_game('test.dat') + assert_equal(nil, _G.get_faction(fno)) +end + +function test_process_make() + u.region:set_resource('tree', 100) + u:set_skill('forestry', 1) + u:add_order('MACHE HOLZ') + eressea.process.produce() + assert_equal(1, u:get_item('log')) +end + +function test_process_study() + u:add_order("LERNEN Holzfaellen") + eressea.process.update_long_order() + eressea.process.study() + x, y = u.faction:get_origin() + assert_equal(1, u:get_skill('forestry')) +end + +function test_process_teach() + eressea.settings.set("study.random_progress", "0") + u:set_skill('forestry', 3) + u2 = _G.unit.create(f, r, 10) + u2:clear_orders() + u2:set_skill('forestry', 1) + u2:add_order("LERNEN Holzfaellen") + u:add_order("LEHREN " .. _G.itoa36(u2.id)) + eressea.process.update_long_order() + eressea.process.study() + assert_equal(2, u2:get_skill('forestry')) +end + +function test_process_move() + r2 = _G.region.create(1, 0, 'plain') + u:add_order('NACH O') + assert_not_equal(r2.id, u.region.id) + eressea.process.update_long_order() + eressea.process.movement() + assert_equal(r2, u.region) +end + +function test_process_leave() + r2 = _G.region.create(1, 0, 'plain') + b = _G.building.create(r, default_building) + u.building = b + assert_equal(b, u.building) + u:add_order('VERLASSEN') + eressea.process.leave() + assert_not_equal(b, u.building) +end + +function test_process_name_unit() + u:add_order("BENENNE EINHEIT 'Weasel'") + u:add_order("BESCHREIBE EINHEIT 'Juanita'") + eressea.process.set_name() + assert_equal('Weasel', u.name) + assert_equal('Juanita', u.info) +end + +function test_process_name_faction() + u:add_order("BENENNE PARTEI 'Herpderp'") + eressea.process.set_name() + assert_equal('Herpderp', f.name) +end + +function test_process_name_building() + u:add_order("BENENNE GEBAEUDE 'Herpderp'") + u.building = _G.building.create(r, default_building) + eressea.process.set_name() + assert_equal('Herpderp', u.building.name) +end + +function test_process_name_ship() + u:add_order("BENENNE SCHIFF 'Herpderp'") + u.ship = _G.ship.create(r, default_ship) + eressea.process.set_name() + assert_equal('Herpderp', u.ship.name) +end + +function test_process_renumber() + u:add_order("NUMMER EINHEIT 'ii'") + eressea.process.renumber() + assert_equal(666, u.id) +end + +function test_process_enter() + b = _G.building.create(r, default_building) + u:add_order("BETRETEN GEBAEUDE " .. _G.itoa36(b.id)) + eressea.process.enter(1) + assert_equal(b, u.building) +end + +function test_process_restack() + eressea.process.restack() +end + +function test_process_setspells() + eressea.process.set_spells() +end + +function test_process_help() + eressea.process.set_help() +end + +function test_process_contact() + eressea.process.contact() +end + +function test_process_battle() + eressea.process.battle() +end + +function test_process_magic() + eressea.process.magic() +end + +function test_process_give_control() + eressea.process.give_control() +end + +function test_process_regeneration() + eressea.process.regeneration() +end + +function test_process_guard_on() + eressea.process.guard_on() +end + +function test_process_guard_off() + eressea.process.guard_off() +end + +function test_process_explain() + eressea.process.explain() +end + +function test_process_messages() + eressea.process.messages() +end + +function test_process_reserve() + eressea.process.reserve() +end + +function test_process_claim() + eressea.process.claim() +end + +function test_process_follow() + eressea.process.follow() +end + +function test_process_idle() + eressea.process.idle() +end + +function test_process_set_default() + eressea.process.set_default() end diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 6f0c4e115..633509d2d 100755 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -3,6 +3,7 @@ project (eressea C) IF(CMAKE_COMPILER_IS_GNUCC) SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pedantic -Wall -Werror -Wno-unknown-pragmas -Wstrict-prototypes -Wpointer-arith -Wno-char-subscripts -Wno-long-long") + SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c99 -DHAVE__BOOL") ELSE(CMAKE_COMPILER_IS_GNUCC) MESSAGE(STATUS "Unknown compiler ${CMAKE_C_COMPILER_ID}") ENDIF(CMAKE_COMPILER_IS_GNUCC) @@ -12,14 +13,13 @@ set (ERESSEA_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR} CACHE INTERNAL "Eressea Cor add_subdirectory(bindings) -find_package (Lua51 REQUIRED) +find_package (Lua 5 REQUIRED) find_package (ToLua REQUIRED) find_package (LibXml2 REQUIRED) find_package (Curses REQUIRED) find_package (SQLite3 REQUIRED) set (ERESSEA_LIBRARIES - ${BSON_LIBRARIES} ${CUTEST_LIBRARIES} ${CRITBIT_LIBRARIES} ${QUICKLIST_LIBRARIES} @@ -40,7 +40,6 @@ include_directories (${CUTEST_INCLUDE_DIR}) include_directories (${LUA_INCLUDE_DIR}) include_directories (${TOLUA_INCLUDE_DIR}) include_directories (${LIBXML2_INCLUDE_DIR}) -include_directories (${BSON_INCLUDE_DIR}) include_directories (${INIPARSER_INCLUDE_DIR}) FILE (GLOB_RECURSE LIB_HDR *.h) @@ -51,6 +50,7 @@ set (TEST_SRC gamecode/economy_test.c gamecode/laws_test.c gamecode/market_test.c + kernel/ally_test.c kernel/battle_test.c kernel/building_test.c kernel/curse_test.c @@ -117,6 +117,7 @@ set (LIB_SRC items/xerewards.c kernel/alchemy.c kernel/alliance.c + kernel/ally.c kernel/battle.c kernel/binarystore.c kernel/build.c @@ -162,7 +163,6 @@ set (LIB_SRC modules/score.c modules/weather.c modules/wormhole.c - modules/xecmd.c modules/xmas.c triggers/changefaction.c triggers/changerace.c @@ -184,7 +184,6 @@ set (LIB_SRC util/console.c util/crmessage.c util/dice.c - util/eventbus.c util/event.c util/filereader.c util/functions.c diff --git a/src/attributes/moved.c b/src/attributes/moved.c index d73b3e541..6ddad1b17 100644 --- a/src/attributes/moved.c +++ b/src/attributes/moved.c @@ -48,7 +48,7 @@ attrib_type at_moved = { "moved", NULL, NULL, age_moved, write_moved, read_moved }; -boolean get_moved(attrib ** alist) +bool get_moved(attrib ** alist) { return a_find(*alist, &at_moved) ? true : false; } diff --git a/src/attributes/moved.h b/src/attributes/moved.h index cce9fe941..bad4dcdd5 100644 --- a/src/attributes/moved.h +++ b/src/attributes/moved.h @@ -25,7 +25,7 @@ extern "C" { struct attrib; struct attrib_type; - extern boolean get_moved(struct attrib **alist); + extern bool get_moved(struct attrib **alist); extern void set_moved(struct attrib **alist); extern struct attrib_type at_moved; diff --git a/src/attributes/movement.c b/src/attributes/movement.c index 8e2515854..1f3bf51c0 100644 --- a/src/attributes/movement.c +++ b/src/attributes/movement.c @@ -42,7 +42,7 @@ attrib_type at_movement = { "movement", NULL, NULL, NULL, write_movement, read_movement }; -boolean get_movement(attrib * const *alist, int type) +bool get_movement(attrib * const *alist, int type) { const attrib *a = a_findc(*alist, &at_movement); if (a == NULL) diff --git a/src/attributes/movement.h b/src/attributes/movement.h index b976a67ec..0fe4cfc83 100644 --- a/src/attributes/movement.h +++ b/src/attributes/movement.h @@ -22,7 +22,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. extern "C" { #endif - extern boolean get_movement(struct attrib *const *alist, int type); + extern bool get_movement(struct attrib *const *alist, int type); extern void set_movement(struct attrib **alist, int type); extern struct attrib_type at_movement; diff --git a/src/bindings/CMakeLists.txt b/src/bindings/CMakeLists.txt index 821238b20..56310c2d3 100755 --- a/src/bindings/CMakeLists.txt +++ b/src/bindings/CMakeLists.txt @@ -9,7 +9,7 @@ ENDIF(CMAKE_COMPILER_IS_GNUCC) set (BINDINGS_LIBRARY ${PROJECT_NAME} CACHE INTERNAL "Eressea Lua Bindings") -find_package (Lua51 REQUIRED) +find_package (Lua 5 REQUIRED) find_package (ToLua REQUIRED) find_package (LibXml2 REQUIRED) find_package (Curses REQUIRED) @@ -23,7 +23,6 @@ include_directories (${CUTEST_INCLUDE_DIR}) include_directories (${LUA_INCLUDE_DIR}) include_directories (${TOLUA_INCLUDE_DIR}) include_directories (${LIBXML2_INCLUDE_DIR}) -include_directories (${BSON_INCLUDE_DIR}) include_directories (${INIPARSER_INCLUDE_DIR}) FILE (GLOB_RECURSE LIB_HDR *.h) diff --git a/src/bindings/bind_building.c b/src/bindings/bind_building.c index 4e51a0a65..230ba5b88 100644 --- a/src/bindings/bind_building.c +++ b/src/bindings/bind_building.c @@ -21,7 +21,6 @@ without prior permission by the authors of Eressea. #include <util/language.h> -#include <lua.h> #include <tolua.h> int tolua_buildinglist_next(lua_State * L) diff --git a/src/bindings/bind_faction.c b/src/bindings/bind_faction.c index 111b49f37..d5efd226c 100644 --- a/src/bindings/bind_faction.c +++ b/src/bindings/bind_faction.c @@ -29,7 +29,6 @@ without prior permission by the authors of Eressea. #include <util/log.h> #include <quicklist.h> -#include <lua.h> #include <tolua.h> int tolua_factionlist_next(lua_State * L) diff --git a/src/bindings/bind_gmtool.c b/src/bindings/bind_gmtool.c index a55cb75b7..654f16f30 100644 --- a/src/bindings/bind_gmtool.c +++ b/src/bindings/bind_gmtool.c @@ -11,7 +11,6 @@ #include <modules/autoseed.h> #include <util/log.h> -#include <lua.h> #include <tolua.h> static int tolua_run_mapper(lua_State * L) diff --git a/src/bindings/bind_hashtable.c b/src/bindings/bind_hashtable.c index 2069e272b..17c6c4975 100644 --- a/src/bindings/bind_hashtable.c +++ b/src/bindings/bind_hashtable.c @@ -23,7 +23,6 @@ without prior permission by the authors of Eressea. #include <util/variant.h> #include <util/attrib.h> -#include <lua.h> #include <tolua.h> #include <assert.h> diff --git a/src/bindings/bind_message.c b/src/bindings/bind_message.c index 6ff30e98a..2959c6c5c 100644 --- a/src/bindings/bind_message.c +++ b/src/bindings/bind_message.c @@ -13,7 +13,6 @@ #include <util/message.h> /* lua includes */ -#include <lua.h> #include <tolua.h> #include <assert.h> diff --git a/src/bindings/bind_process.c b/src/bindings/bind_process.c index 105a68480..83420578b 100755 --- a/src/bindings/bind_process.c +++ b/src/bindings/bind_process.c @@ -2,20 +2,83 @@ #include <platform.h> #include <kernel/types.h> +#include <kernel/alliance.h> +#include <kernel/config.h> +#include <kernel/magic.h> #include <kernel/order.h> +#include <kernel/battle.h> #include <kernel/region.h> +#include <kernel/terrain.h> #include <kernel/unit.h> +#include <kernel/move.h> #include <gamecode/economy.h> #include <gamecode/laws.h> #include <gamecode/market.h> +#include <gamecode/study.h> + +#define PROC_LAND_REGION 0x0001 +#define PROC_LONG_ORDER 0x0002 + +static void process_cmd(keyword_t kwd, int (*callback)(unit *, order *), int flags) +{ + region * r; + for (r=regions; r; r=r->next) { + unit * u; + + /* look for shortcuts */ + if (flags&PROC_LAND_REGION) { + /* only execute when we are on solid terrain */ + while (r && (r->terrain->flags&LAND_REGION)==0) { + r = r->next; + } + if (!r) break; + } + + for (u=r->units; u; u=u->next) { + if (flags & PROC_LONG_ORDER) { + if (kwd == get_keyword(u->thisorder)) { + callback(u, u->thisorder); + } + } else { + order * ord; + for (ord=u->orders; ord; ord=ord->next) { + if (kwd == get_keyword(ord)) { + callback(u, ord); + } + } + } + } + } +} void process_produce(void) { struct region *r; for (r = regions; r; r = r->next) { + unit * u; + for (u=r->units; u; u=u->next) { + order * ord; + for (ord=u->orders; ord; ord=ord->next) { + if (K_MAKE == get_keyword(ord)) { + make_cmd(u, ord); + } + } + } produce(r); + split_allocations(r); } } +void process_battle(void) { + struct region *r; + for (r = regions; r; r = r->next) { + do_battle(r); + } +} + +void process_siege(void) { + process_cmd(K_BESIEGE, siege_cmd, PROC_LAND_REGION); +} + void process_update_long_order(void) { region * r; for (r=regions; r; r=r->next) { @@ -59,51 +122,173 @@ void process_settings(void) { } } -static void process_cmd(keyword_t kwd, int (*callback)(unit *, order *)) -{ +void process_ally(void) { + process_cmd(K_ALLY, ally_cmd, 0); +} + +void process_prefix(void) { + process_cmd(K_PREFIX, prefix_cmd, 0); +} + +void process_setstealth(void) { + process_cmd(K_SETSTEALTH, setstealth_cmd, 0); +} + +void process_status(void) { + process_cmd(K_STATUS, status_cmd, 0); +} + +void process_name(void) { + process_cmd(K_NAME, name_cmd, 0); + process_cmd(K_DISPLAY, display_cmd, 0); +} + +void process_group(void) { + process_cmd(K_GROUP, group_cmd, 0); +} + +void process_origin(void) { + process_cmd(K_URSPRUNG, origin_cmd, 0); +} + +void process_quit(void) { + process_cmd(K_QUIT, quit_cmd, 0); + quit(); +} + +void process_study(void) { + process_cmd(K_TEACH, teach_cmd, PROC_LONG_ORDER); + process_cmd(K_STUDY, learn_cmd, PROC_LONG_ORDER); +} + +void process_movement(void) { + region * r; + + movement(); + for (r=regions; r; r=r->next) { + if (r->ships) { + sinkships(r); + } + } +} + +void process_use(void) { + process_cmd(K_USE, use_cmd, 0); +} + +void process_leave(void) { + process_cmd(K_LEAVE, leave_cmd, 0); +} + +void process_promote(void) { + process_cmd(K_PROMOTION, promotion_cmd, 0); +} + +void process_renumber(void) { + process_cmd(K_NUMBER, renumber_cmd, 0); + renumber_factions(); +} + +void process_restack(void) { + restack_units(); +} + +void process_setspells(void) { + process_cmd(K_COMBATSPELL, combatspell_cmd, 0); +} + +void process_sethelp(void) { + process_cmd(K_ALLY, ally_cmd, 0); +} + +void process_contact(void) { + process_cmd(K_CONTACT, contact_cmd, 0); +} + +void process_magic(void) { + magic(); +} + +void process_give_control(void) { + process_cmd(K_CONTACT, give_control_cmd, 0); +} + +void process_guard_on(void) { + process_cmd(K_GUARD, guard_on_cmd, PROC_LAND_REGION); +} + +void process_explain(void) { + process_cmd(K_RESHOW, reshow_cmd, 0); +} + +void process_reserve(void) { + process_cmd(K_RESERVE, reserve_cmd, 0); +} + +void process_claim(void) { + process_cmd(K_CLAIM, claim_cmd, 0); +} + +void process_follow(void) { + struct region *r; + for (r = regions; r; r = r->next) { + unit * u; + for (u=r->units; u; u=u->next) { + follow_unit(u); + } + } +} + +void process_messages(void) { + process_cmd(K_MAIL, mail_cmd, 0); +} + +void process_guard_off(void) { + process_cmd(K_GUARD, guard_off_cmd, PROC_LAND_REGION); +} + +void process_regeneration(void) { + monthly_healing(); + regenerate_aura(); +} + +void process_enter(int final) { + region * r; + for (r=regions; r; r=r->next) { + do_enter(r, final); + } +} + +void process_maintenance(void) { region * r; for (r=regions; r; r=r->next) { unit * u; for (u=r->units; u; u=u->next) { order * ord; for (ord=u->orders; ord; ord=ord->next) { - if (kwd == get_keyword(ord)) { - callback(u, ord); + keyword_t kwd = get_keyword(ord); + if (kwd==K_PAY) { + pay_cmd(u, ord); } } } + maintain_buildings(r, 0); } } -void process_ally(void) { - process_cmd(K_ALLY, ally_cmd); +void process_alliance(void) { + alliance_cmd(); } -void process_prefix(void) { - process_cmd(K_PREFIX, prefix_cmd); +void process_idle(void) { + region * r; + for (r=regions; r; r=r->next) { + auto_work(r); + } } -void process_setstealth(void) { - process_cmd(K_SETSTEALTH, setstealth_cmd); -} - -void process_status(void) { - process_cmd(K_STATUS, status_cmd); -} - -void process_display(void) { - process_cmd(K_DISPLAY, display_cmd); -} - -void process_group(void) { - process_cmd(K_GROUP, group_cmd); -} - -void process_origin(void) { - process_cmd(K_URSPRUNG, origin_cmd); -} - -void process_quit(void) { - process_cmd(K_QUIT, quit_cmd); - quit(); +void process_set_default(void) { + if (!global.disabled[K_DEFAULT]) { + defaultorders(); + } } diff --git a/src/bindings/bind_process.h b/src/bindings/bind_process.h index 2cd754135..767c7eb77 100755 --- a/src/bindings/bind_process.h +++ b/src/bindings/bind_process.h @@ -14,10 +14,37 @@ void process_ally(void); void process_prefix(void); void process_setstealth(void); void process_status(void); -void process_display(void); +void process_name(void); void process_group(void); void process_origin(void); void process_quit(void); +void process_study(void); +void process_movement(void); +void process_use(void); +void process_battle(void); +void process_siege(void); +void process_leave(void); +void process_maintenance(void); +void process_promote(void); +void process_renumber(void); +void process_restack(void); +void process_setspells(void); +void process_sethelp(void); +void process_contact(void); +void process_enter(int final); +void process_magic(void); +void process_give_control(void); +void process_regeneration(void); +void process_guard_on(void); +void process_guard_off(void); +void process_explain(void); +void process_messages(void); +void process_reserve(void); +void process_claim(void); +void process_follow(void); +void process_alliance(void); +void process_idle(void); +void process_set_default(void); #ifdef __cplusplus } diff --git a/src/bindings/bind_region.c b/src/bindings/bind_region.c index 58f64203c..b5fb16108 100644 --- a/src/bindings/bind_region.c +++ b/src/bindings/bind_region.c @@ -37,7 +37,6 @@ without prior permission by the authors of Eressea. #include <util/language.h> #include <util/log.h> -#include <lua.h> #include <tolua.h> #include <assert.h> diff --git a/src/bindings/bind_ship.c b/src/bindings/bind_ship.c index d5319dfe0..ddfa883ad 100644 --- a/src/bindings/bind_ship.c +++ b/src/bindings/bind_ship.c @@ -22,7 +22,6 @@ without prior permission by the authors of Eressea. #include <util/language.h> -#include <lua.h> #include <tolua.h> int tolua_shiplist_next(lua_State * L) diff --git a/src/bindings/bind_sqlite.c b/src/bindings/bind_sqlite.c index be1eacec7..6f6c5ea29 100644 --- a/src/bindings/bind_sqlite.c +++ b/src/bindings/bind_sqlite.c @@ -16,12 +16,11 @@ without prior permission by the authors of Eressea. #include "bindings.h" #include <sqlite3.h> -#include <lua.h> #include <tolua.h> #define LTYPE_DB TOLUA_CAST "db" -extern int db_update_factions(sqlite3 * db, boolean force); +extern int db_update_factions(sqlite3 * db, bool force); static int tolua_db_update_factions(lua_State * L) { sqlite3 *db = (sqlite3 *) tolua_tousertype(L, 1, 0); @@ -29,7 +28,7 @@ static int tolua_db_update_factions(lua_State * L) return 0; } -extern int db_update_scores(sqlite3 * db, boolean force); +extern int db_update_scores(sqlite3 * db, bool force); static int tolua_db_update_scores(lua_State * L) { sqlite3 *db = (sqlite3 *) tolua_tousertype(L, 1, 0); diff --git a/src/bindings/bind_storage.c b/src/bindings/bind_storage.c index 5e7768d2d..e2b83b670 100644 --- a/src/bindings/bind_storage.c +++ b/src/bindings/bind_storage.c @@ -22,7 +22,6 @@ without prior permission by the authors of Eressea. #include <math.h> #include <stdio.h> -#include <lua.h> #include <tolua.h> static int tolua_storage_create(lua_State * L) diff --git a/src/bindings/bind_unit.c b/src/bindings/bind_unit.c index 543a9f9d5..5d4dd9b47 100755 --- a/src/bindings/bind_unit.c +++ b/src/bindings/bind_unit.c @@ -51,7 +51,6 @@ without prior permission by the authors of Eressea. #include <util/log.h> #include <quicklist.h> -#include <lua.h> #include <tolua.h> #include <assert.h> diff --git a/src/bindings/bindings.c b/src/bindings/bindings.c index ea86df4a0..904e3e015 100755 --- a/src/bindings/bindings.c +++ b/src/bindings/bindings.c @@ -62,7 +62,6 @@ without prior permission by the authors of Eressea. #include <util/attrib.h> #include <util/base36.h> #include <util/console.h> -#include <util/eventbus.h> #include <util/language.h> #include <util/lists.h> #include <util/log.h> @@ -1007,63 +1006,6 @@ typedef struct event_args { const char *sendertype; } event_args; -static void args_free(void *udata) -{ - free(udata); -} - -static void event_cb(void *sender, const char *event, void *udata) -{ - lua_State *L = (lua_State *) global.vm_state; - event_args *args = (event_args *) udata; - int nargs = 2; - lua_rawgeti(L, LUA_REGISTRYINDEX, args->hfunction); - if (sender && args->sendertype) { - tolua_pushusertype(L, sender, TOLUA_CAST args->sendertype); - } else { - lua_pushnil(L); - } - tolua_pushstring(L, event); - if (args->hargs) { - lua_rawgeti(L, LUA_REGISTRYINDEX, args->hfunction); - ++nargs; - } - lua_pcall(L, nargs, 0, 0); -} - -/* arguments: - * 1: sender (usertype) - * 2: event (string) - * 3: handler (function) - * 4: arguments (any, *optional*) -**/ -static int tolua_eventbus_register(lua_State * L) -{ - void *sender = tolua_tousertype(L, 1, 0); - const char *event = tolua_tostring(L, 2, 0); - event_args *args = (event_args *)malloc(sizeof(event_args)); - args->sendertype = sender ? tolua_typename(L, 1) : NULL; - lua_pushvalue(L, 3); - args->hfunction = luaL_ref(L, LUA_REGISTRYINDEX); - if (lua_type(L, 4) != LUA_TNONE) { - lua_pushvalue(L, 4); - args->hargs = luaL_ref(L, LUA_REGISTRYINDEX); - } else { - args->hargs = 0; - } - eventbus_register(sender, event, &event_cb, &args_free, args); - return 0; -} - -static int tolua_eventbus_fire(lua_State * L) -{ - void *sender = tolua_tousertype(L, 1, 0); - const char *event = tolua_tostring(L, 2, 0); - void *args = NULL; - eventbus_fire(sender, event, args); - return 0; -} - static int tolua_report_unit(lua_State * L) { char buffer[512]; @@ -1145,12 +1087,6 @@ int tolua_bindings_open(lua_State * L) #endif tolua_variable(L, TOLUA_CAST "text", tolua_get_spell_text, 0); } tolua_endmodule(L); - tolua_module(L, TOLUA_CAST "eventbus", 1); - tolua_beginmodule(L, TOLUA_CAST "eventbus"); - { - tolua_function(L, TOLUA_CAST "register", &tolua_eventbus_register); - tolua_function(L, TOLUA_CAST "fire", &tolua_eventbus_fire); - } tolua_endmodule(L); tolua_module(L, TOLUA_CAST "report", 1); tolua_beginmodule(L, TOLUA_CAST "report"); { @@ -1224,34 +1160,9 @@ int tolua_bindings_open(lua_State * L) return 1; } -static const struct { - const char *name; - int (*func) (lua_State *); -} lualibs[] = { - { - "", luaopen_base}, { - LUA_TABLIBNAME, luaopen_table}, { - LUA_IOLIBNAME, luaopen_io}, { - LUA_STRLIBNAME, luaopen_string}, { - LUA_MATHLIBNAME, luaopen_math}, { - LUA_LOADLIBNAME, luaopen_package}, { - LUA_DBLIBNAME, luaopen_debug}, -#if LUA_VERSION_NUM>=501 - { - LUA_OSLIBNAME, luaopen_os}, -#endif - { - NULL, NULL} -}; - static void openlibs(lua_State * L) { - int i; - for (i = 0; lualibs[i].func; ++i) { - lua_pushcfunction(L, lualibs[i].func); - lua_pushstring(L, lualibs[i].name); - lua_call(L, 1, 0); - } + luaL_openlibs(L); } void lua_done(lua_State * L) { @@ -1259,7 +1170,7 @@ void lua_done(lua_State * L) { } lua_State *lua_init(void) { - lua_State *L = lua_open(); + lua_State *L = luaL_newstate(); openlibs(L); #ifdef BINDINGS_TOLUA @@ -1286,7 +1197,7 @@ lua_State *lua_init(void) { int eressea_run(lua_State *L, const char *luafile, const char *entry_point) { - int err; + int err = 0; global.vm_state = L; /* run the main script */ @@ -1303,14 +1214,16 @@ int eressea_run(lua_State *L, const char *luafile, const char *entry_point) } if (entry_point) { lua_getglobal(L, entry_point); - err = lua_pcall(L, 0, 1, 0); - if (err != 0) { - log_lua_error(L); - abort(); + if (lua_isfunction(L, -1)) { + log_debug("calling entry-point: %s\n", entry_point); + err = lua_pcall(L, 0, 1, 0); + if (err != 0) { + log_lua_error(L); + } return err; + } else { + log_error("unknown entry-point: %s\n", entry_point); } - } else { - err = lua_console(L); } - return err; -} + return lua_console(L); +} diff --git a/src/bindings/helpers.c b/src/bindings/helpers.c index f2fbae090..5658f590c 100644 --- a/src/bindings/helpers.c +++ b/src/bindings/helpers.c @@ -31,8 +31,8 @@ without prior permission by the authors of Eressea. #include <gamecode/archetype.h> -#include <lua.h> #include <tolua.h> +#include <lua.h> #include <assert.h> @@ -48,8 +48,7 @@ lua_giveitem(unit * s, unit * d, const item_type * itype, int n, struct order *o strlcpy(fname, iname, sizeof(fname)); strlcat(fname, "_give", sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, s, TOLUA_CAST "unit"); tolua_pushusertype(L, d, TOLUA_CAST "unit"); @@ -81,8 +80,7 @@ static int limit_resource(const region * r, const resource_type * rtype) strlcpy(fname, rtype->_name[0], sizeof(fname)); strlcat(fname, "_limit", sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)r, TOLUA_CAST "region"); @@ -111,8 +109,7 @@ produce_resource(region * r, const resource_type * rtype, int norders) strlcpy(fname, rtype->_name[0], sizeof(fname)); strlcat(fname, "_produce", sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)r, TOLUA_CAST "region"); tolua_pushnumber(L, (lua_Number) norders); @@ -140,8 +137,7 @@ static int lc_age(struct attrib *a) if (fname != NULL) { lua_State *L = (lua_State *) global.vm_state; - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)b, TOLUA_CAST "building"); if (fparam) { @@ -201,8 +197,7 @@ static int lua_callspell(castorder * co) fname = fbuf; } - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { int nparam = 4; tolua_pushusertype(L, r, TOLUA_CAST "region"); @@ -254,8 +249,7 @@ static int lua_initfamiliar(unit * u) strlcpy(fname, "initfamiliar_", sizeof(fname)); strlcat(fname, u->race->_name[0], sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, u, TOLUA_CAST "unit"); @@ -290,8 +284,7 @@ lua_changeresource(unit * u, const struct resource_type *rtype, int delta) strlcpy(fname, rtype->_name[0], sizeof(fname)); strlcat(fname, "_changeresource", sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, u, TOLUA_CAST "unit"); tolua_pushnumber(L, (lua_Number) delta); @@ -321,8 +314,7 @@ static int lua_getresource(unit * u, const struct resource_type *rtype) strlcpy(fname, rtype->_name[0], sizeof(fname)); strlcat(fname, "_getresource", sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, u, TOLUA_CAST "unit"); @@ -342,17 +334,16 @@ static int lua_getresource(unit * u, const struct resource_type *rtype) return result; } -static boolean lua_canuse_item(const unit * u, const struct item_type *itype) +static bool lua_canuse_item(const unit * u, const struct item_type *itype) { static int function_exists = 1; - boolean result = true; + bool result = true; if (function_exists) { lua_State *L = (lua_State *) global.vm_state; const char *fname = "item_canuse"; - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); tolua_pushstring(L, itype->rtype->_name[0]); @@ -381,8 +372,7 @@ lua_wage(const region * r, const faction * f, const race * rc, int in_turn) const char *fname = "wage"; int result = -1; - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)r, TOLUA_CAST "region"); tolua_pushusertype(L, (void *)f, TOLUA_CAST "faction"); @@ -413,8 +403,7 @@ static void lua_agebuilding(building * b) strlcpy(fname, "age_", sizeof(fname)); strlcat(fname, b->type->_name, sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)b, TOLUA_CAST "building"); @@ -435,8 +424,7 @@ static int lua_building_protection(building * b, unit * u) const char *fname = "building_protection"; int result = 0; - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)b, TOLUA_CAST "building"); tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); @@ -462,8 +450,7 @@ static double lua_building_taxes(building * b, int level) const char *fname = "building_taxes"; double result = 0.0F; - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)b, TOLUA_CAST "building"); tolua_pushnumber(L, level); @@ -489,8 +476,7 @@ static int lua_maintenance(const unit * u) const char *fname = "maintenance"; int result = -1; - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); @@ -519,8 +505,7 @@ static int lua_equipmentcallback(const struct equipment *eq, unit * u) strlcpy(fname, "equip_", sizeof(fname)); strlcat(fname, eq->name, sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); @@ -551,8 +536,7 @@ lua_useitem(struct unit *u, const struct item_type *itype, int amount, strlcpy(fname, "use_", sizeof(fname)); strlcat(fname, itype->rtype->_name[0], sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); tolua_pushnumber(L, (lua_Number) amount); @@ -582,8 +566,7 @@ static int lua_recruit(struct unit *u, const struct archetype *arch, int amount) strlcpy(fname, "recruit_", sizeof(fname)); strlcat(fname, arch->name[0], sizeof(fname)); - lua_pushstring(L, fname); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, fname); if (lua_isfunction(L, -1)) { tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit"); tolua_pushnumber(L, (lua_Number) amount); diff --git a/src/bindings/process.pkg b/src/bindings/process.pkg index 37086e1cf..fb68e3a42 100755 --- a/src/bindings/process.pkg +++ b/src/bindings/process.pkg @@ -4,16 +4,43 @@ module eressea { module process { void process_update_long_order @ update_long_order(void); void process_markets @ markets(void); /* operate the e3 markets */ - void process_produce @ produce(void); /* BUY/SELL/ENTERTAIN/WORK/TAX/STEAL/SPY/SABOTAGE/PLANT/BREED/RESEARCH */ + void process_produce @ produce(void); /* MAKE+BUY/SELL/ENTERTAIN/WORK/TAX/STEAL/SPY/SABOTAGE/PLANT/BREED/RESEARCH */ void process_make_temp @ make_temp(void); /* MAKE TEMP */ void process_settings @ settings(void); /* EMAIL/PASSWORD/BANNER/OPTION */ void process_ally @ set_allies(void); /* HELP */ void process_prefix @ set_prefix(void); /* PREFIX */ void process_setstealth @ set_stealth(void); /* STEALTH */ void process_status @ set_status(void); /* STATUS */ - void process_display @ set_description(void); /* DESCRIBE */ + void process_name @ set_name(void); /* NAME/DISPLAY */ void process_group @ set_group(void); /* GROUP */ void process_origin @ set_origin(void); /* ORIGIN */ void process_quit @ quit(void); /* QUIT */ + void process_study @ study(void); /* LEARN/TEACH */ + void process_movement @ movement(void); /* MOVE/FOLLOW/ROUTE */ + void process_use @ use(void); /* USE */ + void process_battle @ battle(void); /* ATTACK */ + void process_siege @ siege(void); /* SIEGE */ + void process_leave @ leave(void); /* LEAVE */ + void process_maintenance @ maintenance(void); /* PAY */ + void process_promote @ promote(void); /* PROMOTE */ + void process_renumber @ renumber(void); /* RENUMBER */ + void process_restack @ restack(void); /* SORT */ + void process_setspells @ set_spells(void); /* COMBATSPELL */ + void process_sethelp @ set_help(void); /* HELP */ + void process_contact @ contact(void); /* CONTACT */ + void process_enter @ enter(int message); /* ENTER */ + void process_magic @ magic(void); /* CAST */ + void process_give_control @ give_control(void); /* GIVE CONTROL */ + void process_regeneration @ regeneration(void); /* regen health & aura */ + void process_guard_on @ guard_on(void); /* GUARD */ + void process_guard_off @ guard_off(void); /* GUARD NOT */ + void process_explain @ explain(void); /* SHOW */ + void process_messages @ messages(void); /* MESSAGE */ + void process_reserve @ reserve(void); /* RESERVE */ + void process_claim @ claim(void); /* CLAIM */ + void process_follow @ follow(void); /* FOLLOW */ + void process_alliance @ alliance(void); /* FOLLOW */ + void process_idle @ idle(void); /* work.auto */ + void process_set_default @ set_default(void); /* work.auto */ } } diff --git a/src/gamecode/archetype.h b/src/gamecode/archetype.h index 963acd286..55c6896cc 100644 --- a/src/gamecode/archetype.h +++ b/src/gamecode/archetype.h @@ -18,7 +18,7 @@ extern "C" { #endif typedef struct rule { - boolean allow; + bool allow; char *property; char *value; } rule; diff --git a/src/gamecode/creport.c b/src/gamecode/creport.c index 3f7d4fe1d..90374cb4b 100644 --- a/src/gamecode/creport.c +++ b/src/gamecode/creport.c @@ -33,6 +33,7 @@ without prior permission by the authors of Eressea. /* kernel includes */ #include <kernel/alchemy.h> #include <kernel/alliance.h> +#include <kernel/ally.h> #include <kernel/connection.h> #include <kernel/building.h> #include <kernel/curse.h> @@ -80,7 +81,7 @@ without prior permission by the authors of Eressea. /* imports */ extern int verbosity; -boolean opt_cr_absolute_coords = false; +bool opt_cr_absolute_coords = false; /* globals */ #define C_REPORT_VERSION 66 @@ -177,7 +178,7 @@ static void print_items(FILE * F, item * items, const struct locale *lang) static void cr_output_curses(FILE * F, const faction * viewer, const void *obj, objtype_t typ) { - boolean header = false; + bool header = false; attrib *a = NULL; int self = 0; region *r; @@ -508,7 +509,7 @@ static void render_messages(FILE * F, faction * f, message_list * msgs) struct mlist *m = msgs->begin; while (m) { char crbuffer[BUFFERSIZE]; /* gross, wegen spionage-messages :-( */ - boolean printed = false; + bool printed = false; const struct message_type *mtype = m->msg->type; unsigned int hash = mtype->key; #ifdef RENDER_CRMESSAGES @@ -637,7 +638,7 @@ cr_output_ship(FILE * F, const ship * sh, const unit * u, int fcaptain, static void fwriteorder(FILE * F, const struct order *ord, const struct locale *lang, - boolean escape) + bool escape) { char ebuf[1024]; char obuf[1024]; @@ -690,9 +691,9 @@ static void cr_output_unit(FILE * F, const region * r, const faction * f, const char *pzTmp; skill *sv; const attrib *a_fshidden = NULL; - boolean itemcloak = false; + bool itemcloak = false; static const curse_type *itemcloak_ct = 0; - static boolean init = false; + static bool init = false; item result[MAX_INVENTORY]; if (fval(u->race, RCF_INVISIBLE)) @@ -1096,7 +1097,7 @@ cr_borders(seen_region ** seen, const region * r, const faction * f, } b = get_borders(r, r2); while (b) { - boolean cs = b->type->fvisible(b, f, r); + bool cs = b->type->fvisible(b, f, r); if (!cs) { cs = b->type->rvisible(b, r); @@ -1352,7 +1353,7 @@ static void cr_output_region(FILE * F, report_context * ctx, seen_region * sr) /* describe both passed and inhabited regions */ show_active_spells(r); if (fval(r, RF_TRAVELUNIT)) { - boolean seeunits = false, seeships = false; + bool seeunits = false, seeships = false; const attrib *ru; /* show units pulled through region */ for (ru = a_find(r->attribs, &at_travelunit); diff --git a/src/gamecode/economy.c b/src/gamecode/economy.c index cd47f880a..10de6365d 100644 --- a/src/gamecode/economy.c +++ b/src/gamecode/economy.c @@ -89,7 +89,7 @@ typedef struct request { int qty; int no; union { - boolean goblin; /* stealing */ + bool goblin; /* stealing */ const struct luxury_type *ltype; /* trading */ } type; } request; @@ -215,6 +215,9 @@ typedef struct recruitment { int total, assigned; } recruitment; +/** Creates a list of recruitment structs, one for each faction. Adds every quantifyable request + * to the faction's struct and to total. + */ static recruitment *select_recruitment(request ** rop, int (*quantify) (const struct race *, int), int *total) { @@ -292,14 +295,14 @@ static int any_recruiters(const struct race *rc, int qty) return (int)(qty * 2 * rc->recruit_multi); } -static int peasant_recruiters(const struct race *rc, int qty) +/*static int peasant_recruiters(const struct race *rc, int qty) { if (rc->ec_flags & ECF_REC_ETHEREAL) return -1; if (rc->ec_flags & ECF_REC_HORSES) return -1; return (int)(qty * 2 * rc->recruit_multi); -} +}*/ static int horse_recruiters(const struct race *rc, int qty) { @@ -315,10 +318,12 @@ static int do_recruiting(recruitment * recruits, int available) recruitment *rec; int recruited = 0; + /* try to assign recruits to factions fairly */ while (available > 0) { int n = 0; int rest, mintotal = INT_MAX; + /* find smallest request */ for (rec = recruits; rec != NULL; rec = rec->next) { int want = rec->total - rec->assigned; if (want > 0) { @@ -334,6 +339,8 @@ static int do_recruiting(recruitment * recruits, int available) } rest = available - mintotal * n; + /* assign size of smallest request for everyone if possible; in the end roll dice to assign + * small rest */ for (rec = recruits; rec != NULL; rec = rec->next) { int want = rec->total - rec->assigned; @@ -350,6 +357,7 @@ static int do_recruiting(recruitment * recruits, int available) } } + /* do actual recruiting */ for (rec = recruits; rec != NULL; rec = rec->next) { request *req; int get = rec->assigned; @@ -365,8 +373,6 @@ static int do_recruiting(recruitment * recruits, int available) int afford = get_pooled(u, oldresourcetype[R_SILVER], GET_DEFAULT, number * rc->recruitcost) / rc->recruitcost; number = MIN(number, afford); - use_pooled(u, oldresourcetype[R_SILVER], GET_DEFAULT, - rc->recruitcost * number); } if (u->number + number > UNIT_MAXSIZE) { ADDMSG(&u->faction->msgs, msg_feedback(u, req->ord, "error_unit_size", @@ -374,6 +380,10 @@ static int do_recruiting(recruitment * recruits, int available) number = UNIT_MAXSIZE - u->number; assert(number >= 0); } + if (rc->recruitcost) { + use_pooled(u, oldresourcetype[R_SILVER], GET_DEFAULT, + rc->recruitcost * number); + } add_recruits(u, number, req->qty); dec = (int)(number * multi); if ((rc->ec_flags & ECF_REC_ETHEREAL) == 0) { @@ -392,7 +402,7 @@ static void feedback_give_not_allowed(unit * u, order * ord) "")); } -static boolean check_give(unit * u, unit * u2, const item_type * itype, +static bool check_give(unit * u, unit * u2, const item_type * itype, int mask) { if (u2) { @@ -449,7 +459,7 @@ static void expandrecruit(region * r, request * recruitorders) } /* peasant limited: */ - recruits = select_recruitment(&recruitorders, peasant_recruiters, &orc_total); + recruits = select_recruitment(&recruitorders, any_recruiters, &orc_total); if (recruits) { int orc_recruited, orc_peasants = rpeasants(r) * 2; int orc_frac = orc_peasants / RECRUITFRACTION; /* anzahl orks. 2 ork = 1 bauer */ @@ -464,10 +474,10 @@ static void expandrecruit(region * r, request * recruitorders) /* no limit: */ recruits = select_recruitment(&recruitorders, any_recruiters, &orc_total); if (recruits) { - int recruited, peasants = rpeasants(r); + int recruited, peasants = rpeasants(r) * 2; recruited = do_recruiting(recruits, INT_MAX); if (recruited > 0) { - rsetpeasants(r, peasants - recruited / 2); + rsetpeasants(r, (peasants - recruited) / 2); } free_recruitments(recruits); } @@ -537,7 +547,7 @@ static void recruit(unit * u, struct order *ord, request ** recruitorders) get_gamedate(turn, &date); if (date.season == 0 && r->terrain != newterrain(T_DESERT)) { #ifdef INSECT_POTION - boolean usepotion = false; + bool usepotion = false; unit *u2; for (u2 = r->units; u2; u2 = u2->next) @@ -769,7 +779,7 @@ static void give_cmd(unit * u, order * ord) } else if (p == P_HERBS) { - boolean given = false; + bool given = false; if (!(u->race->ec_flags & GIVEITEM) && u2 != NULL) { ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "race_nogive", "race", u->race)); @@ -996,12 +1006,12 @@ void add_spende(faction * f1, faction * f2, int amount, region * r) r->donations = sp; } -static boolean maintain(building * b, boolean first) +static bool maintain(building * b, bool first) /* first==false -> take money from wherever you can */ { int c; region *r = b->region; - boolean paid = true, work = first; + bool paid = true, work = first; unit *u; if (fval(b, BLD_MAINTAINED) || b->type == NULL || b->type->maintenance == NULL || is_cursed(b->attribs, C_NOCOST, 0)) { @@ -1111,12 +1121,12 @@ static boolean maintain(building * b, boolean first) return true; } -void maintain_buildings(region * r, boolean crash) +void maintain_buildings(region * r, bool crash) { building **bp = &r->buildings; while (*bp) { building *b = *bp; - boolean maintained = maintain(b, !crash); + bool maintained = maintain(b, !crash); /* the second time, send a message */ if (crash) { @@ -1141,7 +1151,7 @@ void maintain_buildings(region * r, boolean crash) static int recruit_archetype(unit * u, order * ord) { - boolean merge = (u->number > 0); + bool merge = (u->number > 0); int want; const char *s; @@ -1178,7 +1188,7 @@ static int recruit_archetype(unit * u, order * ord) */ int k; for (k = 0; arch->rules[k].property; ++k) { - boolean match = false; + bool match = false; if (arch->rules[k].value[0] == '*') match = true; else if (strcmp(arch->rules[k].property, "race") == 0) { @@ -1296,7 +1306,7 @@ void economics(region * r) for (u = r->units; u; u = u->next) { order *ord; - boolean destroyed = false; + bool destroyed = false; if (u->number > 0) { for (ord = u->orders; ord; ord = ord->next) { keyword_t kwd = get_keyword(ord); @@ -1306,7 +1316,7 @@ void economics(region * r) ord = NULL; destroyed = true; } - } else if (kwd == K_GIVE || kwd == K_LIEFERE) { + } else if (kwd == K_GIVE) { give_cmd(u, ord); } else if (kwd == K_FORGET) { forget_cmd(u, ord); @@ -1421,7 +1431,7 @@ typedef struct allocation_list { static allocation_list *allocations; -static boolean can_guard(const unit * guard, const unit * u) +static bool can_guard(const unit * guard, const unit * u) { if (fval(guard, UFL_ISNEW)) return false; @@ -1612,7 +1622,7 @@ leveled_allocation(const resource_type * rtype, region * r, allocation * alist) const item_type *itype = resource2item(rtype); rawmaterial *rm = rm_get(r, rtype); int need; - boolean first = true; + bool first = true; if (rm != NULL) { do { @@ -2373,9 +2383,9 @@ static void expandselling(region * r, request * sellorders, int limit) } } -static boolean sell(unit * u, request ** sellorders, struct order *ord) +static bool sell(unit * u, request ** sellorders, struct order *ord) { - boolean unlimited = true; + bool unlimited = true; const item_type *itype; const luxury_type *ltype = NULL; int n; @@ -2904,7 +2914,7 @@ static int max_skill(region * r, faction * f, skill_t sk) static void steal_cmd(unit * u, struct order *ord, request ** stealorders) { int n, i, id; - boolean goblin = false; + bool goblin = false; request *o; unit *u2 = NULL; region *r = u->region; @@ -3342,7 +3352,7 @@ void produce(struct region *r) unit *u; int todo; static int rule_autowork = -1; - boolean limited = true; + bool limited = true; request *nextworker = workers; assert(r); @@ -3378,7 +3388,7 @@ void produce(struct region *r) for (u = r->units; u; u = u->next) { order *ord; - boolean trader = false; + bool trader = false; if (u->race == new_race[RC_SPELL] || fval(u, UFL_LONGACTION)) continue; diff --git a/src/gamecode/economy.h b/src/gamecode/economy.h index b5ccac86d..8b44df380 100644 --- a/src/gamecode/economy.h +++ b/src/gamecode/economy.h @@ -48,7 +48,7 @@ extern "C" { enum { IC_WORK, IC_ENTERTAIN, IC_TAX, IC_TRADE, IC_TRADETAX, IC_STEAL, IC_MAGIC }; - void maintain_buildings(struct region *r, boolean crash); + void maintain_buildings(struct region *r, bool crash); extern void add_spende(struct faction *f1, struct faction *f2, int betrag, struct region *r); extern int make_cmd(struct unit *u, struct order *ord); diff --git a/src/gamecode/give.c b/src/gamecode/give.c index b9254c7c2..9c259f2cf 100644 --- a/src/gamecode/give.c +++ b/src/gamecode/give.c @@ -87,7 +87,7 @@ add_give(unit * u, unit * u2, int given, int received, } } -static boolean limited_give(const item_type * type) +static bool limited_give(const item_type * type) { /* trade only money 2:1, if at all */ return (type == i_silver); @@ -288,7 +288,7 @@ void give_men(int n, unit * u, unit * u2, struct order *ord) if (u2) { if (u2->number != 0 && recruit_archetypes()) { /* must have same set of skills */ - boolean okay = false; + bool okay = false; if (u->skill_size == u2->skill_size) { int i; for (i = 0; i != u->skill_size; ++i) { diff --git a/src/gamecode/laws.c b/src/gamecode/laws.c index 4ad866a11..cf43535d8 100755 --- a/src/gamecode/laws.c +++ b/src/gamecode/laws.c @@ -37,6 +37,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. /* kernel includes */ #include <kernel/alchemy.h> #include <kernel/alliance.h> +#include <kernel/ally.h> #include <kernel/battle.h> #include <kernel/connection.h> #include <kernel/curse.h> @@ -88,7 +89,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include <util/rng.h> #include <util/xml.h> -#include <modules/xecmd.h> #include <attributes/otherfaction.h> /* libc includes */ @@ -119,9 +119,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #define DMRISEHAFEN 0.2F /* weekly chance that demand goes up with harbor */ /* - exported global symbols ----------------------------------- */ -boolean nobattle = false; -boolean nomonsters = false; -/* ------------------------------------------------------------- */ static int RemoveNMRNewbie(void) { @@ -135,52 +132,17 @@ static int RemoveNMRNewbie(void) return value; } -static void restart_race(unit * u, const race * rc) -{ - faction *oldf = u->faction; - faction *f = addfaction(oldf->email, oldf->passw, rc, oldf->locale, - oldf->subscription); - unit *nu = addplayer(u->region, f); - order **ordp = &u->orders; - f->subscription = u->faction->subscription; - f->age = u->faction->age; - fset(f, FFL_RESTART); - if (f->subscription) { - sql_print( - ("UPDATE subscriptions set faction='%s', race='%s' where id=%u;\n", - itoa36(f->no), dbrace(rc), f->subscription)); - } - f->magiegebiet = u->faction->magiegebiet; - f->options = u->faction->options; - free_orders(&nu->orders); - nu->orders = u->orders; - u->orders = NULL; - while (*ordp) { - order *ord = *ordp; - if (get_keyword(ord) != K_RESTART) { - *ordp = ord->next; - ord->next = NULL; - if (u->thisorder == ord) - set_order(&u->thisorder, NULL); - } else { - ordp = &ord->next; - } - } - destroyfaction(u->faction); -} - static void checkorders(void) { faction *f; - if (verbosity >= 1) - puts(" - Warne spaete Spieler..."); + log_info(" - Warne spaete Spieler..."); for (f = factions; f; f = f->next) if (!is_monsters(f) && turn - f->lastorders == NMRTimeout() - 1) ADDMSG(&f->msgs, msg_message("turnreminder", "")); } -static boolean help_money(const unit * u) +static bool help_money(const unit * u) { if (u->race->ec_flags & GIVEITEM) return true; @@ -1004,8 +966,7 @@ void demographics(void) remove_empty_units(); - if (verbosity >= 1) - puts(" - Einwanderung..."); + log_info(" - Einwanderung..."); for (r = regions; r; r = r->next) { if (r->land && r->land->newpeasants) { int rp = rpeasants(r) + r->land->newpeasants; @@ -1063,51 +1024,112 @@ static void transfer_faction(faction * f, faction * f2) } } -static int restart_cmd(unit * u, struct order *ord) +/* test if the unit can slip through a siege undetected. + * returns 0 if siege is successful, or 1 if the building is either + * not besieged or the unit can slip through the siege due to better stealth. + */ +static int slipthru(const region * r, const unit * u, const building * b) { + unit *u2; + int n, o; + + /* b ist die burg, in die man hinein oder aus der man heraus will. */ + if (b == NULL || b->besieged < b->size * SIEGEFACTOR) { + return 1; + } + + /* u wird am hinein- oder herausschluepfen gehindert, wenn STEALTH <= + * OBSERVATION +2 der belagerer u2 ist */ + n = eff_skill(u, SK_STEALTH, r); + + for (u2 = r->units; u2; u2 = u2->next) { + if (usiege(u2) == b) { + + if (invisible(u, u2) >= u->number) + continue; + + o = eff_skill(u2, SK_PERCEPTION, r); + + if (o + 2 >= n) { + return 0; /* entdeckt! */ + } + } + } + return 1; +} + +int can_contact(const region * r, const unit * u, const unit * u2) { + + /* hier geht es nur um die belagerung von burgen */ + + if (u->building == u2->building) { + return 1; + } + + /* unit u is trying to contact u2 - unasked for contact. wenn u oder u2 + * nicht in einer burg ist, oder die burg nicht belagert ist, ist + * slipthru () == 1. ansonsten ist es nur 1, wenn man die belagerer */ + + if (slipthru(u->region, u, u->building) && slipthru(u->region, u2, u2->building)) { + return 1; + } + + return (alliedunit(u, u2->faction, HELP_GIVE)); +} + +int contact_cmd(unit * u, order * ord) +{ + /* unit u kontaktiert unit u2. Dies setzt den contact einfach auf 1 - + * ein richtiger toggle ist (noch?) nicht noetig. die region als + * parameter ist nur deswegen wichtig, weil er an getunit () + * weitergegeben wird. dies wird fuer das auffinden von tempunits in + * getnewunit () verwendet! */ + unit *u2; + region *r = u->region; + init_tokens(ord); - skip_token(); /* skip keyword */ + skip_token(); + u2 = getunitg(r, u->faction); - if (!fval(u->region->terrain, LAND_REGION)) { - ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "error_onlandonly", "")); - } else { - const char *s_race = getstrtoken(), *s_pass; - const race *frace = findrace(s_race, u->faction->locale); - - if (!frace) { - frace = u->faction->race; - s_pass = s_race; - } else { - s_pass = getstrtoken(); + if (u2 != NULL) { + if (!can_contact(r, u, u2)) { + cmistake(u, u->thisorder, 23, MSG_EVENT); + return -1; } - - if (u->faction->age > 3 && fval(u->faction, FFL_RESTART)) { - cmistake(u, ord, 314, MSG_EVENT); - return 0; - } - - if ( /* frace != u->faction->race && */ u->faction->age < 81) { - cmistake(u, ord, 241, MSG_EVENT); - return 0; - } - - if (!playerrace(frace)) { - cmistake(u, ord, 243, MSG_EVENT); - return 0; - } - - if (!checkpasswd(u->faction, (const char *)s_pass, false)) { - cmistake(u, ord, 86, MSG_EVENT); - log_warning("RESTART with wrong password, faction %s, pass %s\n", factionid(u->faction), s_pass); - return 0; - } - restart_race(u, frace); - return -1; + usetcontact(u, u2); } return 0; } -static boolean EnhancedQuit(void) +int leave_cmd(unit * u, struct order *ord) +{ + region *r = u->region; + + if (fval(u, UFL_ENTER)) { + /* if we just entered this round, then we don't leave again */ + return 0; + } + + if (fval(r->terrain, SEA_REGION) && u->ship) { + if (!fval(u->race, RCF_SWIM)) { + cmistake(u, ord, 11, MSG_MOVE); + return 0; + } + if (has_horses(u)) { + cmistake(u, ord, 231, MSG_MOVE); + return 0; + } + } + if (!slipthru(r, u, u->building)) { + ADDMSG(&u->faction->msgs, msg_feedback(u, u->thisorder, "entrance_besieged", + "building", u->building)); + } else { + leave(u, true); + } + return 0; +} + +static bool EnhancedQuit(void) { static int value = -1; if (value < 0) { @@ -1159,35 +1181,235 @@ int quit_cmd(unit * u, struct order *ord) return 0; } -void quit(void) +static bool mayenter(region * r, unit * u, building * b) { - faction **fptr = &factions; - while (*fptr) { - faction *f = *fptr; - if (f->flags & FFL_QUIT) { - if (EnhancedQuit()) { - /* this doesn't work well (use object_name()) */ - attrib *a = a_find(f->attribs, &at_object); - if (a) { - variant var; - object_type type; - var.i = 0; - object_get(a, &type, &var); - assert(var.i && type == TINTEGER); - if (var.i) { - int f2_id = var.i; - faction *f2 = findfaction(f2_id); + unit *u2; + if (fval(b, BLD_UNGUARDED)) + return true; + u2 = building_owner(b); - assert(f2_id > 0); - assert(f2 != NULL); - transfer_faction(f, f2); + if (u2 == NULL || ucontact(u2, u) + || alliedunit(u2, u->faction, HELP_GUARD)) + return true; + + return false; +} + +static int mayboard(const unit * u, ship * sh) +{ + unit *u2 = ship_owner(sh); + + return (!u2 || ucontact(u2, u) || alliedunit(u2, u->faction, HELP_GUARD)); +} + +static bool CheckOverload(void) +{ + static int value = -1; + if (value < 0) { + value = get_param_int(global.parameters, "rules.check_overload", 0); + } + return value; +} + +int enter_ship(unit * u, struct order *ord, int id, int report) +{ + region *r = u->region; + ship *sh; + + /* Mu� abgefangen werden, sonst k�nnten Schwimmer an + * Bord von Schiffen an Land gelangen. */ + if (!fval(u->race, RCF_CANSAIL) || (!fval(u->race, RCF_WALK) + && !fval(u->race, RCF_FLY))) { + cmistake(u, ord, 233, MSG_MOVE); + return 0; + } + + sh = findship(id); + if (sh == NULL || sh->region != r) { + if (report) + cmistake(u, ord, 20, MSG_MOVE); + return 0; + } + if (sh == u->ship) { + return 1; + } + if (!mayboard(u, sh)) { + if (report) + cmistake(u, ord, 34, MSG_MOVE); + return 0; + } + if (CheckOverload()) { + int sweight, scabins; + int mweight = shipcapacity(sh); + int mcabins = sh->type->cabins; + + if (mweight > 0) { + getshipweight(sh, &sweight, &scabins); + sweight += weight(u); + if (mcabins) { + int pweight = u->number * u->race->weight; + /* weight goes into number of cabins, not cargo */ + scabins += pweight; + sweight -= pweight; + } + + if (sweight > mweight || (mcabins && (scabins > mcabins))) { + if (report) + cmistake(u, ord, 34, MSG_MOVE); + return 0; + } + } + } + + if (leave(u, false)) { + u_set_ship(u, sh); + fset(u, UFL_ENTER); + } else if (report) { + cmistake(u, ord, 150, MSG_MOVE); + } + return 1; +} + +int enter_building(unit * u, order * ord, int id, int report) +{ + region *r = u->region; + building *b; + + /* Schwimmer k�nnen keine Geb�ude betreten, au�er diese sind + * auf dem Ozean */ + if (!fval(u->race, RCF_WALK) && !fval(u->race, RCF_FLY)) { + if (!fval(r->terrain, SEA_REGION)) { + if (report) { + cmistake(u, ord, 232, MSG_MOVE); + } + return 0; + } + } + + b = findbuilding(id); + if (b == NULL || b->region != r) { + if (report) { + cmistake(u, ord, 6, MSG_MOVE); + } + return 0; + } + if (!mayenter(r, u, b)) { + if (report) { + ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "entrance_denied", + "building", b)); + } + return 0; + } + if (!slipthru(r, u, b)) { + if (report) { + ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "entrance_besieged", + "building", b)); + } + return 0; + } + + if (leave(u, 0)) { + fset(u, UFL_ENTER); + u_set_building(u, b); + return 1; + } else if (report) { + cmistake(u, ord, 150, MSG_MOVE); + } + return 0; +} + +static void do_contact(region * r) +{ + unit * u; + for (u = r->units; u; u = u->next) { + order *ord; + for (ord = u->orders; ord; ord = ord->next) { + keyword_t kwd = get_keyword(ord); + if (kwd == K_CONTACT) { + contact_cmd(u, ord); + } + } + } +} + +void do_enter(struct region *r, bool is_final_attempt) +{ + unit **uptr; + + for (uptr = &r->units; *uptr;) { + unit *u = *uptr; + order **ordp = &u->orders; + + while (*ordp) { + order *ord = *ordp; + if (get_keyword(ord) == K_ENTER) { + param_t p; + int id; + unit *ulast = NULL; + const char * s; + + init_tokens(ord); + skip_token(); + s = getstrtoken(); + p = findparam_ex(s, u->faction->locale); + id = getid(); + + switch (p) { + case P_BUILDING: + case P_GEBAEUDE: + if (u->building && u->building->no == id) + break; + if (enter_building(u, ord, id, is_final_attempt)) { + unit *ub; + for (ub = u; ub; ub = ub->next) { + if (ub->building == u->building) { + ulast = ub; + } + } + } + break; + + case P_SHIP: + if (u->ship && u->ship->no == id) + break; + if (enter_ship(u, ord, id, is_final_attempt)) { + unit *ub; + ulast = u; + for (ub = u; ub; ub = ub->next) { + if (ub->ship == u->ship) { + ulast = ub; + } + } + } + break; + + default: + if (is_final_attempt) { + cmistake(u, ord, 79, MSG_MOVE); } } + if (ulast != NULL) { + /* Wenn wir hier angekommen sind, war der Befehl + * erfolgreich und wir l�schen ihn, damit er im + * zweiten Versuch nicht nochmal ausgef�hrt wird. */ + *ordp = ord->next; + ord->next = NULL; + free_order(ord); + + if (ulast != u) { + /* put u behind ulast so it's the last unit in the building */ + *uptr = u->next; + u->next = ulast->next; + ulast->next = u; + } + break; + } } - destroyfaction(f); + if (*ordp == ord) + ordp = &ord->next; } - if (*fptr == f) - fptr = &f->next; + if (*uptr == u) + uptr = &u->next; } } @@ -1209,40 +1431,16 @@ static void nmr_death(faction * f) } } -static void parse_restart(void) +static void remove_idle_players(void) { - region *r; faction *f; - /* Sterben erst nachdem man allen anderen gegeben hat - bzw. man kann - * alles machen, was nicht ein drei�igt�giger Befehl ist. */ - - for (r = regions; r; r = r->next) { - unit *u, *un; - for (u = r->units; u;) { - order *ord; - - un = u->next; - for (ord = u->orders; ord != NULL; ord = ord->next) { - if (get_keyword(ord) == K_RESTART) { - if (u->number > 0) { - if (restart_cmd(u, ord) != 0) { - break; - } - } - } - } - u = un; - } - } - - if (verbosity >= 1) - puts - (" - beseitige Spieler, die sich zu lange nicht mehr gemeldet haben..."); + log_info(" - beseitige Spieler, die sich zu lange nicht mehr gemeldet haben..."); for (f = factions; f; f = f->next) { - if (fval(f, FFL_NOIDLEOUT)) + if (fval(f, FFL_NOIDLEOUT)) { f->lastorders = turn; + } if (NMRTimeout() > 0 && turn - f->lastorders >= NMRTimeout()) { nmr_death(f); destroyfaction(f); @@ -1276,10 +1474,7 @@ static void parse_restart(void) continue; } } - if (verbosity >= 1) { - puts(" - beseitige Spieler, die sich nach der Anmeldung nicht " - "gemeldet haben..."); - } + log_info(" - beseitige Spieler, die sich nach der Anmeldung nicht gemeldet haben..."); age = calloc(MAX(4, turn + 1), sizeof(int)); for (f = factions; f; f = f->next) @@ -1296,9 +1491,46 @@ static void parse_restart(void) } } } +} - if (verbosity >= 1) - puts(" - beseitige leere Einheiten und leere Parteien..."); +void quit(void) +{ + faction **fptr = &factions; + while (*fptr) { + faction *f = *fptr; + if (f->flags & FFL_QUIT) { + if (EnhancedQuit()) { + /* this doesn't work well (use object_name()) */ + attrib *a = a_find(f->attribs, &at_object); + if (a) { + variant var; + object_type type; + var.i = 0; + object_get(a, &type, &var); + assert(var.i && type == TINTEGER); + if (var.i) { + int f2_id = var.i; + faction *f2 = findfaction(f2_id); + + assert(f2_id > 0); + assert(f2 != NULL); + transfer_faction(f, f2); + } + } + } + destroyfaction(f); + } else { + ++f->age; + if (f->age + 1 < NewbieImmunity()) { + ADDMSG(&f->msgs, msg_message("newbieimmunity", "turns", + NewbieImmunity() - f->age - 1)); + } + } + if (*fptr == f) { + fptr = &f->next; + } + } + remove_idle_players(); remove_empty_units(); } @@ -1428,7 +1660,7 @@ static void init_prefixnames(void) int i; for (i = 0; localenames[i]; ++i) { const struct locale *lang = find_locale(localenames[i]); - boolean exist = false; + bool exist = false; struct local_names *in = pnames; while (in != NULL) { @@ -1612,7 +1844,7 @@ int display_cmd(unit * u, struct order *ord) return 0; } -boolean renamed_building(const building * b) +bool renamed_building(const building * b) { const struct locale *lang = locales; size_t len = strlen(b->name); @@ -1650,7 +1882,7 @@ int rename_building(unit * u, order * ord, building * b, const char *name) { unit *owner = b ? building_owner(b) : 0; - boolean foreign = !(owner && owner->faction == u->faction); + bool foreign = !(owner && owner->faction == u->faction); if (!b) { cmistake(u, ord, u->building ? 6 : 145, MSG_EVENT); @@ -1695,7 +1927,7 @@ int name_cmd(struct unit *u, struct order *ord) region *r = u->region; char **s = NULL; param_t p; - boolean foreign = false; + bool foreign = false; const char *str; init_tokens(ord); @@ -1939,7 +2171,7 @@ static void mailfaction(unit * u, int n, struct order *ord, const char *s) cmistake(u, ord, 66, MSG_MESSAGE); } -static int mail_cmd(unit * u, struct order *ord) +int mail_cmd(unit * u, struct order *ord) { region *r = u->region; unit *u2; @@ -1969,7 +2201,7 @@ static int mail_cmd(unit * u, struct order *ord) case P_FACTION: { - boolean see = false; + bool see = false; n = getfactionid(); @@ -1996,7 +2228,7 @@ static int mail_cmd(unit * u, struct order *ord) case P_UNIT: { - boolean see = false; + bool see = false; n = getid(); for (u2 = r->units; u2; u2 = u2->next) { @@ -2147,7 +2379,7 @@ int password_cmd(unit * u, struct order *ord) char pwbuf[32]; int i; const char *s; - boolean pwok = true; + bool pwok = true; init_tokens(ord); skip_token(); @@ -2213,7 +2445,7 @@ int send_cmd(unit * u, struct order *ord) return 0; } -static boolean display_item(faction * f, unit * u, const item_type * itype) +static bool display_item(faction * f, unit * u, const item_type * itype) { const char *name; const char *key; @@ -2246,7 +2478,7 @@ static boolean display_item(faction * f, unit * u, const item_type * itype) return true; } -static boolean display_potion(faction * f, unit * u, const potion_type * ptype) +static bool display_potion(faction * f, unit * u, const potion_type * ptype) { attrib *a; @@ -2270,7 +2502,7 @@ static boolean display_potion(faction * f, unit * u, const potion_type * ptype) return true; } -static boolean display_race(faction * f, unit * u, const race * rc) +static bool display_race(faction * f, unit * u, const race * rc) { const char *name, *key; const char *info; @@ -2481,7 +2713,7 @@ static void reshow(unit * u, struct order *ord, const char *s, param_t p) } } -static int promotion_cmd(unit * u, struct order *ord) +int promotion_cmd(unit * u, struct order *ord) { int money, people; @@ -2542,7 +2774,7 @@ int origin_cmd(unit * u, struct order *ord) return 0; } -static int guard_off_cmd(unit * u, struct order *ord) +int guard_off_cmd(unit * u, struct order *ord) { assert(get_keyword(ord) == K_GUARD); init_tokens(ord); @@ -2554,7 +2786,7 @@ static int guard_off_cmd(unit * u, struct order *ord) return 0; } -static int reshow_cmd(unit * u, struct order *ord) +int reshow_cmd(unit * u, struct order *ord) { const char *s; param_t p = NOPARAM; @@ -2617,7 +2849,7 @@ int status_cmd(unit * u, struct order *ord) return 0; } -static int combatspell_cmd(unit * u, struct order *ord) +int combatspell_cmd(unit * u, struct order *ord) { const char *s; int level = 0; @@ -2703,7 +2935,7 @@ void update_guards(void) } } -static int guard_on_cmd(unit * u, struct order *ord) +int guard_on_cmd(unit * u, struct order *ord) { assert(get_keyword(ord) == K_GUARD); @@ -2743,7 +2975,7 @@ static int guard_on_cmd(unit * u, struct order *ord) return 0; } -static void sinkships(region * r) +void sinkships(struct region * r) { ship **shp = &r->ships; @@ -2783,7 +3015,7 @@ static attrib_type at_number = { ATF_UNIQUE }; -static void renumber_factions(void) +void renumber_factions(void) /* gibt parteien neue nummern */ { struct renum { @@ -2844,12 +3076,12 @@ static void renumber_factions(void) } } -static void reorder(void) +void restack_units(void) { region *r; for (r = regions; r; r = r->next) { unit **up = &r->units; - boolean sorted = false; + bool sorted = false; while (*up) { unit *u = *up; if (!fval(u, UFL_MARK)) { @@ -2924,7 +3156,7 @@ static void reorder(void) } } -static int renumber_cmd(unit * u, order * ord) +int renumber_cmd(unit * u, order * ord) { const char *s; int i; @@ -3044,7 +3276,7 @@ static int renumber_cmd(unit * u, order * ord) static building *age_building(building * b) { - static boolean init = false; + static bool init = false; static const building_type *bt_blessed; static const curse_type *ct_astralblock; if (!init) { @@ -3417,8 +3649,6 @@ void check_long_orders(unit * u) cmistake(u, ord, 52, MSG_EVENT); } break; - case K_WEREWOLF: - /* don't know what WEREWOLF does... */ default: cmistake(u, ord, 52, MSG_EVENT); } @@ -3432,9 +3662,10 @@ void check_long_orders(unit * u) void update_long_order(unit * u) { order *ord; - boolean trade = false; - boolean hunger = LongHunger(u); + bool trade = false; + bool hunger = LongHunger(u); + freset(u, UFL_MOVED); freset(u, UFL_LONGACTION); if (hunger) { /* Hungernde Einheiten f�hren NUR den default-Befehl aus */ @@ -3474,23 +3705,19 @@ void update_long_order(unit * u) case K_BUY: case K_SELL: /* Wenn die Einheit handelt, mu� der Default-Befehl gel�scht - * werden. */ + * werden. + * Wird je diese Ausschliesslichkeit aufgehoben, muss man aufpassen + * mit der Reihenfolge von Kaufen, Verkaufen etc., damit es Spielern + * nicht moeglich ist, Schulden zu machen. */ trade = true; break; case K_CAST: /* dient dazu, das neben Zaubern kein weiterer Befehl * ausgef�hrt werden kann, Zaubern ist ein kurzer Befehl */ - set_order(&u->thisorder, NULL); - break; - - case K_WEREWOLF: set_order(&u->thisorder, copy_order(ord)); break; - /* Wird je diese Ausschliesslichkeit aufgehoben, muss man aufpassen - * mit der Reihenfolge von Kaufen, Verkaufen etc., damit es Spielern - * nicht moeglich ist, Schulden zu machen. */ default: break; } @@ -3558,7 +3785,7 @@ static double heal_factor(const unit * u) } } -static void monthly_healing(void) +void monthly_healing(void) { region *r; static const curse_type *heal_ct = NULL; @@ -3645,13 +3872,15 @@ static void remove_exclusive(order ** ordp) } } -static void defaultorders(void) +void defaultorders(void) { region *r; + + assert(!global.disabled[K_DEFAULT]); for (r = regions; r; r = r->next) { unit *u; for (u = r->units; u; u = u->next) { - boolean neworders = false; + bool neworders = false; order **ordp = &u->orders; while (*ordp != NULL) { order *ord = *ordp; @@ -3764,20 +3993,7 @@ static void update_spells(void) } } -static void age_factions(void) -{ - faction *f; - - for (f = factions; f; f = f->next) { - ++f->age; - if (f->age + 1 < NewbieImmunity()) { - ADDMSG(&f->msgs, msg_message("newbieimmunity", "turns", - NewbieImmunity() - f->age - 1)); - } - } -} - -static int use_cmd(unit * u, struct order *ord) +int use_cmd(unit * u, struct order *ord) { const char *t; int n, err = ENOITEM; @@ -3824,7 +4040,7 @@ static int use_cmd(unit * u, struct order *ord) return err; } -static int pay_cmd(unit * u, struct order *ord) +int pay_cmd(unit * u, struct order *ord) { if (!u->building) { cmistake(u, ord, 6, MSG_EVENT); @@ -3845,7 +4061,39 @@ static int pay_cmd(unit * u, struct order *ord) return 0; } -static int claim_cmd(unit * u, struct order *ord) + +int reserve_cmd(unit * u, struct order *ord) +{ + if (u->number > 0 && (urace(u)->ec_flags & GETITEM)) { + int use, count; + const resource_type *rtype; + const char *s; + + init_tokens(ord); + skip_token(); + s = getstrtoken(); + count = atoip((const char *)s); + + if (count == 0 && findparam(s, u->faction->locale) == P_EACH) { + count = getint() * u->number; + } + + rtype = findresourcetype(getstrtoken(), u->faction->locale); + if (rtype == NULL) + return 0; + + set_resvalue(u, rtype, 0); /* make sure the pool is empty */ + use = use_pooled(u, rtype, GET_DEFAULT, count); + if (use) { + set_resvalue(u, rtype, use); + change_resource(u, rtype, use); + return use; + } + } + return 0; +} + +int claim_cmd(unit * u, struct order *ord) { const char *t; int n; @@ -3880,10 +4128,13 @@ enum { PROC_THISORDER = 1 << 0, PROC_LONGORDER = 1 << 1 }; + +typedef enum { PR_GLOBAL, PR_REGION_PRE, PR_UNIT, PR_ORDER, PR_REGION_POST } processor_t; + typedef struct processor { struct processor *next; int priority; - enum { PR_GLOBAL, PR_REGION_PRE, PR_UNIT, PR_ORDER, PR_REGION_POST } type; + processor_t type; unsigned int flags; union { struct { @@ -3905,7 +4156,7 @@ typedef struct processor { static processor *processors; -processor *add_proc(int priority, const char *name, int type) +static processor *add_proc(int priority, const char *name, processor_t type) { processor **pproc = &processors; processor *proc; @@ -3919,7 +4170,7 @@ processor *add_proc(int priority, const char *name, int type) pproc = &proc->next; } - proc = malloc(sizeof(processor)); + proc = (processor *)malloc(sizeof(processor)); proc->priority = priority; proc->type = type; proc->name = name; @@ -4098,14 +4349,111 @@ void process(void) } +int siege_cmd(unit * u, order * ord) +{ + region *r = u->region; + building *b; + int d, pooled; + int bewaffnete, katapultiere = 0; + static bool init = false; + static const curse_type *magicwalls_ct; + static item_type *it_catapultammo = NULL; + static item_type *it_catapult = NULL; + if (!init) { + init = true; + magicwalls_ct = ct_find("magicwalls"); + it_catapultammo = it_find("catapultammo"); + it_catapult = it_find("catapult"); + } + /* gibt es ueberhaupt Burgen? */ + + init_tokens(ord); + skip_token(); + b = getbuilding(r); + + if (!b) { + cmistake(u, ord, 31, MSG_BATTLE); + return 31; + } + + if (!playerrace(u->race)) { + /* keine Drachen, Illusionen, Untote etc */ + cmistake(u, ord, 166, MSG_BATTLE); + return 166; + } + /* schaden durch katapulte */ + + d = i_get(u->items, it_catapult); + d = MIN(u->number, d); + pooled = get_pooled(u, it_catapultammo->rtype, GET_DEFAULT, d); + d = MIN(pooled, d); + if (eff_skill(u, SK_CATAPULT, r) >= 1) { + katapultiere = d; + d *= eff_skill(u, SK_CATAPULT, r); + } else { + d = 0; + } + + bewaffnete = armedmen(u, true); + if (d == 0 && bewaffnete == 0) { + /* abbruch, falls unbewaffnet oder unfaehig, katapulte zu benutzen */ + cmistake(u, ord, 80, MSG_EVENT); + return 80; + } + + if (!is_guard(u, GUARD_TRAVELTHRU)) { + /* abbruch, wenn die einheit nicht vorher die region bewacht - als + * warnung fuer alle anderen! */ + cmistake(u, ord, 81, MSG_EVENT); + return 81; + } + /* einheit und burg markieren - spart zeit beim behandeln der einheiten + * in der burg, falls die burg auch markiert ist und nicht alle + * einheiten wieder abgesucht werden muessen! */ + + usetsiege(u, b); + b->besieged += MAX(bewaffnete, katapultiere); + + /* definitiver schaden eingeschraenkt */ + + d = MIN(d, b->size - 1); + + /* meldung, schaden anrichten */ + if (d && !curse_active(get_curse(b->attribs, magicwalls_ct))) { + b->size -= d; + use_pooled(u, it_catapultammo->rtype, + GET_SLACK | GET_RESERVE | GET_POOLED_SLACK, d); + /* send message to the entire region */ + ADDMSG(&r->msgs, msg_message("siege_catapults", + "unit building destruction", u, b, d)); + } else { + /* send message to the entire region */ + ADDMSG(&r->msgs, msg_message("siege", "unit building", u, b)); + } + return 0; +} + +void do_siege(region * r) +{ + if (fval(r->terrain, LAND_REGION)) { + unit *u; + + for (u = r->units; u; u = u->next) { + if (get_keyword(u->thisorder) == K_BESIEGE) { + siege_cmd(u, u->thisorder); + } + } + } +} + static void enter_1(region * r) { - do_misc(r, 0); + do_enter(r, 0); } static void enter_2(region * r) { - do_misc(r, 1); + do_enter(r, 1); } static void maintain_buildings_1(region * r) @@ -4113,11 +4461,6 @@ static void maintain_buildings_1(region * r) maintain_buildings(r, false); } -static void reset_moved(unit * u) -{ - freset(u, UFL_MOVED); -} - /** warn about passwords that are not US ASCII. * even though passwords are technically UTF8 strings, the server receives * them as part of the Subject of an email when reports are requested. @@ -4128,7 +4471,7 @@ static int warn_password(void) { faction *f = factions; while (f) { - boolean pwok = true; + bool pwok = true; const char *c = f->passw; while (*c && pwok) { if (!isalnum((unsigned char)*c)) @@ -4161,7 +4504,6 @@ void init_processor(void) add_proc_order(p, K_GROUP, &group_cmd, 0, NULL); p += 10; - add_proc_unit(p, &reset_moved, "Instant-Befehle"); add_proc_order(p, K_QUIT, &quit_cmd, 0, NULL); add_proc_order(p, K_URSPRUNG, &origin_cmd, 0, NULL); add_proc_order(p, K_ALLY, &ally_cmd, 0, NULL); @@ -4180,11 +4522,11 @@ void init_processor(void) } p += 10; - add_proc_global(p, &age_factions, "Parteienalter++"); + add_proc_region(p, do_contact, "Kontaktieren"); add_proc_order(p, K_MAIL, &mail_cmd, 0, "Botschaften"); p += 10; /* all claims must be done before we can USE */ - add_proc_region(p, &enter_1, "Kontaktieren & Betreten (1. Versuch)"); + add_proc_region(p, &enter_1, "Betreten (1. Versuch)"); add_proc_order(p, K_USE, &use_cmd, 0, "Benutzen"); if (!global.disabled[K_GM]) { @@ -4197,9 +4539,7 @@ void init_processor(void) p += 10; /* in case it has any effects on alliance victories */ add_proc_order(p, K_LEAVE, &leave_cmd, 0, "Verlassen"); - if (!nobattle) { - add_proc_region(p, &do_battle, "Attackieren"); - } + add_proc_region(p, &do_battle, "Attackieren"); if (!global.disabled[K_BESIEGE]) { p += 10; @@ -4207,7 +4547,7 @@ void init_processor(void) } p += 10; /* can't allow reserve before siege (weapons) */ - add_proc_region(p, &enter_1, "Kontaktieren & Betreten (2. Versuch)"); + add_proc_region(p, &enter_1, "Betreten (2. Versuch)"); add_proc_order(p, K_RESERVE, &reserve_cmd, 0, "Reservieren"); add_proc_order(p, K_CLAIM, &claim_cmd, 0, NULL); add_proc_unit(p, &follow_unit, "Folge auf Einheiten setzen"); @@ -4223,10 +4563,7 @@ void init_processor(void) "Gebaeudeunterhalt (1. Versuch)"); p += 10; /* QUIT fuer sich alleine */ - add_proc_global(p, &quit, "Sterben"); - if (!global.disabled[K_RESTART]) { - add_proc_global(p, &parse_restart, "Neustart"); - } + add_proc_global(p, quit, "Sterben"); if (!global.disabled[K_CAST]) { p += 10; @@ -4247,7 +4584,7 @@ void init_processor(void) add_proc_postregion(p, &split_allocations, "Produktion II"); p += 10; - add_proc_region(p, &enter_2, "Kontaktieren & Betreten (3. Versuch)"); + add_proc_region(p, &enter_2, "Betreten (3. Versuch)"); p += 10; add_proc_region(p, &sinkships, "Schiffe sinken"); @@ -4262,13 +4599,12 @@ void init_processor(void) p += 10; add_proc_order(p, K_GUARD, &guard_on_cmd, 0, "Bewache (an)"); -#if XECMD_MODULE - /* can do together with guard */ - add_proc_order(p, K_XE, &xecmd, 0, "Zeitung"); -#endif - p += 10; - add_proc_global(p, &encounters, "Zufallsbegegnungen"); + if (get_param_int(global.parameters, "rules.encounters", 1)) { + p += 10; + add_proc_global(p, &encounters, "Zufallsbegegnungen"); + } + p += 10; add_proc_unit(p, &monster_kills_peasants, "Monster fressen und vertreiben Bauern"); @@ -4279,7 +4615,7 @@ void init_processor(void) p += 10; add_proc_global(p, &monthly_healing, "Regeneration (HP)"); - add_proc_global(p, ®eneration_magiepunkte, "Regeneration (Aura)"); + add_proc_global(p, ®enerate_aura, "Regeneration (Aura)"); if (!global.disabled[K_DEFAULT]) { add_proc_global(p, &defaultorders, "Defaults setzen"); } @@ -4287,7 +4623,7 @@ void init_processor(void) if (!global.disabled[K_SORT]) { p += 10; - add_proc_global(p, &reorder, "Einheiten sortieren"); + add_proc_global(p, restack_units, "Einheiten sortieren"); } add_proc_order(p, K_PROMOTION, &promotion_cmd, 0, "Heldenbefoerderung"); if (!global.disabled[K_NUMBER]) { @@ -4313,8 +4649,7 @@ void processorders(void) do_markets(); } - if (verbosity >= 1) - puts(" - Attribute altern"); + log_info(" - Attribute altern"); ageing(); remove_empty_units(); @@ -4338,7 +4673,7 @@ int writepasswd(void) F = cfopen(zText, "w"); if (F) { faction *f; - puts("writing passwords..."); + log_info("writing passwords..."); for (f = factions; f; f = f->next) { fprintf(F, "%s:%s:%s:%s:%u\n", diff --git a/src/gamecode/laws.h b/src/gamecode/laws.h index 2d9cc2ce7..09f7ce5e8 100755 --- a/src/gamecode/laws.h +++ b/src/gamecode/laws.h @@ -34,9 +34,10 @@ extern "C" { const char *s, struct unit *receiver); int init_data(const char *filename, const char *catalog); - boolean renamed_building(const struct building * b); + bool renamed_building(const struct building * b); int rename_building(struct unit * u, struct order * ord, struct building * b, const char *name); void get_food(struct region * r); + extern int can_contact(const struct region *r, const struct unit *u, const struct unit *u2); /* eressea-specific. put somewhere else, please. */ void processorders(void); @@ -45,9 +46,19 @@ extern "C" { extern int dropouts[2]; extern int *age; + extern int enter_building(struct unit *u, struct order *ord, int id, int report); + extern int enter_ship(struct unit *u, struct order *ord, int id, int report); + extern void new_units(void); + extern void defaultorders(void); extern void quit(void); - extern void update_long_order(struct unit * u); + extern void monthly_healing(void); + extern void renumber_factions(void); + extern void restack_units(void); + extern void update_long_order(struct unit *u); + extern void sinkships(struct region * r); + extern void do_enter(struct region *r, bool is_final_attempt); + extern int password_cmd(struct unit *u, struct order *ord); extern int banner_cmd(struct unit *u, struct order *ord); extern int email_cmd(struct unit *u, struct order *ord); @@ -61,7 +72,22 @@ extern "C" { extern int origin_cmd(struct unit *u, struct order *ord); extern int quit_cmd(struct unit *u, struct order *ord); extern int name_cmd(struct unit *u, struct order *ord); - + extern int use_cmd(struct unit *u, struct order *ord); + extern int siege_cmd(struct unit *u, struct order *ord); + extern int leave_cmd(struct unit *u, struct order *ord); + extern int pay_cmd(struct unit *u, struct order *ord); + extern int promotion_cmd(struct unit *u, struct order *ord); + extern int renumber_cmd(struct unit *u, struct order *ord); + extern int combatspell_cmd(struct unit *u, struct order *ord); + extern int contact_cmd(struct unit *u, struct order *ord); + extern int guard_on_cmd(struct unit *u, struct order *ord); + extern int guard_off_cmd(struct unit *u, struct order *ord); + extern int reshow_cmd(struct unit *u, struct order *ord); + extern int mail_cmd(struct unit *u, struct order *ord); + extern int reserve_cmd(struct unit *u, struct order *ord); + extern int claim_cmd(struct unit *u, struct order *ord); + extern int follow_cmd(struct unit *u, struct order *ord); + #ifdef __cplusplus } #endif diff --git a/src/gamecode/monster.c b/src/gamecode/monster.c index 1c4911cd1..4fe9d9ec2 100644 --- a/src/gamecode/monster.c +++ b/src/gamecode/monster.c @@ -70,7 +70,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #define MAXILLUSION_TEXTS 3 -boolean monster_is_waiting(const unit * u) +bool monster_is_waiting(const unit * u) { if (fval(u, UFL_ISNEW | UFL_MOVED)) return true; diff --git a/src/gamecode/monster.h b/src/gamecode/monster.h index 0ae45a6bf..27a8f23f7 100644 --- a/src/gamecode/monster.h +++ b/src/gamecode/monster.h @@ -23,7 +23,7 @@ extern "C" { #endif void monster_kills_peasants(struct unit *u); - boolean monster_is_waiting(const struct unit *u); + bool monster_is_waiting(const struct unit *u); #ifdef __cplusplus } diff --git a/src/gamecode/randenc.c b/src/gamecode/randenc.c index 43d3370b2..196fdd5a0 100644 --- a/src/gamecode/randenc.c +++ b/src/gamecode/randenc.c @@ -153,7 +153,7 @@ static void dissolve_units(void) static int improve_all(faction * f, skill_t sk, int by_weeks) { unit *u; - boolean ret = by_weeks; + bool ret = by_weeks; for (u = f->units; u; u = u->nextF) { if (has_skill(u, sk)) { @@ -596,7 +596,7 @@ static int nb_armor(const unit * u, int index) } static int -damage_unit(unit * u, const char *dam, boolean physical, boolean magic) +damage_unit(unit * u, const char *dam, bool physical, bool magic) { int *hp = malloc(u->number * sizeof(int)); int h; @@ -980,7 +980,7 @@ void create_icebergs(void) for (r = regions; r; r = r->next) { if (r->terrain == newterrain(T_ICEBERG_SLEEP) && chance(0.05)) { - boolean has_ocean_neighbour = false; + bool has_ocean_neighbour = false; direction_t dir; region *rc; unit *u; @@ -1062,7 +1062,7 @@ static void orc_growth(void) for (r = regions; r; r = r->next) { unit *u; for (u = r->units; u; u = u->next) { - static boolean init = false; + static bool init = false; static const curse_type *ct_orcish = 0; curse *c = 0; if (!init) { diff --git a/src/gamecode/report.c b/src/gamecode/report.c index 2127d2940..c8b3d1179 100644 --- a/src/gamecode/report.c +++ b/src/gamecode/report.c @@ -38,6 +38,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. /* kernel includes */ #include <kernel/alchemy.h> +#include <kernel/ally.h> #include <kernel/connection.h> #include <kernel/build.h> #include <kernel/building.h> @@ -134,7 +135,7 @@ void rnl(FILE * F) fputc('\n', F); } -static void centre(FILE * F, const char *s, boolean breaking) +static void centre(FILE * F, const char *s, bool breaking) { /* Bei Namen die genau 80 Zeichen lang sind, kann es hier Probleme * geben. Seltsamerweise wird i dann auf MAXINT oder aehnlich @@ -217,12 +218,25 @@ rparagraph(FILE * F, const char *str, ptrdiff_t indent, int hanging_indent, } while (*begin); } +static size_t write_spell_modifier(spell * sp, int flag, const char * str, bool cont, char * bufp, size_t size) { + if (sp->sptyp & flag) { + size_t bytes = 0; + if (cont) { + bytes = strlcpy(bufp, ", ", size); + } else { + bytes = strlcpy(bufp, " ", size); + } + bytes += strlcpy(bufp+bytes, str, size-bytes); + return bytes; + } + return 0; +} + static void nr_spell(FILE * F, spellbook_entry * sbe, const struct locale *lang) { int bytes, k, itemanz, costtyp; - int dh = 0; char buf[4096]; - char *bufp = buf; + char *startp, *bufp = buf; size_t size = sizeof(buf) - 1; spell * sp = sbe->sp; const char *params = sp->parameter; @@ -296,52 +310,29 @@ static void nr_spell(FILE * F, spellbook_entry * sbe, const struct locale *lang) bytes = (int)strlcpy(buf, LOC(lang, "nr_spell_modifiers"), size); if (wrptr(&bufp, &size, bytes) != 0) WARN_STATIC_BUFFER(); - if (sp->sptyp & FARCASTING) { - bytes = (int)strlcpy(bufp, " Fernzauber", size); - if (wrptr(&bufp, &size, bytes) != 0) - WARN_STATIC_BUFFER(); - dh = 1; + + startp = bufp; + bytes = (int)write_spell_modifier(sp, FARCASTING, LOC(lang, "smod_far"), startp!=bufp, bufp, size); + if (bytes && wrptr(&bufp, &size, bytes) != 0) { + WARN_STATIC_BUFFER(); } - if (sp->sptyp & OCEANCASTABLE) { - if (dh == 1) { - bytes = (int)strlcpy(bufp, ",", size); - if (wrptr(&bufp, &size, bytes) != 0) - WARN_STATIC_BUFFER(); + bytes = (int)write_spell_modifier(sp, OCEANCASTABLE, LOC(lang, "smod_sea"), startp!=bufp, bufp, size); + if (bytes && wrptr(&bufp, &size, bytes) != 0) { + WARN_STATIC_BUFFER(); + } + bytes = (int)write_spell_modifier(sp, ONSHIPCAST, LOC(lang, "smod_ship"), startp!=bufp, bufp, size); + if (bytes && wrptr(&bufp, &size, bytes) != 0) { + WARN_STATIC_BUFFER(); + } + bytes = (int)write_spell_modifier(sp, NOTFAMILIARCAST, LOC(lang, "smod_nofamiliar"), startp!=bufp, bufp, size); + if (bytes && wrptr(&bufp, &size, bytes) != 0) { + WARN_STATIC_BUFFER(); + } + if (startp==bufp) { + bytes = (int)write_spell_modifier(sp, NOTFAMILIARCAST, LOC(lang, "smod_none"), startp!=bufp, bufp, size); + if (bytes && wrptr(&bufp, &size, bytes) != 0) { + WARN_STATIC_BUFFER(); } - bytes = (int)strlcpy(bufp, " Seezauber", size); - if (wrptr(&bufp, &size, bytes) != 0) - WARN_STATIC_BUFFER(); - dh = 1; - } - if (sp->sptyp & ONSHIPCAST) { - if (dh == 1) { - bytes = (int)strlcpy(bufp, ",", size); - if (wrptr(&bufp, &size, bytes) != 0) - WARN_STATIC_BUFFER(); - } - bytes = (int)strlcpy(bufp, " Schiffszauber", size); - if (wrptr(&bufp, &size, bytes) != 0) - WARN_STATIC_BUFFER(); - dh = 1; - } - if (sp->sptyp & NOTFAMILIARCAST) { - if (dh == 1) { - bytes = (int)strlcpy(bufp, ", k", size); - } else { - bytes = (int)strlcpy(bufp, " K", size); - } - if (wrptr(&bufp, &size, bytes) != 0) - WARN_STATIC_BUFFER(); - bytes = - (int)strlcpy(bufp, "ann nicht vom Vertrauten gezaubert werden", size); - if (wrptr(&bufp, &size, bytes) != 0) - WARN_STATIC_BUFFER(); - dh = 1; - } - if (dh == 0) { - bytes = (int)strlcpy(bufp, " Keine", size); - if (wrptr(&bufp, &size, bytes) != 0) - WARN_STATIC_BUFFER(); } *bufp = 0; rparagraph(F, buf, 0, 0, 0); @@ -698,7 +689,7 @@ nr_unit(FILE * F, const faction * f, const unit * u, int indent, int mode) attrib *a_otherfaction; char marker; int dh; - boolean isbattle = (boolean) (mode == see_battle); + bool isbattle = (bool) (mode == see_battle); char buf[8192]; if (fval(u->race, RCF_INVISIBLE)) @@ -735,7 +726,7 @@ nr_unit(FILE * F, const faction * f, const unit * u, int indent, int mode) static void rp_messages(FILE * F, message_list * msgs, faction * viewer, int indent, - boolean categorized) + bool categorized) { nrsection *section; if (!msgs) @@ -866,9 +857,9 @@ static void prices(FILE * F, const region * r, const faction * f) } -boolean see_border(const connection * b, const faction * f, const region * r) +bool see_border(const connection * b, const faction * f, const region * r) { - boolean cs = b->type->fvisible(b, f, r); + bool cs = b->type->fvisible(b, f, r); if (!cs) { cs = b->type->rvisible(b, r); if (!cs) { @@ -890,7 +881,7 @@ static void describe(FILE * F, const seen_region * sr, faction * f) { const region *r = sr->r; int n; - boolean dh; + bool dh; direction_t d; int trees; int saplings; @@ -899,12 +890,12 @@ static void describe(FILE * F, const seen_region * sr, faction * f) struct edge { struct edge *next; char *name; - boolean transparent; - boolean block; - boolean exist[MAXDIRECTIONS]; + bool transparent; + bool block; + bool exist[MAXDIRECTIONS]; direction_t lastd; } *edges = NULL, *e; - boolean see[MAXDIRECTIONS]; + bool see[MAXDIRECTIONS]; char buf[8192]; char *bufp = buf; size_t size = sizeof(buf); @@ -919,7 +910,7 @@ static void describe(FILE * F, const seen_region * sr, faction * f) continue; for (b = get_borders(r, r2); b;) { struct edge *e = edges; - boolean transparent = b->type->transparent(b, f); + bool transparent = b->type->transparent(b, f); const char *name = b->type->name(b, r, f, GF_DETAILED | GF_ARTICLE); if (!transparent) @@ -948,11 +939,11 @@ static void describe(FILE * F, const seen_region * sr, faction * f) WARN_STATIC_BUFFER(); if (sr->mode == see_travel) { - bytes = (int)strlcpy(bufp, " (durchgereist)", size); + bytes = snprintf(bufp, size, " (%s)", LOC(f->locale, "see_travel")); } else if (sr->mode == see_neighbour) { - bytes = (int)strlcpy(bufp, " (benachbart)", size); + bytes = snprintf(bufp, size, " (%s)", LOC(f->locale, "see_neighbour")); } else if (sr->mode == see_lighthouse) { - bytes = (int)strlcpy(bufp, " (vom Turm erblickt)", size); + bytes = snprintf(bufp, size, " (%s)", LOC(f->locale, "see_lighthouse")); } else { bytes = 0; } @@ -1235,7 +1226,7 @@ static void describe(FILE * F, const seen_region * sr, faction * f) if (edges) rnl(F); for (e = edges; e; e = e->next) { - boolean first = true; + bool first = true; bufp = buf; size = sizeof(buf) - 1; for (d = 0; d != MAXDIRECTIONS; ++d) { @@ -1440,9 +1431,9 @@ static void durchreisende(FILE * F, const region * r, const faction * f) } /* TODO: finish localization */ if (maxtravel == 1) { - bytes = (int)strlcpy(bufp, " hat die Region durchquert.", size); + bytes = snprintf(bufp, size, " %s", LOC(f->locale, "has_moved_one")); } else { - bytes = (int)strlcpy(bufp, " haben die Region durchquert.", size); + bytes = snprintf(bufp, size, " %s", LOC(f->locale, "has_moved_many")); } if (wrptr(&bufp, &size, bytes) != 0) WARN_STATIC_BUFFER(); @@ -1455,7 +1446,7 @@ static int buildingmaintenance(const building * b, const resource_type * rtype) { const building_type *bt = b->type; int c, cost = 0; - static boolean init = false; + static bool init = false; static const curse_type *nocost_ct; if (!init) { init = true; @@ -1735,9 +1726,9 @@ static void allies(FILE * F, const faction * f) int bytes; size_t size = sizeof(buf); if (!f->allies->next) { - bytes = (int)strlcpy(buf, "Wir helfen der Partei ", size); + bytes = snprintf(buf, size, "%s ", LOC(f->locale, "faction_help_one")); } else { - bytes = (int)strlcpy(buf, "Wir helfen den Parteien ", size); + bytes = snprintf(buf, size, "%s ", LOC(f->locale, "faction_help_many")); } size -= bytes; show_allies(f, f->allies, buf + bytes, size); @@ -1750,9 +1741,9 @@ static void allies(FILE * F, const faction * f) int bytes; size_t size = sizeof(buf); if (!g->allies->next) { - bytes = snprintf(buf, size, "%s hilft der Partei ", g->name); + bytes = snprintf(buf, size, "%s %s ", g->name, LOC(f->locale, "group_help_one")); } else { - bytes = snprintf(buf, size, "%s hilft den Parteien ", g->name); + bytes = snprintf(buf, size, "%s %s ", g->name, LOC(f->locale, "group_help_many")); } size -= bytes; show_allies(f, g->allies, buf + bytes, size); @@ -1775,7 +1766,7 @@ static void guards(FILE * F, const region * r, const faction * see) unit *u; int i; - boolean tarned = false; + bool tarned = false; /* Bewachung */ for (u = r->units; u; u = u->next) { @@ -2579,7 +2570,7 @@ static void add_find(faction * f, unit * u, faction * f2) static void update_find(void) { region *r; - static boolean initial = true; + static bool initial = true; if (initial) for (r = regions; r; r = r->next) { @@ -2601,10 +2592,10 @@ static void update_find(void) initial = false; } -boolean kann_finden(faction * f1, faction * f2) +bool kann_finden(faction * f1, faction * f2) { update_find(); - return (boolean) (can_find(f1, f2) != NULL); + return (bool) (can_find(f1, f2) != NULL); } /******* end summary ******/ diff --git a/src/gamecode/spy.c b/src/gamecode/spy.c index 76b0360b5..476aed8af 100644 --- a/src/gamecode/spy.c +++ b/src/gamecode/spy.c @@ -19,15 +19,16 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include <platform.h> #include <kernel/config.h> #include "spy.h" +#include "laws.h" /* kernel includes */ -#include <kernel/build.h> #include <kernel/reports.h> #include <kernel/item.h> #include <kernel/faction.h> #include <kernel/magic.h> #include <kernel/message.h> #include <kernel/move.h> +#include <kernel/order.h> #include <kernel/race.h> #include <kernel/region.h> #include <kernel/ship.h> diff --git a/src/gamecode/study.c b/src/gamecode/study.c index 2919e8b1f..653ef5bb9 100644 --- a/src/gamecode/study.c +++ b/src/gamecode/study.c @@ -87,7 +87,7 @@ magic_t getmagicskill(const struct locale * lang) /* ------------------------------------------------------------- */ /* Vertraute und Kr�ten sind keine Migranten */ -boolean is_migrant(unit * u) +bool is_migrant(unit * u) { if (u->race == u->faction->race) return false; @@ -103,7 +103,7 @@ boolean is_migrant(unit * u) } /* ------------------------------------------------------------- */ -boolean magic_lowskill(unit * u) +bool magic_lowskill(unit * u) { return (u->race == new_race[RC_TOAD]) ? true : false; } @@ -174,7 +174,7 @@ static int study_days(unit * student, skill_t sk) static int teach_unit(unit * teacher, unit * student, int nteaching, skill_t sk, - boolean report, int *academy) + bool report, int *academy) { teaching_info *teach = NULL; attrib *a; @@ -393,7 +393,7 @@ int teach_cmd(unit * u, struct order *ord) while (!parser_end()) { unit *u2 = getunit(r, u->faction); - boolean feedback; + bool feedback; ++count; /* Falls die Unit nicht gefunden wird, Fehler melden */ @@ -763,7 +763,7 @@ int learn_cmd(unit * u, order * ord) while (teach->teachers[index] && index != MAXTEACHERS) { unit *teacher = teach->teachers[index++]; if (teacher->faction != u->faction) { - boolean feedback = alliedunit(u, teacher->faction, HELP_GUARD); + bool feedback = alliedunit(u, teacher->faction, HELP_GUARD); if (feedback) { ADDMSG(&teacher->faction->msgs, msg_message("teach_teacher", "teacher student skill level", teacher, u, sk, diff --git a/src/gamecode/study.h b/src/gamecode/study.h index 3527e3cec..182e364ee 100644 --- a/src/gamecode/study.h +++ b/src/gamecode/study.h @@ -27,7 +27,7 @@ extern "C" { extern int learn_cmd(struct unit *u, struct order *ord); extern magic_t getmagicskill(const struct locale *lang); - extern boolean is_migrant(struct unit *u); + extern bool is_migrant(struct unit *u); extern int study_cost(struct unit *u, skill_t talent); #define MAXTEACHERS 4 diff --git a/src/gamecode/summary.c b/src/gamecode/summary.c index 03690dee7..1d3c73e2f 100644 --- a/src/gamecode/summary.c +++ b/src/gamecode/summary.c @@ -132,7 +132,7 @@ static void writeturn(void) fclose(f); } -void report_summary(summary * s, summary * o, boolean full) +void report_summary(summary * s, summary * o, bool full) { FILE *F = NULL; int i, newplayers = 0; diff --git a/src/gamecode/summary.h b/src/gamecode/summary.h index 5da62e688..bb2ae04b7 100644 --- a/src/gamecode/summary.h +++ b/src/gamecode/summary.h @@ -17,7 +17,7 @@ extern "C" { struct summary; extern void report_summary(struct summary *n, struct summary *o, - boolean full); + bool full); extern struct summary *make_summary(void); #ifdef __cplusplus diff --git a/src/gamecode/xmlreport.c b/src/gamecode/xmlreport.c index 5b93dc887..f4e4f9b6d 100644 --- a/src/gamecode/xmlreport.c +++ b/src/gamecode/xmlreport.c @@ -31,6 +31,7 @@ without prior permission by the authors of Eressea. /* kernel includes */ #include <kernel/alchemy.h> #include <kernel/alliance.h> +#include <kernel/ally.h> #include <kernel/connection.h> #include <kernel/curse.h> #include <kernel/building.h> @@ -213,10 +214,10 @@ static xmlNodePtr xml_unit(report_context * ctx, unit * u, int mode) xml_context *xct = (xml_context *) ctx->userdata; xmlNodePtr node = xmlNewNode(xct->ns_atl, BAD_CAST "unit"); static const curse_type *itemcloak_ct = 0; - static boolean init = false; + static bool init = false; xmlNodePtr child; const char *str, *rcname, *rcillusion; - boolean disclosure = (ctx->f == u->faction || omniscient(ctx->f)); + bool disclosure = (ctx->f == u->faction || omniscient(ctx->f)); /* TODO: hitpoints, aura, combatspells, curses */ @@ -391,7 +392,7 @@ static xmlNodePtr xml_unit(report_context * ctx, unit * u, int mode) if (disclosure) { show = u->items; } else { - boolean see_items = (mode >= see_unit); + bool see_items = (mode >= see_unit); if (see_items) { if (itemcloak_ct && curse_active(get_curse(u->attribs, itemcloak_ct))) { see_items = false; diff --git a/src/gmtool.c b/src/gmtool.c index 57d715501..83d637d04 100644 --- a/src/gmtool.c +++ b/src/gmtool.c @@ -356,7 +356,7 @@ static void paint_status(window * wnd, const state * st) wclrtoeol(win); } -static boolean handle_info_region(window * wnd, state * st, int c) +static bool handle_info_region(window * wnd, state * st, int c) { return false; } @@ -1281,7 +1281,7 @@ curses_readline(struct lua_State *L, char *buffer, size_t size, return buffer[0] != 0; } -void seed_players(const char *filename, boolean new_island) +void seed_players(const char *filename, bool new_island) { newfaction *players = read_newfactions(filename); if (players != NULL) { diff --git a/src/gmtool.h b/src/gmtool.h index fa2df80e7..0359973b5 100644 --- a/src/gmtool.h +++ b/src/gmtool.h @@ -33,7 +33,7 @@ extern "C" { void state_close(struct state *); void make_block(int x, int y, int radius, const struct terrain_type *terrain); - void seed_players(const char *filename, boolean new_island); + void seed_players(const char *filename, bool new_island); #ifdef __cplusplus } diff --git a/src/gmtool_structs.h b/src/gmtool_structs.h index 49acbf526..1f3e4e9a7 100644 --- a/src/gmtool_structs.h +++ b/src/gmtool_structs.h @@ -70,13 +70,13 @@ extern "C" { } state; typedef struct window { - boolean(*handlekey) (struct window * win, struct state * st, int key); + bool(*handlekey) (struct window * win, struct state * st, int key); void (*paint) (struct window * win, const struct state * st); WINDOW *handle; struct window *next; struct window *prev; - boolean initialized; + bool initialized; int update; } window; diff --git a/src/items/phoenixcompass.c b/src/items/phoenixcompass.c index e26adfa8e..9787d4e9d 100644 --- a/src/items/phoenixcompass.c +++ b/src/items/phoenixcompass.c @@ -45,7 +45,7 @@ use_phoenixcompass(struct unit *u, const struct item_type *itype, region *r; unit *closest_phoenix = NULL; int closest_phoenix_distance = INT_MAX; - boolean confusion = false; + bool confusion = false; direction_t direction; unit *u2; direction_t closest_neighbour_direction = 0; diff --git a/src/items/weapons.c b/src/items/weapons.c index 05fbc31a5..7b817510a 100644 --- a/src/items/weapons.c +++ b/src/items/weapons.c @@ -38,7 +38,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. /* damage types */ -static boolean +static bool attack_firesword(const troop * at, const struct weapon_type *wtype, int *casualties) { @@ -83,7 +83,7 @@ attack_firesword(const troop * at, const struct weapon_type *wtype, #define CATAPULT_ATTACKS 6 -static boolean +static bool attack_catapult(const troop * at, const struct weapon_type *wtype, int *casualties) { diff --git a/src/items/xerewards.c b/src/items/xerewards.c index fb1a9595d..26cd621bb 100644 --- a/src/items/xerewards.c +++ b/src/items/xerewards.c @@ -54,7 +54,7 @@ use_skillpotion(struct unit *u, const struct item_type *itype, int amount, while (sv != u->skills + u->skill_size) { int i; for (i = 0; i != 3; ++i) - learn_skill(u, sv->id, 1.0); + learn_skill(u, (skill_t)sv->id, 1.0); ++sv; } } diff --git a/src/kernel/alliance.c b/src/kernel/alliance.c index ede4b0dfd..afd31343d 100644 --- a/src/kernel/alliance.c +++ b/src/kernel/alliance.c @@ -452,7 +452,7 @@ int victorycondition(const alliance * al, const char *name) const struct item_type *itype = it_find(*igem); quicklist *flist = al->members; int qi; - boolean found = false; + bool found = false; assert(itype != NULL); for (qi = 0; flist && !found; ql_advance(&flist, &qi, 1)) { diff --git a/src/kernel/alliance.h b/src/kernel/alliance.h index a97227ab0..04871c50a 100644 --- a/src/kernel/alliance.h +++ b/src/kernel/alliance.h @@ -40,6 +40,8 @@ extern "C" { #define ALF_NON_ALLIED (1<<0) /* this alliance is just a default for a non-allied faction */ +#define ALLY_ENEMY (1<<0) + typedef struct alliance { struct alliance *next; struct faction *_leader; @@ -47,6 +49,7 @@ extern "C" { unsigned int flags; int id; char *name; + struct ally *allies; } alliance; extern alliance *alliances; diff --git a/src/kernel/ally.c b/src/kernel/ally.c new file mode 100644 index 000000000..cf5772fd6 --- /dev/null +++ b/src/kernel/ally.c @@ -0,0 +1,39 @@ +#include "types.h" +#include "ally.h" + +#include <stdlib.h> + +ally * ally_find(ally *al, const struct faction *f) { + for (;al;al=al->next) { + if (al->faction==f) return al; + } + return 0; +} + +ally * ally_add(ally **al_p, struct faction *f) { + ally * al; + while (*al_p) { + al = *al_p; + if (al->faction==f) return al; + al_p = &al->next; + } + al = (ally *)malloc(sizeof(ally)); + al->faction = f; + al->status = 0; + al->next = 0; + *al_p = al; + return al; +} + +void ally_remove(ally **al_p, struct faction *f) { + ally * al; + while (*al_p) { + al = *al_p; + if (al->faction==f) { + *al_p = al->next; + free(al); + break; + } + al_p = &al->next; + } +} diff --git a/src/kernel/ally.h b/src/kernel/ally.h new file mode 100644 index 000000000..5e09b721c --- /dev/null +++ b/src/kernel/ally.h @@ -0,0 +1,40 @@ +/* +Copyright (c) 1998-2010, Enno Rehling <enno@eressea.de> + Katja Zedel <katze@felidae.kn-bremen.de + Christian Schlittchen <corwin@amber.kn-bremen.de> + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +**/ + +#ifndef ALLY_H +#define ALLY_H + +#ifdef __cplusplus +extern "C" { +#endif + + typedef struct ally { + struct ally *next; + struct faction *faction; + int status; + } ally; + + ally * ally_find(ally *al, const struct faction *f); + ally * ally_add(ally **al_p, struct faction *f); + void ally_remove(ally **al_p, struct faction *f); + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/src/kernel/ally_test.c b/src/kernel/ally_test.c new file mode 100644 index 000000000..c7b8500ad --- /dev/null +++ b/src/kernel/ally_test.c @@ -0,0 +1,27 @@ +#include <platform.h> +#include "types.h" +#include "ally.h" + +#include <CuTest.h> +#include <tests.h> + +static void test_ally(CuTest * tc) +{ + ally * al = 0; + struct faction * f1 = test_create_faction(0); + + ally_add(&al, f1); + CuAssertPtrNotNull(tc, al); + CuAssertPtrEquals(tc, f1, ally_find(al, f1)->faction); + + ally_remove(&al, f1); + CuAssertPtrEquals(tc, 0, al); + CuAssertPtrEquals(tc, 0, ally_find(al, f1)); +} + +CuSuite *get_ally_suite(void) +{ + CuSuite *suite = CuSuiteNew(); + SUITE_ADD_TEST(suite, test_ally); + return suite; +} diff --git a/src/kernel/battle.c b/src/kernel/battle.c index ab7a52db7..b69107524 100644 --- a/src/kernel/battle.c +++ b/src/kernel/battle.c @@ -175,35 +175,6 @@ static int army_index(side * s) return s->index; } -#ifndef SIMPLE_ESCAPE -region *fleeregion(const unit * u) -{ - region *r = u->region; - region *neighbours[MAXDIRECTIONS]; - int c = 0; - direction_t i; - - if (u->ship && !fval(r->terrain, SEA_REGION)) - return NULL; - - if (u->ship && !(u->race->flags & RCF_SWIM) && !(u->race->flags & RCF_FLY)) { - return NULL; - } - - for (i = 0; i != MAXDIRECTIONS; ++i) { - region *r2 = rconnect(r, i); - if (r2) { - if (can_survive(u, r2) && !move_blocked(u, r, r2)) - neighbours[c++] = r2; - } - } - - if (!c) - return NULL; - return neighbours[rng_int() % c]; -} -#endif /* SIMPLE_ESCAPE */ - static char *sidename(side * s) { #define SIDENAMEBUFLEN 256 @@ -215,7 +186,7 @@ static char *sidename(side * s) return sidename_buf[bufno++]; } -static const char *sideabkz(side * s, boolean truename) +static const char *sideabkz(side * s, bool truename) { static char sideabkz_buf[8]; /* STATIC_RESULT: used for return, not across calls */ const faction *f = (s->stealthfaction @@ -235,7 +206,7 @@ static void message_faction(battle * b, faction * f, struct message *m) region *r = b->region; if (f->battles == NULL || f->battles->r != r) { - struct bmsg *bm = calloc(1, sizeof(struct bmsg)); + struct bmsg *bm = (struct bmsg *)calloc(1, sizeof(struct bmsg)); bm->next = f->battles; f->battles = bm; bm->r = r; @@ -243,7 +214,7 @@ static void message_faction(battle * b, faction * f, struct message *m) add_message(&f->battles->msgs, m); } -int armedmen(const unit * u, boolean siege_weapons) +int armedmen(const unit * u, bool siege_weapons) { item *itm; int n = 0; @@ -302,7 +273,7 @@ static void fbattlerecord(battle * b, faction * f, const char *s) #define enemy(as, ds) (as->relations[ds->index]&E_ENEMY) #define friendly(as, ds) (as->relations[ds->index]&E_FRIEND) -static boolean set_enemy(side * as, side * ds, boolean attacking) +static bool set_enemy(side * as, side * ds, bool attacking) { int i; for (i = 0; i != MAXSIDES; ++i) { @@ -395,11 +366,11 @@ fighter *select_corpse(battle * b, fighter * af) return NULL; } -boolean helping(const side * as, const side * ds) +bool helping(const side * as, const side * ds) { if (as->faction == ds->faction) return true; - return (boolean) (!enemy(as, ds) && allysf(as, ds->faction)); + return (bool) (!enemy(as, ds) && allysf(as, ds->faction)); } int statusrow(int status) @@ -443,7 +414,7 @@ static double hpflee(int status) static int get_row(const side * s, int row, const side * vs) { - boolean counted[MAXSIDES]; + bool counted[MAXSIDES]; int enemyfront = 0; int line, result; int retreat = 0; @@ -508,7 +479,6 @@ int get_unitrow(const fighter * af, const side * vs) break; return FIGHT_ROW + (row - i); } else { -#ifdef FASTROW battle *b = vs->battle; if (row != b->rowcache.row || b->alive != b->rowcache.alive || af->side != b->rowcache.as || vs != b->rowcache.vs) { @@ -526,9 +496,6 @@ int get_unitrow(const fighter * af, const side * vs) } #endif return b->rowcache.result; -#else - return get_row(af->side, row, vs); -#endif } } @@ -538,14 +505,6 @@ static void reportcasualties(battle * b, fighter * fig, int dead) region *r = NULL; if (fig->alive == fig->unit->number) return; -#ifndef SIMPLE_ESCAPE - if (fig->run.region == NULL) { - fig->run.region = fleeregion(fig->unit); - if (fig->run.region == NULL) - fig->run.region = b->region; - } - r = fig->run.region; -#endif /* SIMPLE_ESCAPE */ m = msg_message("casualties", "unit runto run alive fallen", fig->unit, r, fig->run.number, fig->alive, dead); message_all(b, m); @@ -601,7 +560,7 @@ contest(int skdiff, const troop dt, const armor_type * ar, } } -static boolean is_riding(const troop t) +static bool is_riding(const troop t) { if (t.fighter->building != NULL) return false; @@ -610,7 +569,7 @@ static boolean is_riding(const troop t) return false; } -static weapon *preferred_weapon(const troop t, boolean attacking) +static weapon *preferred_weapon(const troop t, bool attacking) { weapon *missile = t.fighter->person[t.index].missile; weapon *melee = t.fighter->person[t.index].melee; @@ -627,8 +586,8 @@ static weapon *preferred_weapon(const troop t, boolean attacking) return melee; } -static weapon *select_weapon(const troop t, boolean attacking, - boolean ismissile) +static weapon *select_weapon(const troop t, bool attacking, + bool ismissile) /* select the primary weapon for this trooper */ { if (attacking) { @@ -645,7 +604,7 @@ static weapon *select_weapon(const troop t, boolean attacking, return preferred_weapon(t, attacking); } -static boolean i_canuse(const unit * u, const item_type * itype) +static bool i_canuse(const unit * u, const item_type * itype) { if (itype->canuse) { return itype->canuse(u, itype); @@ -654,7 +613,7 @@ static boolean i_canuse(const unit * u, const item_type * itype) } static int -weapon_skill(const weapon_type * wtype, const unit * u, boolean attacking) +weapon_skill(const weapon_type * wtype, const unit * u, bool attacking) /* the 'pure' skill when using this weapon to attack or defend. * only undiscriminate modifiers (not affected by troops or enemies) * are taken into account, e.g. no horses, magic, etc. */ @@ -770,8 +729,8 @@ static int CavalryBonus(const unit * u, troop enemy, int type) } static int -weapon_effskill(troop t, troop enemy, const weapon * w, boolean attacking, - boolean missile) +weapon_effskill(troop t, troop enemy, const weapon * w, bool attacking, + bool missile) /* effektiver Waffenskill w�hrend des Kampfes */ { /* In dieser Runde alle die Modifier berechnen, die fig durch die @@ -851,7 +810,7 @@ weapon_effskill(troop t, troop enemy, const weapon * w, boolean attacking, return skill; } -static const armor_type *select_armor(troop t, boolean shield) +static const armor_type *select_armor(troop t, bool shield) { unsigned int type = shield ? ATF_SHIELD : 0; unit *u = t.fighter->unit; @@ -899,7 +858,7 @@ int select_magicarmor(troop t) } /* Sind side ds und Magier des meffect verb�ndet, dann return 1*/ -boolean meffect_protection(battle * b, meffect * s, side * ds) +bool meffect_protection(battle * b, meffect * s, side * ds) { if (!s->magician->alive) return false; @@ -913,7 +872,7 @@ boolean meffect_protection(battle * b, meffect * s, side * ds) } /* Sind side as und Magier des meffect verfeindet, dann return 1*/ -boolean meffect_blocked(battle * b, meffect * s, side * as) +bool meffect_blocked(battle * b, meffect * s, side * as) { if (!s->magician->alive) return false; @@ -973,12 +932,8 @@ void remove_troop(troop dt) fighter *df = dt.fighter; struct person p = df->person[dt.index]; battle *b = df->side->battle; -#ifdef FASTCOUNT b->fast.alive = -1; /* invalidate cached value */ -#endif -#ifdef FASTROW b->rowcache.alive = -1; /* invalidate cached value */ -#endif ++df->removed; ++df->side->removed; df->person[dt.index] = df->person[df->alive - df->removed]; @@ -1096,8 +1051,8 @@ static int natural_armor(unit * du) return an; } -boolean -terminate(troop dt, troop at, int type, const char *damage, boolean missile) +bool +terminate(troop dt, troop at, int type, const char *damage, bool missile) { item **pitm; fighter *df = dt.fighter; @@ -1121,13 +1076,11 @@ terminate(troop dt, troop at, int type, const char *damage, boolean missile) const weapon *weapon; int rda, sk = 0, sd; - boolean magic = false; + bool magic = false; int da = dice_rand(damage); assert(du->number > 0); -#ifdef SHOW_KILLS ++at.fighter->hits; -#endif switch (type) { case AT_STANDARD: @@ -1364,9 +1317,7 @@ terminate(troop dt, troop at, int type, const char *damage, boolean missile) return false; } } -#ifdef SHOW_KILLS ++at.fighter->kills; -#endif if (bdebug) { fprintf(bdebug, "Damage %d, armor %d, type %d: %d -> %d HP, tot.\n", @@ -1468,7 +1419,6 @@ int count_enemies(battle * b, const fighter * af, int minrow, int maxrow, int select) { -#ifdef FASTCOUNT int sr = statusrow(af->status); side *as = af->side; @@ -1497,12 +1447,9 @@ count_enemies(battle * b, const fighter * af, int minrow, int maxrow, b->fast.maxrow = maxrow; memset(b->fast.enemies, -1, sizeof(b->fast.enemies)); } -#endif if (maxrow >= FIRST_ROW) { int i = count_enemies_i(b, af, minrow, maxrow, select); -#ifdef FASTCOUNT b->fast.enemies[select] = i; -#endif return i; } return 0; @@ -1788,14 +1735,6 @@ void do_combatmagic(battle * b, combatmagic_t was) } } -static void combat_action(fighter * af) -{ -#ifndef SIMPLE_COMBAT - af->action_counter++; - af->side->bf->lastturn = af->side->battle->turn; -#endif -} - static int cast_combatspell(troop at, const spell * sp, int level, double force) { castorder co; @@ -1806,7 +1745,6 @@ static int cast_combatspell(troop at, const spell * sp, int level, double force) free_castorder(&co); if (level > 0) { pay_spell(at.fighter->unit, sp, level, 1); - combat_action(at.fighter); } return level; } @@ -1926,7 +1864,7 @@ int skilldiff(troop at, troop dt, int dist) } if (df->building) { - boolean init = false; + bool init = false; static const curse_type *strongwall_ct, *magicwalls_ct; if (!init) { strongwall_ct = ct_find("strongwall"); @@ -1996,7 +1934,7 @@ int getreload(troop at) static void debug_hit(troop at, const weapon * awp, troop dt, const weapon * dwp, - int skdiff, int dist, boolean success) + int skdiff, int dist, bool success) { fprintf(bdebug, "%.4s/%d [%6s/%d] %s %.4s/%d [%6s/%d] with %d, distance %d\n", unitid(at.fighter->unit), at.index, @@ -2174,8 +2112,8 @@ static void attack(battle * b, troop ta, const att * a, int numattack) if (getreload(ta)) { ta.fighter->person[ta.index].reload--; } else { - boolean standard_attack = true; - boolean reload = false; + bool standard_attack = true; + bool reload = false; /* spezialattacken der waffe nur, wenn erste attacke in der runde. * sonst helden mit feuerschwertern zu m�chtig */ if (numattack == 0 && wp && wp->type->attack) { @@ -2186,11 +2124,10 @@ static void attack(battle * b, troop ta, const att * a, int numattack) af->catmsg += dead; if (!standard_attack && af->person[ta.index].last_action < b->turn) { af->person[ta.index].last_action = b->turn; - combat_action(af); } } if (standard_attack) { - boolean missile = false; + bool missile = false; if (wp && fval(wp->type, WTF_MISSILE)) missile = true; if (missile) { @@ -2202,7 +2139,6 @@ static void attack(battle * b, troop ta, const att * a, int numattack) return; if (ta.fighter->person[ta.index].last_action < b->turn) { ta.fighter->person[ta.index].last_action = b->turn; - combat_action(ta.fighter); } reload = true; if (hits(ta, td, wp)) { @@ -2235,7 +2171,6 @@ static void attack(battle * b, troop ta, const att * a, int numattack) return; if (ta.fighter->person[ta.index].last_action < b->turn) { ta.fighter->person[ta.index].last_action = b->turn; - combat_action(ta.fighter); } if (hits(ta, td, NULL)) { terminate(td, ta, a->type, a->data.dice, false); @@ -2247,7 +2182,6 @@ static void attack(battle * b, troop ta, const att * a, int numattack) return; if (ta.fighter->person[ta.index].last_action < b->turn) { ta.fighter->person[ta.index].last_action = b->turn; - combat_action(ta.fighter); } if (hits(ta, td, NULL)) { int c = dice_rand(a->data.dice); @@ -2267,7 +2201,6 @@ static void attack(battle * b, troop ta, const att * a, int numattack) return; if (ta.fighter->person[ta.index].last_action < b->turn) { ta.fighter->person[ta.index].last_action = b->turn; - combat_action(ta.fighter); } if (hits(ta, td, NULL)) { drain_exp(td.fighter->unit, dice_rand(a->data.dice)); @@ -2279,7 +2212,6 @@ static void attack(battle * b, troop ta, const att * a, int numattack) return; if (ta.fighter->person[ta.index].last_action < b->turn) { ta.fighter->person[ta.index].last_action = b->turn; - combat_action(ta.fighter); } if (hits(ta, td, NULL)) { dazzle(b, &td); @@ -2291,7 +2223,6 @@ static void attack(battle * b, troop ta, const att * a, int numattack) return; if (ta.fighter->person[ta.index].last_action < b->turn) { ta.fighter->person[ta.index].last_action = b->turn; - combat_action(ta.fighter); } if (td.fighter->unit->ship) { /* FIXME should use damage_ship here? */ @@ -2453,7 +2384,6 @@ side *make_side(battle * b, const faction * f, const group * g, side *s1 = b->sides + b->nsides; bfaction *bf; -#ifdef SIMPLE_COMBAT if (fval(b->region->terrain, SEA_REGION)) { /* every fight in an ocean is short */ flags |= SIDE_HASGUARDS; @@ -2468,7 +2398,6 @@ side *make_side(battle * b, const faction * f, const group * g, } } } -#endif s1->battle = b; s1->group = g; @@ -2631,23 +2560,7 @@ static void loot_items(fighter * corpse) } } -#ifndef SIMPLE_ESCAPE -static void loot_fleeing(fighter * fig, unit * runner) -{ - /* TODO: Vern�nftig fixen */ - runner->items = NULL; - assert(runner->items == NULL); - runner->items = fig->run.items; - fig->run.items = NULL; -} - -static void merge_fleeloot(fighter * fig, unit * u) -{ - i_merge(&u->items, &fig->run.items); -} -#endif /* SIMPLE_ESCAPE */ - -static boolean seematrix(const faction * f, const side * s) +static bool seematrix(const faction * f, const side * s) { if (f == s->faction) return true; @@ -2713,7 +2626,7 @@ static void aftermath(battle * b) side *s; int dead_players = 0; bfaction *bf; - boolean ships_damaged = (boolean) (b->turn + (b->has_tactics_turn ? 1 : 0) > 2); /* only used for ship damage! */ + bool ships_damaged = (bool) (b->turn + (b->has_tactics_turn ? 1 : 0) > 2); /* only used for ship damage! */ for (s = b->sides; s != b->sides + b->nsides; ++s) { fighter *df; @@ -2743,7 +2656,6 @@ static void aftermath(battle * b) if (playerrace(df->unit->race)) { s->casualties += dead; } -#ifdef SHOW_KILLS if (df->hits + df->kills) { struct message *m = msg_message("killsandhits", "unit hits kills", du, df->hits, @@ -2751,7 +2663,6 @@ static void aftermath(battle * b) message_faction(b, du->faction, m); msg_release(m); } -#endif } } @@ -2761,23 +2672,10 @@ static void aftermath(battle * b) for (s = b->sides; s != b->sides + b->nsides; ++s) { int snumber = 0; fighter *df; - boolean relevant = false; /* Kampf relevant f�r diese Partei? */ -#ifdef SIMPLE_COMBAT - if (fval(s, SIDE_HASGUARDS) == 0) + bool relevant = false; /* Kampf relevant f�r diese Partei? */ + if (!fval(s, SIDE_HASGUARDS)) { relevant = true; -#else - if (s->bf->lastturn > 1) { - relevant = true; - } else if (s->bf->lastturn == 1 && b->has_tactics_turn) { - side *stac; - for (stac = b->sides; stac; stac = stac->next) { - if (stac->leader.value == b->max_tactics && helping(stac, s)) { - relevant = true; - break; - } - } } -#endif s->flee = 0; for (df = s->fighters; df; df = df->next) { @@ -2792,13 +2690,11 @@ static void aftermath(battle * b) } } snumber += du->number; -#ifdef SIMPLE_COMBAT if (relevant) { int flags = UFL_LONGACTION | UFL_NOTMOVING; -#ifdef SIMPLE_ESCAPE - if (du->status == ST_FLEE) + if (du->status == ST_FLEE) { flags -= UFL_NOTMOVING; -#endif /* SIMPLE_ESCAPE */ + } fset(du, flags); } if (sum_hp + df->run.hp < du->hp) { @@ -2807,17 +2703,6 @@ static void aftermath(battle * b) if (sh) fset(sh, SF_DAMAGED); } -#else - if (relevant) { - fset(du, UFL_NOTMOVING); /* unit cannot move this round */ - if (df->action_counter >= du->number) { - ship *sh = du->ship ? du->ship : leftship(du); - if (sh) - fset(sh, SF_DAMAGED); - fset(du, UFL_LONGACTION); - } - } -#endif if (df->alive == du->number) { du->hp = sum_hp; @@ -2830,18 +2715,9 @@ static void aftermath(battle * b) /* Zuerst d�rfen die Feinde pl�ndern, die mitgenommenen Items * stehen in fig->run.items. Dann werden die Fliehenden auf * die leere (tote) alte Einheit gemapt */ -#ifdef SIMPLE_ESCAPE if (!fval(df, FIG_NOLOOT)) { loot_items(df); } -#else - if (fval(df, FIG_NOLOOT)) { - merge_fleeloot(df, du); - } else { - loot_items(df); - loot_fleeing(df, du); - } -#endif /* SIMPLE_ESCAPE */ scale_number(du, df->run.number); du->hp = df->run.hp; setguard(du, GUARD_NONE); @@ -2850,13 +2726,6 @@ static void aftermath(battle * b) if (!fval(r->terrain, SEA_REGION)) { leave(du, true); /* even region owners have to flee */ } -#ifndef SIMPLE_ESCAPE - if (df->run.region) { - run_to(du, df->run.region); - df->run.region = du->region; - } - fset(du, UFL_LONGACTION | UFL_NOTMOVING); -#endif /* SIMPLE_ESCAPE */ fset(du, UFL_FLEEING); } else { /* nur teilweise geflohene Einheiten mergen sich wieder */ @@ -2865,9 +2734,6 @@ static void aftermath(battle * b) s->size[statusrow(df->status)] += df->run.number; s->alive += df->run.number; sum_hp += df->run.hp; -#ifndef SIMPLE_ESCAPE - merge_fleeloot(df, du); -#endif /* SIMPLE_ESCAPE */ df->run.number = 0; df->run.hp = 0; /* df->run.region = NULL; */ @@ -2882,9 +2748,6 @@ static void aftermath(battle * b) /* alle sind tot, niemand geflohen. Einheit aufl�sen */ df->run.number = 0; df->run.hp = 0; -#ifndef SIMPLE_ESCAPE - df->run.region = NULL; -#endif /* SIMPLE_ESCAPE */ /* Report the casualties */ reportcasualties(b, df, dead); @@ -3057,7 +2920,7 @@ static void print_fighters(battle * b, const side * s) } } -boolean is_attacker(const fighter * fig) +bool is_attacker(const fighter * fig) { return fval(fig, FIG_ATTACKER) != 0; } @@ -3076,7 +2939,7 @@ static void print_header(battle * b) message *m; faction *f = bf->faction; const char *lastf = NULL; - boolean first = false; + bool first = false; side *s; char *bufp = zText; size_t size = sizeof(zText) - 1; @@ -3266,7 +3129,7 @@ static void print_stats(battle * b) } } -static int weapon_weight(const weapon * w, boolean missile) +static int weapon_weight(const weapon * w, bool missile) { if (missile == i2b(fval(w->type, WTF_MISSILE))) { return w->attackskill + w->defenseskill; @@ -3274,7 +3137,46 @@ static int weapon_weight(const weapon * w, boolean missile) return 0; } -fighter *make_fighter(battle * b, unit * u, side * s1, boolean attack) +side * get_side(battle * b, const struct unit * u) +{ + side * s; + for (s = b->sides; s != b->sides + b->nsides; ++s) { + if (s->faction==u->faction) { + fighter * fig; + for (fig=s->fighters;fig;fig=fig->next) { + if (fig->unit==u) { + return s; + } + } + } + } + return 0; +} + +side * find_side(battle * b, const faction * f, const group * g, int flags, const faction * stealthfaction) +{ + side * s; + static int rule_anon_battle = -1; + + if (rule_anon_battle < 0) { + rule_anon_battle = get_param_int(global.parameters, "rules.stealth.anon_battle", 1); + } + for (s = b->sides; s != b->sides + b->nsides; ++s) { + if (s->faction == f && s->group == g) { + int s1flags = flags | SIDE_HASGUARDS; + int s2flags = s->flags | SIDE_HASGUARDS; + if (rule_anon_battle && s->stealthfaction != stealthfaction) { + continue; + } + if (s1flags == s2flags) { + return s; + } + } + } + return 0; +} + +fighter *make_fighter(battle * b, unit * u, side * s1, bool attack) { #define WMAX 20 weapon weapons[WMAX]; @@ -3284,26 +3186,18 @@ fighter *make_fighter(battle * b, unit * u, side * s1, boolean attack) region *r = b->region; item *itm; fighter *fig = NULL; - int i, tactics = eff_skill(u, SK_TACTICS, r); - side *s2; - int h; + int h, i, tactics = eff_skill(u, SK_TACTICS, r); int berserk; int strongmen; int speeded = 0, speed = 1; - boolean pr_aid = false; + bool pr_aid = false; int rest; const group *g = NULL; const attrib *a = a_find(u->attribs, &at_otherfaction); const faction *stealthfaction = a ? get_otherfaction(a) : NULL; unsigned int flags = 0; - static int rule_anon_battle = -1; assert(u->number); - - if (rule_anon_battle < 0) { - rule_anon_battle = - get_param_int(global.parameters, "rules.stealth.anon_battle", 1); - } if (fval(u, UFL_ANON_FACTION) != 0) flags |= SIDE_STEALTH; if (!(AllianceAuto() & HELP_FIGHT) && fval(u, UFL_GROUP)) { @@ -3317,25 +3211,7 @@ fighter *make_fighter(battle * b, unit * u, side * s1, boolean attack) return NULL; } if (s1 == NULL) { - for (s2 = b->sides; s2 != b->sides + b->nsides; ++s2) { - if (s2->faction == u->faction && s2->group == g) { -#ifdef SIMPLE_COMBAT - int s1flags = flags | SIDE_HASGUARDS; - int s2flags = s2->flags | SIDE_HASGUARDS; -#else - int s1flags = flags; - int s2flags = s2->flags; -#endif - if (rule_anon_battle && s2->stealthfaction != stealthfaction) { - continue; - } - if (s1flags == s2flags) { - s1 = s2; - break; - } - } - } - + s1 = find_side(b, u->faction, g, flags, stealthfaction); /* aliances are moved out of make_fighter and will be handled later */ if (!s1) { s1 = make_side(b, u->faction, g, flags, stealthfaction); @@ -3345,7 +3221,7 @@ fighter *make_fighter(battle * b, unit * u, side * s1, boolean attack) /* Zu diesem Zeitpunkt ist attacked noch 0, da die Einheit f�r noch * keinen Kampf ausgew�hlt wurde (sonst w�rde ein fighter existieren) */ } - fig = calloc(1, sizeof(struct fighter)); + fig = (struct fighter*)calloc(1, sizeof(struct fighter)); fig->next = s1->fighters; s1->fighters = fig; @@ -3370,7 +3246,7 @@ fighter *make_fighter(battle * b, unit * u, side * s1, boolean attack) fig->catmsg = -1; /* Freigeben nicht vergessen! */ - fig->person = calloc(fig->alive, sizeof(struct person)); + fig->person = (struct person*)calloc(fig->alive, sizeof(struct person)); h = u->hp / u->number; assert(h); @@ -3601,7 +3477,24 @@ fighter *make_fighter(battle * b, unit * u, side * s1, boolean attack) return fig; } -static int join_battle(battle * b, unit * u, boolean attack, fighter ** cp) +fighter * get_fighter(battle * b, const struct unit * u) +{ + side * s; + + for (s = b->sides; s != b->sides + b->nsides; ++s) { + fighter *fig; + if (s->faction == u->faction) { + for (fig = s->fighters; fig; fig = fig->next) { + if (fig->unit == u) { + return fig; + } + } + } + } + return 0; +} + +static int join_battle(battle * b, unit * u, bool attack, fighter ** cp) { side *s; fighter *c = NULL; @@ -3684,7 +3577,7 @@ battle *make_battle(region * r) else { const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 }; fwrite(utf8_bom, 1, 3, bdebug); - fprintf(bdebug, "In %s findet ein Kampf stattactics:\n", rname(r, + fprintf(bdebug, "In %s findet ein Kampf statt:\n", rname(r, default_locale)); } obs_count++; @@ -3742,7 +3635,6 @@ static void free_fighter(fighter * fig) static void free_battle(battle * b) { - side *s; int max_fac_no = 0; if (bdebug) { @@ -3757,19 +3649,11 @@ static void free_battle(battle * b) free(bf); } - for (s = b->sides; s != b->sides + b->nsides; ++s) { - fighter *fnext = s->fighters; - while (fnext) { - fighter *fig = fnext; - fnext = fig->next; - free_fighter(fig); - free(fig); - } - free_side(s); - } ql_free(b->leaders); ql_foreach(b->meffects, free); ql_free(b->meffects); + + battle_free(b); } static int *get_alive(side * s) @@ -3792,8 +3676,8 @@ static int *get_alive(side * s) static int battle_report(battle * b) { side *s, *s2; - boolean cont = false; - boolean komma; + bool cont = false; + bool komma; bfaction *bf; for (s = b->sides; s != b->sides + b->nsides; ++s) { @@ -4010,53 +3894,6 @@ static void flee(const troop dt) fighter *fig = dt.fighter; unit *u = fig->unit; -#ifndef SIMPLE_ESCAPE - int carry = personcapacity(u) - u->race->weight; - int money; - - item **ip = &u->items; - - while (*ip) { - item *itm = *ip; - const item_type *itype = itm->type; - int keep = 0; - - if (fval(itype, ITF_ANIMAL)) { - /* Regel�nderung: Man mu� das Tier nicht reiten k�nnen, - * um es vom Schlachtfeld mitzunehmen, ist ja nur - * eine Region weit. * */ - keep = MIN(1, itm->number); - /* da ist das weight des tiers mit drin */ - carry += itype->capacity - itype->weight; - } else if (itm->type->weight <= 0) { - /* if it doesn'tactics weigh anything, it won'tactics slow us down */ - keep = itm->number; - } - /* jeder troop nimmt seinen eigenen Teil der Sachen mit */ - if (keep > 0) { - if (itm->number == keep) { - i_add(&fig->run.items, i_remove(ip, itm)); - } else { - item *run_itm = i_new(itype, keep); - i_add(&fig->run.items, run_itm); - i_change(ip, itype, -keep); - } - } - if (*ip == itm) - ip = &itm->next; - } - - /* we will take money with us */ - money = get_money(u); - /* nur ganzgeflohene/resttote Einheiten verlassen die Region */ - if (money > carry) - money = carry; - if (money > 0) { - i_change(&u->items, i_silver, -money); - i_change(&fig->run.items, i_silver, +money); - } -#endif /* SIMPLE_ESCAPE */ - fig->run.hp += fig->person[dt.index].hp; ++fig->run.number; @@ -4065,11 +3902,11 @@ static void flee(const troop dt) kill_troop(dt); } -static boolean init_battle(region * r, battle ** bp) +static bool start_battle(region * r, battle ** bp) { battle *b = NULL; unit *u; - boolean fighting = false; + bool fighting = false; /* list_foreach geht nicht, wegen flucht */ for (u = r->units; u != NULL; u = u->next) { @@ -4079,7 +3916,7 @@ static boolean init_battle(region * r, battle ** bp) order *ord; for (ord = u->orders; ord; ord = ord->next) { - static boolean init = false; + static bool init = false; static const curse_type *peace_ct, *slave_ct, *calm_ct; if (!init) { @@ -4178,7 +4015,7 @@ static boolean init_battle(region * r, battle ** bp) if (calm_ct) { attrib *a = a_find(u->attribs, &at_curse); - boolean calm = false; + bool calm = false; while (a && a->type == &at_curse) { curse *c = (curse *) a->data.v; if (c->type == calm_ct @@ -4280,7 +4117,7 @@ static void battle_stats(FILE * F, battle * b) } stat = *slist; if (stat == NULL || stat->wtype != wtype || stat->level != level) { - stat = calloc(1, sizeof(stat_info)); + stat = (stat_info*)calloc(1, sizeof(stat_info)); stat->wtype = wtype; stat->level = level; stat->next = *slist; @@ -4378,12 +4215,6 @@ static void battle_flee(battle * b) } dt.fighter = fig; -#ifndef SIMPLE_ESCAPE - if (!fig->run.region) - fig->run.region = fleeregion(u); - if (!fig->run.region) - continue; -#endif /* SIMPLE_ESCAPE */ dt.index = fig->alive - fig->removed; while (s->size[SUM_ROW] && dt.index != 0) { double ispaniced = 0.0; @@ -4434,7 +4265,7 @@ static void battle_flee(battle * b) void do_battle(region * r) { battle *b = NULL; - boolean fighting = false; + bool fighting = false; ship *sh; static int init_rules = 0; @@ -4446,7 +4277,7 @@ void do_battle(region * r) msg_separator = msg_message("battle::section", ""); } - fighting = init_battle(r, &b); + fighting = start_battle(r, &b); if (b == NULL) return; @@ -4513,3 +4344,26 @@ void do_battle(region * r) free(b); } } + +void battle_init(battle * b) { + assert(b); + memset(b, 0, sizeof(battle)); +} + +void battle_free(battle * b) { + side *s; + + assert(b); + + for (s = b->sides; s != b->sides + b->nsides; ++s) { + fighter *fnext = s->fighters; + while (fnext) { + fighter *fig = fnext; + fnext = fig->next; + free_fighter(fig); + free(fig); + } + free_side(s); + } +} + diff --git a/src/kernel/battle.h b/src/kernel/battle.h index b7fbf9f2f..eb854caeb 100644 --- a/src/kernel/battle.h +++ b/src/kernel/battle.h @@ -22,9 +22,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. extern "C" { #endif -#define SHOW_KILLS -#undef SMALL_BATTLE_MESSAGES - /** more defines **/ #define FS_ENEMY 1 #define FS_HELP 2 @@ -49,10 +46,7 @@ extern "C" { struct bfaction *next; struct side *sides; struct faction *faction; -#ifndef SIMPLE_COMBAT - int lastturn; /* last time this struct faction was involved in combat */ -#endif - boolean attacker; + bool attacker; } bfaction; typedef struct tactics { @@ -61,9 +55,7 @@ extern "C" { } tactics; #define SIDE_STEALTH 1<<0 -#ifdef SIMPLE_COMBAT #define SIDE_HASGUARDS 1<<1 -#endif typedef struct side { struct side *nextF; /* next army of same faction */ struct battle *battle; @@ -102,15 +94,10 @@ extern "C" { struct quicklist *meffects; int max_tactics; int turn; - boolean has_tactics_turn; + bool has_tactics_turn; int keeploot; - boolean reelarrow; + bool reelarrow; int alive; -#ifdef SMALL_BATTLE_MESSAGES - boolean small; -#endif -#define FASTROW -#ifdef FASTROW struct { const struct side *as; const struct side *vs; @@ -118,9 +105,6 @@ extern "C" { int row; int result; } rowcache; -#endif -#define FASTCOUNT -#ifdef FASTCOUNT struct { struct side *side; int status; @@ -128,7 +112,6 @@ extern "C" { int minrow, maxrow; int enemies[8]; } fast; -#endif } battle; typedef struct weapon { @@ -198,18 +181,9 @@ extern "C" { struct { int number; /* number of people who fled */ int hp; /* accumulated hp of fleeing people */ -#ifndef SIMPLE_ESCAPE - struct region *region; /* destination of fleeing people */ - struct item *items; /* items they take */ -#endif /* SIMPLE_ESCAPE */ } run; -#ifndef SIMPLE_COMBAT - int action_counter; /* number of active actions the struct unit did in the fight */ -#endif /* SIMPLE_COMBAT */ -#ifdef SHOW_KILLS int kills; int hits; -#endif } fighter; /* schilde */ @@ -231,6 +205,14 @@ extern "C" { extern const troop no_troop; + /* BEGIN battle interface */ + void battle_init(battle * b); + void battle_free(battle * b); + side * find_side(battle * b, const struct faction * f, const struct group * g, int flags, const struct faction * stealthfaction); + side * get_side(battle * b, const struct unit * u); + fighter * get_fighter(battle * b, const struct unit * u); + /* END battle interface */ + extern void do_battle(struct region *r); /* for combat spells and special attacks */ @@ -244,8 +226,8 @@ extern "C" { extern int count_enemies(struct battle *b, const struct fighter *af, int minrow, int maxrow, int select); - extern boolean terminate(troop dt, troop at, int type, const char *damage, - boolean missile); + extern bool terminate(troop dt, troop at, int type, const char *damage, + bool missile); extern void message_all(battle * b, struct message *m); extern int hits(troop at, troop dt, weapon * awp); extern void damage_building(struct battle *b, struct building *bldg, @@ -255,21 +237,18 @@ extern "C" { extern int count_allies(const struct side *as, int minrow, int maxrow, int select, int allytype); extern int get_unitrow(const struct fighter *af, const struct side *vs); - extern boolean helping(const struct side *as, const struct side *ds); + extern bool helping(const struct side *as, const struct side *ds); extern void rmfighter(fighter * df, int i); -#ifndef SIMPLE_ESCAPE - extern struct region *fleeregion(const struct unit *u); -#endif extern struct fighter *select_corpse(struct battle *b, struct fighter *af); extern int statusrow(int status); extern void drain_exp(struct unit *u, int d); extern void kill_troop(troop dt); extern void remove_troop(troop dt); /* not the same as the badly named rmtroop */ - extern boolean is_attacker(const fighter * fig); + extern bool is_attacker(const fighter * fig); extern struct battle *make_battle(struct region * r); extern fighter *make_fighter(struct battle *b, struct unit *u, side * s, - boolean attack); + bool attack); extern struct side *make_side(struct battle * b, const struct faction * f, const struct group * g, unsigned int flags, const struct faction * stealthfaction); diff --git a/src/kernel/battle_test.c b/src/kernel/battle_test.c index c8a558af1..8bdc50822 100644 --- a/src/kernel/battle_test.c +++ b/src/kernel/battle_test.c @@ -8,8 +8,9 @@ #include "region.h" #include "skill.h" #include "unit.h" -#include "tests.h" + #include <CuTest.h> +#include "tests.h" static void test_make_fighter(CuTest * tc) { diff --git a/src/kernel/build.c b/src/kernel/build.c index 6b9746e24..5726f4828 100644 --- a/src/kernel/build.c +++ b/src/kernel/build.c @@ -69,99 +69,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. /* Name, MaxGroesse, MinBauTalent, Kapazitaet, {Eisen, Holz, Stein, BauSilber, * Laen, Mallorn}, UnterSilber, UnterSpezialTyp, UnterSpezial */ -static boolean CheckOverload(void) -{ - static int value = -1; - if (value < 0) { - value = get_param_int(global.parameters, "rules.check_overload", 0); - } - return value; -} - -/* test if the unit can slip through a siege undetected. - * returns 0 if siege is successful, or 1 if the building is either - * not besieged or the unit can slip through the siege due to better stealth. - */ -static int slipthru(const region * r, const unit * u, const building * b) -{ - unit *u2; - int n, o; - - /* b ist die burg, in die man hinein oder aus der man heraus will. */ - if (b == NULL || b->besieged < b->size * SIEGEFACTOR) { - return 1; - } - - /* u wird am hinein- oder herausschluepfen gehindert, wenn STEALTH <= - * OBSERVATION +2 der belagerer u2 ist */ - n = eff_skill(u, SK_STEALTH, r); - - for (u2 = r->units; u2; u2 = u2->next) { - if (usiege(u2) == b) { - - if (invisible(u, u2) >= u->number) - continue; - - o = eff_skill(u2, SK_PERCEPTION, r); - - if (o + 2 >= n) { - return 0; /* entdeckt! */ - } - } - } - return 1; -} - -int can_contact(const region * r, const unit * u, const unit * u2) -{ - - /* hier geht es nur um die belagerung von burgen */ - - if (u->building == u2->building) { - return 1; - } - - /* unit u is trying to contact u2 - unasked for contact. wenn u oder u2 - * nicht in einer burg ist, oder die burg nicht belagert ist, ist - * slipthru () == 1. ansonsten ist es nur 1, wenn man die belagerer */ - - if (slipthru(u->region, u, u->building) && slipthru(u->region, u2, u2->building)) { - return 1; - } - - return (alliedunit(u, u2->faction, HELP_GIVE)); -} - -static void contact_cmd(unit * u, order * ord, int final) -{ - /* unit u kontaktiert unit u2. Dies setzt den contact einfach auf 1 - - * ein richtiger toggle ist (noch?) nicht noetig. die region als - * parameter ist nur deswegen wichtig, weil er an getunit () - * weitergegeben wird. dies wird fuer das auffinden von tempunits in - * getnewunit () verwendet! */ - unit *u2; - region *r = u->region; - - init_tokens(ord); - skip_token(); - u2 = getunitg(r, u->faction); - - if (u2 != NULL) { - if (!can_contact(r, u, u2)) { - if (final) - cmistake(u, u->thisorder, 23, MSG_EVENT); - return; - } - usetcontact(u, u2); - } -} - -/* ------------------------------------------------------------- */ - -/* ------------------------------------------------------------- */ - -/* ------------------------------------------------------------- */ - struct building *getbuilding(const struct region *r) { building *b = findbuilding(getid()); @@ -182,102 +89,6 @@ ship *getship(const struct region * r) /* ------------------------------------------------------------- */ -static void siege_cmd(unit * u, order * ord) -{ - region *r = u->region; - building *b; - int d, pooled; - int bewaffnete, katapultiere = 0; - static boolean init = false; - static const curse_type *magicwalls_ct; - static item_type *it_catapultammo = NULL; - static item_type *it_catapult = NULL; - if (!init) { - init = true; - magicwalls_ct = ct_find("magicwalls"); - it_catapultammo = it_find("catapultammo"); - it_catapult = it_find("catapult"); - } - /* gibt es ueberhaupt Burgen? */ - - init_tokens(ord); - skip_token(); - b = getbuilding(r); - - if (!b) { - cmistake(u, ord, 31, MSG_BATTLE); - return; - } - - if (!playerrace(u->race)) { - /* keine Drachen, Illusionen, Untote etc */ - cmistake(u, ord, 166, MSG_BATTLE); - return; - } - /* schaden durch katapulte */ - - d = i_get(u->items, it_catapult); - d = MIN(u->number, d); - pooled = get_pooled(u, it_catapultammo->rtype, GET_DEFAULT, d); - d = MIN(pooled, d); - if (eff_skill(u, SK_CATAPULT, r) >= 1) { - katapultiere = d; - d *= eff_skill(u, SK_CATAPULT, r); - } else { - d = 0; - } - - bewaffnete = armedmen(u, true); - if (d == 0 && bewaffnete == 0) { - /* abbruch, falls unbewaffnet oder unfaehig, katapulte zu benutzen */ - cmistake(u, ord, 80, MSG_EVENT); - return; - } - - if (!is_guard(u, GUARD_TRAVELTHRU)) { - /* abbruch, wenn die einheit nicht vorher die region bewacht - als - * warnung fuer alle anderen! */ - cmistake(u, ord, 81, MSG_EVENT); - return; - } - /* einheit und burg markieren - spart zeit beim behandeln der einheiten - * in der burg, falls die burg auch markiert ist und nicht alle - * einheiten wieder abgesucht werden muessen! */ - - usetsiege(u, b); - b->besieged += MAX(bewaffnete, katapultiere); - - /* definitiver schaden eingeschraenkt */ - - d = MIN(d, b->size - 1); - - /* meldung, schaden anrichten */ - if (d && !curse_active(get_curse(b->attribs, magicwalls_ct))) { - b->size -= d; - use_pooled(u, it_catapultammo->rtype, - GET_SLACK | GET_RESERVE | GET_POOLED_SLACK, d); - /* send message to the entire region */ - ADDMSG(&r->msgs, msg_message("siege_catapults", - "unit building destruction", u, b, d)); - } else { - /* send message to the entire region */ - ADDMSG(&r->msgs, msg_message("siege", "unit building", u, b)); - } -} - -void do_siege(region * r) -{ - if (fval(r->terrain, LAND_REGION)) { - unit *u; - - for (u = r->units; u; u = u->next) { - if (get_keyword(u->thisorder) == K_BESIEGE) { - siege_cmd(u, u->thisorder); - } - } - } -} - /* ------------------------------------------------------------- */ static void destroy_road(unit * u, int nmax, struct order *ord) @@ -1152,246 +963,3 @@ void continue_ship(region * r, unit * u, int want) build_ship(u, sh, want); } -/* ------------------------------------------------------------- */ - -static boolean mayenter(region * r, unit * u, building * b) -{ - unit *u2; - if (fval(b, BLD_UNGUARDED)) - return true; - u2 = building_owner(b); - - if (u2 == NULL || ucontact(u2, u) - || alliedunit(u2, u->faction, HELP_GUARD)) - return true; - - return false; -} - -static int mayboard(const unit * u, ship * sh) -{ - unit *u2 = ship_owner(sh); - - return (!u2 || ucontact(u2, u) || alliedunit(u2, u->faction, HELP_GUARD)); -} - -int leave_cmd(unit * u, struct order *ord) -{ - region *r = u->region; - - if (fval(u, UFL_ENTER)) { - /* if we just entered this round, then we don't leave again */ - return 0; - } - - if (fval(r->terrain, SEA_REGION) && u->ship) { - if (!fval(u->race, RCF_SWIM)) { - cmistake(u, ord, 11, MSG_MOVE); - return 0; - } - if (has_horses(u)) { - cmistake(u, ord, 231, MSG_MOVE); - return 0; - } - } - if (!slipthru(r, u, u->building)) { - ADDMSG(&u->faction->msgs, msg_feedback(u, u->thisorder, "entrance_besieged", - "building", u->building)); - } else { - leave(u, true); - } - return 0; -} - -static boolean enter_ship(unit * u, struct order *ord, int id, boolean report) -{ - region *r = u->region; - ship *sh; - - /* Mu� abgefangen werden, sonst k�nnten Schwimmer an - * Bord von Schiffen an Land gelangen. */ - if (!fval(u->race, RCF_CANSAIL) || (!fval(u->race, RCF_WALK) - && !fval(u->race, RCF_FLY))) { - cmistake(u, ord, 233, MSG_MOVE); - return false; - } - - sh = findship(id); - if (sh == NULL || sh->region != r) { - if (report) - cmistake(u, ord, 20, MSG_MOVE); - return false; - } - if (sh == u->ship) - return true; - if (!mayboard(u, sh)) { - if (report) - cmistake(u, ord, 34, MSG_MOVE); - return false; - } - if (CheckOverload()) { - int sweight, scabins; - int mweight = shipcapacity(sh); - int mcabins = sh->type->cabins; - - if (mweight > 0) { - getshipweight(sh, &sweight, &scabins); - sweight += weight(u); - if (mcabins) { - int pweight = u->number * u->race->weight; - /* weight goes into number of cabins, not cargo */ - scabins += pweight; - sweight -= pweight; - } - - if (sweight > mweight || (mcabins && (scabins > mcabins))) { - if (report) - cmistake(u, ord, 34, MSG_MOVE); - return false; - } - } - } - - if (leave(u, false)) { - u_set_ship(u, sh); - fset(u, UFL_ENTER); - } - return true; -} - -static boolean enter_building(unit * u, order * ord, int id, boolean report) -{ - region *r = u->region; - building *b; - - /* Schwimmer k�nnen keine Geb�ude betreten, au�er diese sind - * auf dem Ozean */ - if (!fval(u->race, RCF_WALK) && !fval(u->race, RCF_FLY)) { - if (!fval(r->terrain, SEA_REGION)) { - if (report) { - cmistake(u, ord, 232, MSG_MOVE); - } - return false; - } - } - - b = findbuilding(id); - if (b == NULL || b->region != r) { - if (report) { - cmistake(u, ord, 6, MSG_MOVE); - } - return false; - } - if (!mayenter(r, u, b)) { - if (report) { - ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "entrance_denied", - "building", b)); - } - return false; - } - if (!slipthru(r, u, b)) { - if (report) { - ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "entrance_besieged", - "building", b)); - } - return false; - } - - if (leave(u, false)) { - fset(u, UFL_ENTER); - u_set_building(u, b); - return true; - } - return false; -} - -void do_misc(region * r, int is_final_attempt) -{ - unit **uptr, *uc; - - for (uc = r->units; uc; uc = uc->next) { - order *ord; - for (ord = uc->orders; ord; ord = ord->next) { - keyword_t kwd = get_keyword(ord); - if (kwd == K_CONTACT) { - contact_cmd(uc, ord, is_final_attempt); - } - } - } - - for (uptr = &r->units; *uptr;) { - unit *u = *uptr; - order **ordp = &u->orders; - - while (*ordp) { - order *ord = *ordp; - if (get_keyword(ord) == K_ENTER) { - param_t p; - int id; - unit *ulast = NULL; - const char * s; - - init_tokens(ord); - skip_token(); - s = getstrtoken(); - p = findparam_ex(s, u->faction->locale); - id = getid(); - - switch (p) { - case P_BUILDING: - case P_GEBAEUDE: - if (u->building && u->building->no == id) - break; - if (enter_building(u, ord, id, is_final_attempt)) { - unit *ub; - for (ub = u; ub; ub = ub->next) { - if (ub->building == u->building) { - ulast = ub; - } - } - } - break; - - case P_SHIP: - if (u->ship && u->ship->no == id) - break; - if (enter_ship(u, ord, id, is_final_attempt)) { - unit *ub; - ulast = u; - for (ub = u; ub; ub = ub->next) { - if (ub->ship == u->ship) { - ulast = ub; - } - } - } - break; - - default: - if (is_final_attempt) { - cmistake(u, ord, 79, MSG_MOVE); - } - } - if (ulast != NULL) { - /* Wenn wir hier angekommen sind, war der Befehl - * erfolgreich und wir l�schen ihn, damit er im - * zweiten Versuch nicht nochmal ausgef�hrt wird. */ - *ordp = ord->next; - ord->next = NULL; - free_order(ord); - - if (ulast != u) { - /* put u behind ulast so it's the last unit in the building */ - *uptr = u->next; - u->next = ulast->next; - ulast->next = u; - } - break; - } - } - if (*ordp == ord) - ordp = &ord->next; - } - if (*uptr == u) - uptr = &u->next; - } -} diff --git a/src/kernel/build.h b/src/kernel/build.h index 5407034bf..1e7b7d623 100644 --- a/src/kernel/build.h +++ b/src/kernel/build.h @@ -64,10 +64,6 @@ extern "C" { extern int destroy_cmd(struct unit *u, struct order *ord); extern int leave_cmd(struct unit *u, struct order *ord); - extern int can_contact(const struct region *r, const struct unit *u, - const struct unit *u2); - - void do_siege(struct region *r); void build_road(struct region *r, struct unit *u, int size, direction_t d); void create_ship(struct region *r, struct unit *u, const struct ship_type *newtype, int size, struct order *ord); @@ -76,8 +72,6 @@ extern "C" { struct building *getbuilding(const struct region *r); struct ship *getship(const struct region *r); - void do_misc(struct region *r, int is_final_attempt); - void reportevent(struct region *r, char *s); void shash(struct ship *sh); diff --git a/src/kernel/building.c b/src/kernel/building.c index 0b695622d..4ba7cad10 100644 --- a/src/kernel/building.c +++ b/src/kernel/building.c @@ -180,7 +180,7 @@ const char *buildingtype(const building_type * btype, const building * b, int bsize) { const char *s = NULL; - static boolean init_generic = false; + static bool init_generic = false; static const struct building_type *bt_generic; if (!init_generic) { @@ -451,7 +451,7 @@ building *new_building(const struct building_type * btype, region * r, { building **bptr = &r->buildings; building *b = (building *) calloc(1, sizeof(building)); - static boolean init_lighthouse = false; + static bool init_lighthouse = false; static const struct building_type *bt_lighthouse = 0; const char *bname = 0; char buffer[32]; @@ -501,7 +501,7 @@ void remove_building(building ** blist, building * b) { unit *u; static const struct building_type *bt_caravan, *bt_dam, *bt_tunnel; - static boolean init = false; + static bool init = false; if (!init) { init = true; diff --git a/src/kernel/config.c b/src/kernel/config.c index 23b568579..caf72d6cb 100644 --- a/src/kernel/config.c +++ b/src/kernel/config.c @@ -25,6 +25,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. /* kernel includes */ #include "alliance.h" +#include "ally.h" #include "alchemy.h" #include "battle.h" #include "connection.h" @@ -95,22 +96,10 @@ struct settings global = { FILE *logfile; FILE *updatelog; const struct race *new_race[MAXRACES]; -boolean sqlpatch = false; -boolean battledebug = false; +bool sqlpatch = false; +bool battledebug = false; int turn = 0; -#if XECMD_MODULE -attrib_type at_xontormiaexpress = { - "xontormiaexpress", - DEFAULT_INIT, - DEFAULT_FINALIZE, - DEFAULT_AGE, - a_writeint, - a_readint, - ATF_UNIQUE -}; -#endif - int NewbieImmunity(void) { static int value = -1; @@ -122,7 +111,7 @@ int NewbieImmunity(void) return value; } -boolean IsImmune(const faction * f) +bool IsImmune(const faction * f) { return !fval(f, FFL_NPC) && f->age < NewbieImmunity(); } @@ -155,7 +144,7 @@ static int ally_flag(const char *s, int help_mask) return 0; } -boolean ExpensiveMigrants(void) +bool ExpensiveMigrants(void) { static int value = -1; static int gamecookie = -1; @@ -411,8 +400,6 @@ const char *keywords[MAXKEYWORDS] = { "ENDE", "FAHREN", "NUMMER", - "KRIEG", - "FRIEDEN", "FOLGEN", "FORSCHEN", "GIB", @@ -423,7 +410,6 @@ const char *keywords[MAXKEYWORDS] = { "KONTAKTIEREN", "LEHREN", "LERNEN", - "LIEFERE", "MACHEN", "NACH", "PASSWORT", @@ -449,18 +435,12 @@ const char *keywords[MAXKEYWORDS] = { "URSPRUNG", "EMAIL", "PIRATERIE", - "NEUSTART", "GRUPPE", - "OPFERE", - "BETEN", "SORTIEREN", - "JIHAD", "GM", "INFO", "PRAEFIX", "PFLANZEN", - "WERWESEN", - "XONTORMIA", "ALLIANZ", "BEANSPRUCHEN", "PROMOTION", @@ -637,7 +617,7 @@ int shipspeed(const ship * sh, const unit * u) { double k = sh->type->range; static const curse_type *stormwind_ct, *nodrift_ct; - static boolean init; + static bool init; attrib *a; curse *c; @@ -849,7 +829,7 @@ int eff_stealth(const unit * u, const region * r) return e; } -boolean unit_has_cursed_item(unit * u) +bool unit_has_cursed_item(unit * u) { item *itm = u->items; while (itm) { @@ -875,7 +855,7 @@ static void init_gms(void) static int autoalliance(const plane * pl, const faction * sf, const faction * f2) { - static boolean init = false; + static bool init = false; if (!init) { init_gms(); init = true; @@ -979,7 +959,7 @@ int alliedunit(const unit * u, const faction * f2, int mode) return 0; } -boolean +bool seefaction(const faction * f, const region * r, const unit * u, int modifier) { if (((f == u->faction) || !fval(u, UFL_ANON_FACTION)) @@ -988,7 +968,7 @@ seefaction(const faction * f, const region * r, const unit * u, int modifier) return false; } -boolean +bool cansee(const faction * f, const region * r, const unit * u, int modifier) /* r kann != u->region sein, wenn es um durchreisen geht */ /* und es muss niemand aus f in der region sein, wenn sie vom Turm @@ -997,7 +977,7 @@ cansee(const faction * f, const region * r, const unit * u, int modifier) int stealth, rings; unit *u2 = r->units; static const item_type *itype_grail; - static boolean init; + static bool init; if (!init) { init = true; @@ -1057,7 +1037,7 @@ cansee(const faction * f, const region * r, const unit * u, int modifier) return false; } -boolean cansee_unit(const unit * u, const unit * target, int modifier) +bool cansee_unit(const unit * u, const unit * target, int modifier) /* target->region kann != u->region sein, wenn es um durchreisen geht */ { if (fval(target->race, RCF_INVISIBLE) || target->number == 0) @@ -1093,7 +1073,7 @@ boolean cansee_unit(const unit * u, const unit * target, int modifier) return false; } -boolean +bool cansee_durchgezogen(const faction * f, const region * r, const unit * u, int modifier) /* r kann != u->region sein, wenn es um durchreisen geht */ @@ -1164,7 +1144,7 @@ static attrib_type at_lighthouse = { */ void update_lighthouse(building * lh) { - static boolean init_lighthouse = false; + static bool init_lighthouse = false; static const struct building_type *bt_lighthouse = 0; if (!init_lighthouse) { @@ -1269,14 +1249,8 @@ int count_maxmigrants(const faction * f) return migrants; } -void init_tokens(const struct order *ord) -{ - char *cmd = getcommand(ord); - init_tokens_str(cmd, cmd); -} - void -parse(keyword_t kword, int (*dofun) (unit *, struct order *), boolean thisorder) +parse(keyword_t kword, int (*dofun) (unit *, struct order *), bool thisorder) { region *r; @@ -1423,13 +1397,13 @@ param_t findparam_ex(const char *s, const struct locale * lang) return (result == P_BUILDING) ? P_GEBAEUDE : result; } -int isparam(const char *s, const struct locale * lang, param_t param) +bool isparam(const char *s, const struct locale * lang, param_t param) { if (s[0]>'@') { param_t p = (param==P_GEBAEUDE) ? findparam_ex(s, lang) : findparam(s, lang); return p==param; } - return 0; + return false; } param_t getparam(const struct locale * lang) @@ -1522,7 +1496,7 @@ int read_unitid(const faction * f, const region * r) } /* exported symbol */ -boolean getunitpeasants; +bool getunitpeasants; unit *getunitg(const region * r, const faction * f) { int n = read_unitid(f, r); @@ -1585,7 +1559,7 @@ void freestrlist(strlist * s) /* - Meldungen und Fehler ------------------------------------------------- */ -boolean lomem = false; +bool lomem = false; /* - Namen der Strukturen -------------------------------------- */ typedef char name[OBJECTIDSIZE + 1]; @@ -1635,7 +1609,7 @@ char *cstring(const char *s) } building *largestbuilding(const region * r, cmp_building_cb cmp_gt, - boolean imaginary) + bool imaginary) { building *b, *best = NULL; @@ -1740,9 +1714,9 @@ unit *createunit(region * r, faction * f, int number, const struct race * rc) return create_unit(r, f, number, rc, 0, NULL, NULL); } -boolean idle(faction * f) +bool idle(faction * f) { - return (boolean) (f ? false : true); + return (bool) (f ? false : true); } int maxworkingpeasants(const struct region *r) @@ -1785,7 +1759,7 @@ int lighthouse_range(const building * b, const faction * f) return d; } -boolean check_leuchtturm(region * r, faction * f) +bool check_leuchtturm(region * r, faction * f) { attrib *a; @@ -1973,6 +1947,11 @@ direction_t finddirection(const char *s, const struct locale *lang) return NODIRECTION; } +direction_t getdirection(const struct locale * lang) +{ + return finddirection(getstrtoken(), lang); +} + static void init_translations(const struct locale *lang, int ut, const char * (*string_cb)(int i), int maxstrings) { char buffer[256]; @@ -2384,7 +2363,7 @@ void remove_empty_units(void) } } -boolean faction_id_is_unused(int id) +bool faction_id_is_unused(int id) { return findfaction(id) == NULL; } @@ -2481,7 +2460,7 @@ int lifestyle(const unit * u) return need; } -boolean has_horses(const struct unit * u) +bool has_horses(const struct unit * u) { item *itm = u->items; for (; itm; itm = itm->next) { @@ -2491,7 +2470,7 @@ boolean has_horses(const struct unit * u) return false; } -boolean hunger(int number, unit * u) +bool hunger(int number, unit * u) { region *r = u->region; int dead = 0, hpsub = 0; @@ -2540,7 +2519,7 @@ boolean hunger(int number, unit * u) return (dead || hpsub); } -void plagues(region * r, boolean ismagic) +void plagues(region * r, bool ismagic) { int peasants; int i; @@ -2604,7 +2583,7 @@ int cmp_wage(const struct building *b, const building * a) return -1; } -boolean is_owner_building(const struct building * b) +bool is_owner_building(const struct building * b) { region *r = b->region; if (b->type->taxes && r->land && r->land->ownership) { @@ -2774,7 +2753,7 @@ default_wage(const region * r, const faction * f, const race * rc, int in_turn) attrib *a; const building_type *artsculpture_type = bt_find("artsculpture"); static const curse_type *drought_ct, *blessedharvest_ct; - static boolean init; + static bool init; if (!init) { init = true; @@ -2915,7 +2894,7 @@ int movewhere(const unit * u, const char *token, region * r, region ** resultp) return E_MOVE_OK; } -boolean move_blocked(const unit * u, const region * r, const region * r2) +bool move_blocked(const unit * u, const region * r, const region * r2) { connection *b; curse *c; @@ -2964,7 +2943,7 @@ int lovar(double xpct_x2) return (rng_int() % n + rng_int() % n) / 1000; } -boolean has_limited_skills(const struct unit * u) +bool has_limited_skills(const struct unit * u) { if (has_skill(u, SK_MAGIC) || has_skill(u, SK_ALCHEMY) || has_skill(u, SK_TACTICS) || has_skill(u, SK_HERBALISM) || @@ -3022,9 +3001,8 @@ void attrib_init(void) register_function((pf_generic) & minimum_wage, "minimum_wage"); at_register(&at_germs); -#if XECMD_MODULE - at_register(&at_xontormiaexpress); /* required for old datafiles */ -#endif + + at_deprecate("xontormiaexpress", a_readint); /* required for old datafiles */ at_register(&at_speedup); at_register(&at_building_action); } diff --git a/src/kernel/config.h b/src/kernel/config.h index 510678c27..23542caf5 100644 --- a/src/kernel/config.h +++ b/src/kernel/config.h @@ -111,13 +111,7 @@ extern "C" { extern int shipspeed(const struct ship *sh, const struct unit *u); -#define i2b(i) ((boolean)((i)?(true):(false))) - - typedef struct ally { - struct ally *next; - struct faction *faction; - int status; - } ally; +#define i2b(i) ((bool)((i)?(true):(false))) void remove_empty_units_in_region(struct region *r); void remove_empty_units(void); @@ -136,10 +130,10 @@ extern "C" { extern int verbosity; /* parteinummern */ - extern boolean faction_id_is_unused(int); + extern bool faction_id_is_unused(int); /* leuchtturm */ - extern boolean check_leuchtturm(struct region *r, struct faction *f); + extern bool check_leuchtturm(struct region *r, struct faction *f); extern void update_lighthouse(struct building *lh); extern int lighthouse_range(const struct building *b, const struct faction *f); @@ -159,22 +153,23 @@ extern "C" { void addstrlist(strlist ** SP, const char *s); - int armedmen(const struct unit *u, boolean siege_weapons); + int armedmen(const struct unit *u, bool siege_weapons); unsigned int atoip(const char *s); unsigned int getuint(void); int getint(void); + direction_t getdirection(const struct locale *); + extern const char *igetstrtoken(const char *s); - extern void init_tokens(const struct order *ord); /* initialize token parsing */ extern skill_t findskill(const char *s, const struct locale *lang); extern keyword_t findkeyword(const char *s, const struct locale *lang); param_t findparam(const char *s, const struct locale *lang); param_t findparam_ex(const char *s, const struct locale * lang); - int isparam(const char *s, const struct locale * lang, param_t param); + bool isparam(const char *s, const struct locale * lang, param_t param); param_t getparam(const struct locale *lang); extern int getid(void); @@ -188,13 +183,13 @@ extern "C" { #define factionid(x) itoa36((x)->no) #define curseid(x) itoa36((x)->no) - extern boolean cansee(const struct faction *f, const struct region *r, + extern bool cansee(const struct faction *f, const struct region *r, const struct unit *u, int modifier); - boolean cansee_durchgezogen(const struct faction *f, const struct region *r, + bool cansee_durchgezogen(const struct faction *f, const struct region *r, const struct unit *u, int modifier); - extern boolean cansee_unit(const struct unit *u, const struct unit *target, + extern bool cansee_unit(const struct unit *u, const struct unit *target, int modifier); - boolean seefaction(const struct faction *f, const struct region *r, + bool seefaction(const struct faction *f, const struct region *r, const struct unit *u, int modifier); extern int effskill(const struct unit *u, skill_t sk); @@ -210,7 +205,7 @@ extern "C" { extern struct unit *createunit(struct region *r, struct faction *f, int number, const struct race *rc); extern void create_unitid(struct unit *u, int id); - extern boolean getunitpeasants; + extern bool getunitpeasants; extern struct unit *getunitg(const struct region *r, const struct faction *f); extern struct unit *getunit(const struct region *r, const struct faction *f); @@ -242,7 +237,7 @@ extern "C" { typedef int (*cmp_building_cb) (const struct building * b, const struct building * a); struct building *largestbuilding(const struct region *r, cmp_building_cb, - boolean imaginary); + bool imaginary); int cmp_wage(const struct building *b, const struct building *bother); int cmp_taxes(const struct building *b, const struct building *bother); int cmp_current_owner(const struct building *b, @@ -265,7 +260,7 @@ extern "C" { extern int count_migrants(const struct faction *f); extern int count_maxmigrants(const struct faction *f); - extern boolean has_limited_skills(const struct unit *u); + extern bool has_limited_skills(const struct unit *u); extern const struct race *findrace(const char *, const struct locale *); int eff_stealth(const struct unit *u, const struct region *r); @@ -273,7 +268,7 @@ extern "C" { int check_option(struct faction *f, int option); extern void parse(keyword_t kword, int (*dofun) (struct unit *, - struct order *), boolean thisorder); + struct order *), bool thisorder); /* Anzahl Personen in einer Einheit festlegen. NUR (!) mit dieser Routine, * sonst gro�es Ungl�ck. Durch asserts an ein paar Stellen abgesichert. */ @@ -293,8 +288,8 @@ extern "C" { void fhash(struct faction *f); void funhash(struct faction *f); - boolean idle(struct faction *f); - boolean unit_has_cursed_item(struct unit *u); + bool idle(struct faction *f); + bool unit_has_cursed_item(struct unit *u); /* simple garbage collection: */ void *gc_add(void *p); @@ -344,18 +339,18 @@ extern "C" { */ unsigned int guard_flags(const struct unit *u); - extern boolean hunger(int number, struct unit *u); + extern bool hunger(int number, struct unit *u); extern int lifestyle(const struct unit *); extern int besieged(const struct unit *u); extern int maxworkingpeasants(const struct region *r); - extern boolean has_horses(const struct unit *u); + extern bool has_horses(const struct unit *u); extern int markets_module(void); extern int wage(const struct region *r, const struct faction *f, const struct race *rc, int in_turn); extern int maintenance_cost(const struct unit *u); extern struct message *movement_error(struct unit *u, const char *token, struct order *ord, int error_code); - extern boolean move_blocked(const struct unit *u, const struct region *src, + extern bool move_blocked(const struct unit *u, const struct region *src, const struct region *dest); extern void add_income(struct unit *u, int type, int want, int qty); @@ -392,7 +387,7 @@ extern "C" { const char *gamename; struct attrib *attribs; unsigned int data_turn; - boolean disabled[MAXKEYWORDS]; + bool disabled[MAXKEYWORDS]; struct param *parameters; void *vm_state; float producexpchance; @@ -409,9 +404,9 @@ extern "C" { extern int produceexp(struct unit *u, skill_t sk, int n); - extern boolean battledebug; - extern boolean sqlpatch; - extern boolean lomem; /* save memory */ + extern bool battledebug; + extern bool sqlpatch; + extern bool lomem; /* save memory */ extern const char *dbrace(const struct race *rc); @@ -421,19 +416,19 @@ extern "C" { extern float get_param_flt(const struct param *p, const char *name, float def); - extern boolean ExpensiveMigrants(void); + extern bool ExpensiveMigrants(void); extern int NMRTimeout(void); extern int LongHunger(const struct unit *u); extern int SkillCap(skill_t sk); extern int NewbieImmunity(void); - extern boolean IsImmune(const struct faction *f); + extern bool IsImmune(const struct faction *f); extern int AllianceAuto(void); /* flags that allied factions get automatically */ extern int AllianceRestricted(void); /* flags restricted to allied factions */ extern int HelpMask(void); /* flags restricted to allied factions */ extern struct order *default_order(const struct locale *lang); extern int entertainmoney(const struct region *r); - extern void plagues(struct region *r, boolean ismagic); + extern void plagues(struct region *r, bool ismagic); typedef struct helpmode { const char *name; int status; @@ -458,10 +453,6 @@ extern "C" { # define count_unit(u) 1 #endif -#if XECMD_MODULE - extern struct attrib_type at_xontormiaexpress; -#endif - #ifdef __cplusplus } #endif diff --git a/src/kernel/connection.c b/src/kernel/connection.c index 5d4d24d19..7bbb2e75a 100644 --- a/src/kernel/connection.c +++ b/src/kernel/connection.c @@ -224,21 +224,21 @@ void b_write(const connection * b, storage * store) } } -boolean b_transparent(const connection * b, const struct faction *f) +bool b_transparent(const connection * b, const struct faction *f) { unused(b); unused(f); return true; } -boolean b_opaque(const connection * b, const struct faction * f) +bool b_opaque(const connection * b, const struct faction * f) { unused(b); unused(f); return false; } -boolean b_blockall(const connection * b, const unit * u, const region * r) +bool b_blockall(const connection * b, const unit * u, const region * r) { unused(u); unused(r); @@ -246,7 +246,7 @@ boolean b_blockall(const connection * b, const unit * u, const region * r) return true; } -boolean b_blocknone(const connection * b, const unit * u, const region * r) +bool b_blocknone(const connection * b, const unit * u, const region * r) { unused(u); unused(r); @@ -254,12 +254,12 @@ boolean b_blocknone(const connection * b, const unit * u, const region * r) return false; } -boolean b_rvisible(const connection * b, const region * r) +bool b_rvisible(const connection * b, const region * r) { - return (boolean) (b->to == r || b->from == r); + return (bool) (b->to == r || b->from == r); } -boolean b_fvisible(const connection * b, const struct faction * f, +bool b_fvisible(const connection * b, const struct faction * f, const region * r) { unused(r); @@ -268,21 +268,21 @@ boolean b_fvisible(const connection * b, const struct faction * f, return true; } -boolean b_uvisible(const connection * b, const unit * u) +bool b_uvisible(const connection * b, const unit * u) { unused(u); unused(b); return true; } -boolean b_rinvisible(const connection * b, const region * r) +bool b_rinvisible(const connection * b, const region * r) { unused(r); unused(b); return false; } -boolean b_finvisible(const connection * b, const struct faction * f, +bool b_finvisible(const connection * b, const struct faction * f, const region * r) { unused(r); @@ -291,7 +291,7 @@ boolean b_finvisible(const connection * b, const struct faction * f, return false; } -boolean b_uinvisible(const connection * b, const unit * u) +bool b_uinvisible(const connection * b, const unit * u) { unused(u); unused(b); @@ -399,14 +399,14 @@ static const char *b_namefogwall(const connection * b, const region * r, return LOC(f->locale, mkname("border", "fogwall")); } -static boolean +static bool b_blockfogwall(const connection * b, const unit * u, const region * r) { unused(b); unused(r); if (!u) return true; - return (boolean) (effskill(u, SK_PERCEPTION) > 4); /* Das ist die alte Nebelwand */ + return (bool) (effskill(u, SK_PERCEPTION) > 4); /* Das ist die alte Nebelwand */ } /** Legacy type used in old Eressea games, no longer in use. */ @@ -458,7 +458,7 @@ border_type bt_illusionwall = { * special quest door ***/ -boolean b_blockquestportal(const connection * b, const unit * u, +bool b_blockquestportal(const connection * b, const unit * u, const region * r) { if (b->data.i > 0) @@ -558,14 +558,14 @@ static void b_writeroad(const connection * b, storage * store) store->w_int(store, b->data.sa[1]); } -static boolean b_validroad(const connection * b) +static bool b_validroad(const connection * b) { if (b->data.sa[0] == SHRT_MAX) return false; return true; } -static boolean b_rvisibleroad(const connection * b, const region * r) +static bool b_rvisibleroad(const connection * b, const region * r) { int x = b->data.i; x = (r == b->from) ? b->data.sa[0] : b->data.sa[1]; diff --git a/src/kernel/connection.h b/src/kernel/connection.h index 62e09771e..b582377c5 100644 --- a/src/kernel/connection.h +++ b/src/kernel/connection.h @@ -39,7 +39,7 @@ extern "C" { typedef struct border_type { const char *__name; /* internal use only */ variant_type datatype; - boolean(*transparent) (const connection *, const struct faction *); + bool(*transparent) (const connection *, const struct faction *); /* is it possible to see through this? */ void (*init) (connection *); /* constructor: initialize the connection. allocate extra memory if needed */ @@ -47,7 +47,7 @@ extern "C" { /* destructor: remove all extra memory for destruction */ void (*read) (connection *, struct storage *); void (*write) (const connection *, struct storage *); - boolean(*block) (const connection *, const struct unit *, + bool(*block) (const connection *, const struct unit *, const struct region * r); /* return true if it blocks movement of u from * r to the opposite struct region. @@ -59,11 +59,11 @@ extern "C" { * may depend on the struct faction, for example "a wall" may * turn out to be "an illusionary wall" */ - boolean(*rvisible) (const connection *, const struct region *); + bool(*rvisible) (const connection *, const struct region *); /* is it visible to everyone in r ? * if not, it may still be fvisible() for some f. */ - boolean(*fvisible) (const connection *, const struct faction *, + bool(*fvisible) (const connection *, const struct faction *, const struct region *); /* is it visible to units of f in r? * the function shall not check for @@ -73,16 +73,16 @@ extern "C" { * the reporting function will have to assure). * if not true, it may still be uvisible() for some u. */ - boolean(*uvisible) (const connection *, const struct unit *); + bool(*uvisible) (const connection *, const struct unit *); /* is it visible to u ? * a doorway may only be visible to a struct unit with perception > 5 */ - boolean(*valid) (const connection *); + bool(*valid) (const connection *); /* is the connection in a valid state, * or should it be erased at the end of this turn to save space? */ struct region *(*move) (const connection *, struct unit * u, - struct region * from, struct region * to, boolean routing); + struct region * from, struct region * to, bool routing); /* executed when the units traverses this connection */ int (*age) (struct connection *); /* return 0 if connection needs to be removed. >0 if still aging, <0 if not aging */ @@ -112,20 +112,20 @@ extern "C" { /* provide default implementations for some member functions: */ extern void b_read(connection * b, struct storage *store); extern void b_write(const connection * b, struct storage *store); - extern boolean b_blockall(const connection *, const struct unit *, + extern bool b_blockall(const connection *, const struct unit *, const struct region *); - extern boolean b_blocknone(const connection *, const struct unit *, + extern bool b_blocknone(const connection *, const struct unit *, const struct region *); - extern boolean b_rvisible(const connection *, const struct region *r); - extern boolean b_fvisible(const connection *, const struct faction *f, + extern bool b_rvisible(const connection *, const struct region *r); + extern bool b_fvisible(const connection *, const struct faction *f, const struct region *); - extern boolean b_uvisible(const connection *, const struct unit *u); - extern boolean b_rinvisible(const connection *, const struct region *r); - extern boolean b_finvisible(const connection *, const struct faction *f, + extern bool b_uvisible(const connection *, const struct unit *u); + extern bool b_rinvisible(const connection *, const struct region *r); + extern bool b_finvisible(const connection *, const struct faction *f, const struct region *); - extern boolean b_uinvisible(const connection *, const struct unit *u); - extern boolean b_transparent(const connection *, const struct faction *); - extern boolean b_opaque(const connection *, const struct faction *); /* !transparent */ + extern bool b_uinvisible(const connection *, const struct unit *u); + extern bool b_transparent(const connection *, const struct faction *); + extern bool b_opaque(const connection *, const struct faction *); /* !transparent */ extern border_type bt_fogwall; extern border_type bt_noway; diff --git a/src/kernel/curse.c b/src/kernel/curse.c index 3b0d7c3e2..a903d8bed 100644 --- a/src/kernel/curse.c +++ b/src/kernel/curse.c @@ -322,7 +322,7 @@ const curse_type *ct_find(const char *c) * einen pointer auf die struct zur�ck. */ -boolean cmp_curse(const attrib * a, const void *data) +bool cmp_curse(const attrib * a, const void *data) { const curse *c = (const curse *)data; if (a->type->flags & ATF_CURSE) { @@ -332,7 +332,7 @@ boolean cmp_curse(const attrib * a, const void *data) return false; } -boolean cmp_cursetype(const attrib * a, const void *data) +bool cmp_cursetype(const attrib * a, const void *data) { const curse_type *ct = (const curse_type *)data; if (a->type->flags & ATF_CURSE) { @@ -343,7 +343,7 @@ boolean cmp_cursetype(const attrib * a, const void *data) } curse *get_cursex(attrib * ap, const curse_type * ctype, variant data, - boolean(*compare) (const curse *, variant)) + bool(*compare) (const curse *, variant)) { attrib *a = a_select(ap, ctype, cmp_cursetype); while (a) { @@ -585,7 +585,7 @@ static void do_transfer_curse(curse * c, unit * u, unit * u2, int n) { int cursedmen = 0; int men = get_cursedmen(u, c); - boolean dogive = false; + bool dogive = false; const curse_type *ct = c->type; switch ((ct->flags | c->flags) & CURSE_SPREADMASK) { @@ -642,7 +642,7 @@ void transfer_curse(unit * u, unit * u2, int n) /* ------------------------------------------------------------- */ -boolean curse_active(const curse * c) +bool curse_active(const curse * c) { if (!c) return false; @@ -654,7 +654,7 @@ boolean curse_active(const curse * c) return true; } -boolean is_cursed_internal(attrib * ap, const curse_type * ct) +bool is_cursed_internal(attrib * ap, const curse_type * ct) { curse *c = get_curse(ap, ct); @@ -664,7 +664,7 @@ boolean is_cursed_internal(attrib * ap, const curse_type * ct) return true; } -boolean is_cursed_with(const attrib * ap, const curse * c) +bool is_cursed_with(const attrib * ap, const curse * c) { const attrib *a = ap; diff --git a/src/kernel/curse.h b/src/kernel/curse.h index ee2f7899e..a4b2f9c80 100644 --- a/src/kernel/curse.h +++ b/src/kernel/curse.h @@ -248,7 +248,7 @@ extern "C" { extern void destroy_curse(curse * c); - boolean is_cursed_internal(struct attrib *ap, const curse_type * ctype); + bool is_cursed_internal(struct attrib *ap, const curse_type * ctype); /* ignoriert CURSE_ISNEW */ extern void remove_curse(struct attrib **ap, const struct curse *c); @@ -281,7 +281,7 @@ extern "C" { * */ extern struct curse *get_cursex(struct attrib *ap, const curse_type * ctype, - variant data, boolean(*compare) (const struct curse *, variant)); + variant data, bool(*compare) (const struct curse *, variant)); /* gibt pointer auf die erste curse-struct zur�ck, deren Typ ctype ist, * und f�r die compare() true liefert, oder einen NULL-pointer. * */ @@ -303,15 +303,15 @@ extern "C" { extern void curse_done(struct attrib *a); extern int curse_age(struct attrib *a); - extern boolean cmp_curse(const struct attrib *a, const void *data); - extern boolean cmp_cursetype(const struct attrib *a, const void *data); + extern bool cmp_curse(const struct attrib *a, const void *data); + extern bool cmp_cursetype(const struct attrib *a, const void *data); extern double destr_curse(struct curse *c, int cast_level, double force); extern int resolve_curse(variant data, void *address); - extern boolean is_cursed_with(const struct attrib *ap, const struct curse *c); + extern bool is_cursed_with(const struct attrib *ap, const struct curse *c); - extern boolean curse_active(const struct curse *c); + extern bool curse_active(const struct curse *c); /* gibt true, wenn der Curse nicht NULL oder inaktiv ist */ /*** COMPATIBILITY MACROS. DO NOT USE FOR NEW CODE, REPLACE IN OLD CODE: */ diff --git a/src/kernel/faction.c b/src/kernel/faction.c index 009922bca..ea02a62a1 100755 --- a/src/kernel/faction.c +++ b/src/kernel/faction.c @@ -21,6 +21,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include "faction.h" #include "alliance.h" +#include "ally.h" #include "equipment.h" #include "group.h" #include "item.h" @@ -258,7 +259,7 @@ unit *addplayer(region * r, faction * f) return u; } -boolean checkpasswd(const faction * f, const char *passwd, boolean shortp) +bool checkpasswd(const faction * f, const char *passwd, bool shortp) { if (unicode_utf8_strcasecmp(f->passw, passwd) == 0) return true; @@ -490,14 +491,14 @@ void faction_setpassword(faction * f, const char *passw) f->passw = strdup(itoa36(rng_int())); } -boolean valid_race(const struct faction *f, const struct race *rc) +bool valid_race(const struct faction *f, const struct race *rc) { if (f->race == rc) return true; else { const char *str = get_param(f->race->parameters, "other_race"); if (str) - return (boolean) (rc_find(str) == rc); + return (bool) (rc_find(str) == rc); return false; } } diff --git a/src/kernel/faction.h b/src/kernel/faction.h index a81d0545c..cc7239e82 100644 --- a/src/kernel/faction.h +++ b/src/kernel/faction.h @@ -87,7 +87,7 @@ extern "C" { int no_units; struct ally *allies; struct group *groups; - boolean alive; /* enno: sollte ein flag werden */ + bool alive; /* enno: sollte ein flag werden */ int nregions; int money; #if SCORE_MODULE @@ -118,14 +118,14 @@ extern "C" { extern struct unit *addplayer(struct region *r, faction * f); extern struct faction *addfaction(const char *email, const char *password, const struct race *frace, const struct locale *loc, int subscription); - extern boolean checkpasswd(const faction * f, const char *passwd, - boolean shortp); + extern bool checkpasswd(const faction * f, const char *passwd, + bool shortp); extern void destroyfaction(faction * f); extern void set_alliance(struct faction *a, struct faction *b, int status); extern int get_alliance(const struct faction *a, const struct faction *b); - extern struct alliance *f_get_alliance(const struct faction *a); + extern struct alliance *f_get_alliance(const struct faction *f); extern void write_faction_reference(const struct faction *f, struct storage *store); @@ -150,7 +150,7 @@ extern "C" { const char *faction_getpassword(const struct faction *self); void faction_setpassword(struct faction *self, const char *password); - boolean valid_race(const struct faction *f, const struct race *rc); + bool valid_race(const struct faction *f, const struct race *rc); struct spellbook * faction_get_spellbook(struct faction *f); #ifdef __cplusplus diff --git a/src/kernel/group.c b/src/kernel/group.c index a0b5821c5..0e49fd4aa 100755 --- a/src/kernel/group.c +++ b/src/kernel/group.c @@ -21,9 +21,10 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include "group.h" /* kernel includes */ -#include "unit.h" +#include "ally.h" #include "faction.h" #include "save.h" +#include "unit.h" #include "version.h" /* attrib includes */ @@ -175,7 +176,7 @@ void set_group(struct unit *u, struct group *g) } } -boolean join_group(unit * u, const char *name) +bool join_group(unit * u, const char *name) { group *g = NULL; diff --git a/src/kernel/group.h b/src/kernel/group.h index 14dd119cd..17b44ab3d 100755 --- a/src/kernel/group.h +++ b/src/kernel/group.h @@ -38,7 +38,7 @@ extern "C" { } group; extern struct attrib_type at_group; /* attribute for units assigned to a group */ - extern boolean join_group(struct unit *u, const char *name); + extern bool join_group(struct unit *u, const char *name); extern void set_group(struct unit *u, struct group *g); extern struct group * get_group(const struct unit *u); extern void free_group(struct group *g); diff --git a/src/kernel/item.c b/src/kernel/item.c index c588fbeca..fd35f0776 100644 --- a/src/kernel/item.c +++ b/src/kernel/item.c @@ -684,7 +684,7 @@ typedef struct t_item { const char *name; /* [0]: Einzahl f�r eigene; [1]: Mehrzahl f�r eigene; * [2]: Einzahl f�r Fremde; [3]: Mehrzahl f�r Fremde */ - boolean is_resource; + bool is_resource; skill_t skill; int minskill; int gewicht; diff --git a/src/kernel/item.h b/src/kernel/item.h index 7ff3b9454..be6d18272 100644 --- a/src/kernel/item.h +++ b/src/kernel/item.h @@ -132,7 +132,7 @@ extern "C" { int capacity; struct construction *construction; /* --- functions --- */ - boolean(*canuse) (const struct unit * user, + bool(*canuse) (const struct unit * user, const struct item_type * itype); int (*use) (struct unit * user, const struct item_type * itype, int amount, struct order * ord); @@ -220,7 +220,7 @@ extern "C" { int reload; /* time to reload this weapon */ weapon_mod *modifiers; /* --- functions --- */ - boolean(*attack) (const struct troop *, const struct weapon_type *, + bool(*attack) (const struct troop *, const struct weapon_type *, int *deaths); } weapon_type; diff --git a/src/kernel/magic.c b/src/kernel/magic.c index a0bbef2a0..f062549bf 100644 --- a/src/kernel/magic.c +++ b/src/kernel/magic.c @@ -345,7 +345,7 @@ attrib_type at_mage = { ATF_UNIQUE }; -boolean is_mage(const unit * u) +bool is_mage(const unit * u) { return i2b(get_mage(u) != NULL); } @@ -407,7 +407,7 @@ attrib_type at_seenspell = { #define MAXSPELLS 256 -static boolean already_seen(const faction * f, const spell * sp) +static bool already_seen(const faction * f, const spell * sp) { attrib *a; @@ -912,7 +912,7 @@ void pay_spell(unit * u, const spell * sp, int cast_level, int range) * aber dann immer noch nicht k�nnen, vieleicht ist seine Stufe derzeit * nicht ausreichend oder die Komponenten fehlen. */ -boolean knowsspell(const region * r, const unit * u, const spell * sp) +bool knowsspell(const region * r, const unit * u, const spell * sp) { /* Ist �berhaupt ein g�ltiger Spruch angegeben? */ if (!sp || sp->id == 0) { @@ -929,7 +929,7 @@ boolean knowsspell(const region * r, const unit * u, const spell * sp) * und sonstige Gegenstaende sein. */ -boolean +bool cancast(unit * u, const spell * sp, int level, int range, struct order * ord) { int k; @@ -1178,7 +1178,7 @@ double magic_resistance(unit * target) * true zur�ck */ -boolean +bool target_resists_magic(unit * magician, void *obj, int objtyp, int t_bonus) { double probability = 0.0; @@ -1244,9 +1244,9 @@ target_resists_magic(unit * magician, void *obj, int objtyp, int t_bonus) /* ------------------------------------------------------------- */ -boolean is_magic_resistant(unit * magician, unit * target, int resist_bonus) +bool is_magic_resistant(unit * magician, unit * target, int resist_bonus) { - return (boolean) target_resists_magic(magician, target, TYP_UNIT, + return (bool) target_resists_magic(magician, target, TYP_UNIT, resist_bonus); } @@ -1261,7 +1261,7 @@ boolean is_magic_resistant(unit * magician, unit * target, int resist_bonus) * eben) bis zu etwa 1% bei doppelt so gut wie notwendig */ -boolean fumble(region * r, unit * u, const spell * sp, int cast_grade) +bool fumble(region * r, unit * u, const spell * sp, int cast_grade) { /* X ergibt Zahl zwischen 1 und 0, je kleiner, desto besser der Magier. * 0,5*40-20=0, dh wenn der Magier doppelt so gut ist, wie der Spruch @@ -1445,7 +1445,7 @@ static double regeneration(unit * u) return aura; } -void regeneration_magiepunkte(void) +void regenerate_aura(void) { region *r; unit *u; @@ -1500,7 +1500,7 @@ void regeneration_magiepunkte(void) } } -static boolean +static bool verify_ship(region * r, unit * mage, const spell * sp, spllprm * spobj, order * ord) { @@ -1523,7 +1523,7 @@ verify_ship(region * r, unit * mage, const spell * sp, spllprm * spobj, return true; } -static boolean +static bool verify_building(region * r, unit * mage, const spell * sp, spllprm * spobj, order * ord) { @@ -1564,7 +1564,7 @@ message *msg_unitnotfound(const struct unit * mage, struct order * ord, "unit region command id", mage, mage->region, ord, uid); } -static boolean +static bool verify_unit(region * r, unit * mage, const spell * sp, spllprm * spobj, order * ord) { @@ -1907,7 +1907,7 @@ addparam_unit(const char *const param[], spllprm ** spobjp, const unit * u, static spellparameter *add_spellparameter(region * target_r, unit * u, const char *syntax, const char *const param[], int size, struct order *ord) { - boolean fail = false; + bool fail = false; int i = 0; int p = 0; const char *c; @@ -2116,7 +2116,7 @@ typedef struct familiar_data { unit *familiar; } famililar_data; -boolean is_familiar(const unit * u) +bool is_familiar(const unit * u) { attrib *a = a_find(u->attribs, &at_familiarmage); return i2b(a != NULL); @@ -2200,7 +2200,7 @@ void remove_familiar(unit * mage) } } -boolean create_newfamiliar(unit * mage, unit * familiar) +bool create_newfamiliar(unit * mage, unit * familiar) { /* if the skill modifier for the mage does not yet exist, add it */ attrib *a; @@ -2461,7 +2461,7 @@ unit *get_clone_mage(const unit * u) return NULL; } -static boolean is_moving_ship(const region * r, ship * sh) +static bool is_moving_ship(const region * r, ship * sh) { const unit *u = ship_owner(sh); @@ -2743,13 +2743,15 @@ void magic(void) continue; } - for (ord = u->orders; ord; ord = ord->next) { - if (get_keyword(ord) == K_CAST) { - castorder *co = cast_cmd(u, ord); - fset(u, UFL_LONGACTION | UFL_NOTMOVING); - if (co) { - const spell *sp = co->sp; - add_castorder(&spellranks[sp->rank], co); + if (u->thisorder != NULL) { + for (ord = u->orders; ord; ord = ord->next) { + if (get_keyword(ord) == K_CAST) { + castorder *co = cast_cmd(u, ord); + fset(u, UFL_LONGACTION | UFL_NOTMOVING); + if (co) { + const spell *sp = co->sp; + add_castorder(&spellranks[sp->rank], co); + } } } } @@ -2767,7 +2769,7 @@ void magic(void) for (co = spellranks[rank].begin; co; co = co->next) { order *ord = co->order; int invalid, resist, success, cast_level = co->level; - boolean fumbled = false; + bool fumbled = false; unit *u = co->magician.u; const spell *sp = co->sp; region *target_r = co_get_region(co); diff --git a/src/kernel/magic.h b/src/kernel/magic.h index 07ec04772..f2dfaa5ba 100644 --- a/src/kernel/magic.h +++ b/src/kernel/magic.h @@ -192,7 +192,7 @@ typedef struct sc_mage { void magic(void); - void regeneration_magiepunkte(void); + void regenerate_aura(void); extern struct attrib_type at_seenspell; extern struct attrib_type at_mage; @@ -228,9 +228,9 @@ typedef struct sc_mage { * und initialisiert den Magiertypus mit mtyp. */ sc_mage *get_mage(const struct unit *u); /* gibt u->mage zur�ck, bei nicht-Magiern *NULL */ - boolean is_mage(const struct unit *u); + bool is_mage(const struct unit *u); /* gibt true, wenn u->mage gesetzt. */ - boolean is_familiar(const struct unit *u); + bool is_familiar(const struct unit *u); /* gibt true, wenn eine Familiar-Relation besteht. */ /* Spr�che */ @@ -253,7 +253,7 @@ typedef struct sc_mage { /* f�gt alle Zauber des Magiegebietes der Einheit, deren Stufe kleiner * als das aktuelle Magietalent ist, in die Spruchliste der Einheit * ein */ - boolean knowsspell(const struct region *r, const struct unit *u, + bool knowsspell(const struct region *r, const struct unit *u, const struct spell * sp); /* pr�ft, ob die Einheit diesen Spruch gerade beherrscht, dh * mindestens die erforderliche Stufe hat. Hier k�nnen auch Abfragen @@ -277,7 +277,7 @@ typedef struct sc_mage { extern double spellpower(struct region *r, struct unit *u, const struct spell * sp, int cast_level, struct order *ord); /* ermittelt die St�rke eines Spruchs */ - boolean fumble(struct region *r, struct unit *u, const struct spell * sp, + bool fumble(struct region *r, struct unit *u, const struct spell * sp, int cast_level); /* true, wenn der Zauber misslingt, bei false gelingt der Zauber */ @@ -304,7 +304,7 @@ typedef struct sc_mage { /* gibt die f�r diesen Spruch derzeit notwendigen Magiepunkte auf der * geringstm�glichen Stufe zur�ck, schon um den Faktor der bereits * zuvor gezauberten Spr�che erh�ht */ - boolean cancast(struct unit *u, const struct spell * spruch, int eff_stufe, + bool cancast(struct unit *u, const struct spell * spruch, int eff_stufe, int distance, struct order *ord); /* true, wenn Einheit alle Komponenten des Zaubers (incl. MP) f�r die * geringstm�gliche Stufe hat und den Spruch beherrscht */ @@ -317,13 +317,13 @@ typedef struct sc_mage { /* ermittelt die effektive Stufe des Zaubers. Dabei ist cast_level * die gew�nschte maximale Stufe (im Normalfall Stufe des Magiers, * bei Farcasting Stufe*2^Entfernung) */ - boolean is_magic_resistant(struct unit *magician, struct unit *target, int + bool is_magic_resistant(struct unit *magician, struct unit *target, int resist_bonus); /* Mapperfunktion f�r target_resists_magic() vom Typ struct unit. */ extern double magic_resistance(struct unit *target); /* gibt die Chance an, mit der einem Zauber widerstanden wird. Je * gr��er, desto resistenter ist da Opfer */ - boolean target_resists_magic(struct unit *magician, void *obj, int objtyp, + bool target_resists_magic(struct unit *magician, void *obj, int objtyp, int resist_bonus); /* gibt false zur�ck, wenn der Zauber gelingt, true, wenn das Ziel * widersteht */ @@ -339,7 +339,7 @@ typedef struct sc_mage { extern struct attrib_type at_familiar; extern struct attrib_type at_familiarmage; extern void remove_familiar(struct unit *mage); - extern boolean create_newfamiliar(struct unit *mage, struct unit *familiar); + extern bool create_newfamiliar(struct unit *mage, struct unit *familiar); extern void create_newclone(struct unit *mage, struct unit *familiar); extern struct unit *has_clone(struct unit *mage); diff --git a/src/kernel/move.c b/src/kernel/move.c index 993125b43..9821e92b5 100644 --- a/src/kernel/move.c +++ b/src/kernel/move.c @@ -176,18 +176,11 @@ attrib_type at_speedup = { /* ------------------------------------------------------------- */ -direction_t getdirection(const struct locale * lang) -{ - return finddirection(getstrtoken(), lang); -} - -/* ------------------------------------------------------------- */ - static attrib_type at_driveweight = { "driveweight", NULL, NULL, NULL, NULL, NULL }; -static boolean entrance_allowed(const struct unit *u, const struct region *r) +static bool entrance_allowed(const struct unit *u, const struct region *r) { #ifdef REGIONOWNERS faction *owner = region_get_owner(r); @@ -372,7 +365,7 @@ static int canwalk(unit * u) return E_CANWALK_TOOHEAVY; } -boolean canfly(unit * u) +bool canfly(unit * u) { if (get_item(u, I_PEGASUS) >= u->number && effskill(u, SK_RIDING) >= 4) return true; @@ -386,7 +379,7 @@ boolean canfly(unit * u) return false; } -boolean canswim(unit * u) +bool canswim(unit * u) { if (get_item(u, I_DOLPHIN) >= u->number && effskill(u, SK_RIDING) >= 4) return true; @@ -448,7 +441,7 @@ static int canride(unit * u) return 0; } -static boolean cansail(const region * r, ship * sh) +static bool cansail(const region * r, ship * sh) { /* sonst ist construction:: size nicht ship_type::maxsize */ assert(!sh->type->construction @@ -584,7 +577,7 @@ ship *move_ship(ship * sh, region * from, region * to, region_list * route) { unit **iunit = &from->units; unit **ulist = &to->units; - boolean trail = (route == NULL); + bool trail = (route == NULL); if (from != to) { translist(&from->ships, &to->ships, sh); @@ -619,7 +612,7 @@ ship *move_ship(ship * sh, region * from, region * to, region_list * route) return sh; } -static boolean is_freezing(const unit * u) +static bool is_freezing(const unit * u) { if (u->race != new_race[RC_INSECT]) return false; @@ -628,12 +621,7 @@ static boolean is_freezing(const unit * u) return true; } -#define SA_HARBOUR 1 -#define SA_COAST 1 -#define SA_NO_INSECT -1 -#define SA_NO_COAST -2 - -static int is_ship_allowed(struct ship *sh, const region * r) +int check_ship_allowed(struct ship *sh, const region * r) { int c = 0; static const building_type *bt_harbour = NULL; @@ -641,7 +629,7 @@ static int is_ship_allowed(struct ship *sh, const region * r) if (bt_harbour == NULL) bt_harbour = bt_find("harbour"); - if (r_insectstalled(r)) { + if (sh->region && r_insectstalled(r)) { /* insekten d�rfen nicht hier rein. haben wir welche? */ unit *u; @@ -661,7 +649,7 @@ static int is_ship_allowed(struct ship *sh, const region * r) } } - if (buildingtype_exists(r, bt_harbour, true)) + if (bt_harbour && buildingtype_exists(r, bt_harbour, true)) return SA_HARBOUR; for (c = 0; sh->type->coasts[c] != NULL; ++c) { if (sh->type->coasts[c] == r->terrain) @@ -671,7 +659,7 @@ static int is_ship_allowed(struct ship *sh, const region * r) return SA_NO_COAST; } -static boolean flying_ship(const ship * sh) +static bool flying_ship(const ship * sh) { if (sh->type->flags & SFL_FLY) return true; @@ -704,7 +692,7 @@ static float damage_drift(void) static void drifting_ships(region * r) { direction_t d; - if (get_param_int(global.parameters, "rules.ship.drifting", 1)==0) return; + bool drift = get_param_int(global.parameters, "rules.ship.drifting", 1)!=0; if (fval(r->terrain, SEA_REGION)) { ship **shp = &r->ships; @@ -721,7 +709,7 @@ static void drifting_ships(region * r) } /* Schiff schon abgetrieben oder durch Zauber gesch�tzt? */ - if (fval(sh, SF_DRIFTED) || is_cursed(sh->attribs, C_SHIP_NODRIFT, 0)) { + if (!drift || fval(sh, SF_DRIFTED) || is_cursed(sh->attribs, C_SHIP_NODRIFT, 0)) { shp = &sh->next; continue; } @@ -753,7 +741,7 @@ static void drifting_ships(region * r) region *rn; dir = (direction_t) ((d + d_offset) % MAXDIRECTIONS); rn = rconnect(r, dir); - if (rn != NULL && fval(rn->terrain, SAIL_INTO) && is_ship_allowed(sh, rn) > 0) { + if (rn != NULL && fval(rn->terrain, SAIL_INTO) && check_ship_allowed(sh, rn) > 0) { rnext = rn; if (!fval(rnext->terrain, SEA_REGION)) break; @@ -804,9 +792,9 @@ static void drifting_ships(region * r) } } -static boolean present(region * r, unit * u) +static bool present(region * r, unit * u) { - return (boolean) (u && u->region == r); + return (bool) (u && u->region == r); } static void caught_target(region * r, unit * u) @@ -837,7 +825,7 @@ static unit *bewegung_blockiert_von(unit * reisender, region * r) { unit *u; int perception = 0; - boolean contact = false; + bool contact = false; unit *guard = NULL; if (fval(reisender->race, RCF_ILLUSIONARY)) @@ -871,7 +859,7 @@ static unit *bewegung_blockiert_von(unit * reisender, region * r) return NULL; } -static boolean is_guardian_u(const unit * guard, unit * u, unsigned int mask) +static bool is_guardian_u(const unit * guard, unit * u, unsigned int mask) { if (guard->faction == u->faction) return false; @@ -887,7 +875,7 @@ static boolean is_guardian_u(const unit * guard, unit * u, unsigned int mask) return true; } -static boolean is_guardian_r(const unit * guard) +static bool is_guardian_r(const unit * guard) { if (guard->number == 0) return false; @@ -912,7 +900,7 @@ static boolean is_guardian_r(const unit * guard) return true; } -boolean is_guard(const struct unit * u, int mask) +bool is_guard(const struct unit * u, int mask) { return is_guardian_r(u) && (getguard(u) & mask) != 0; } @@ -1011,8 +999,8 @@ static void cycle_route(order * ord, unit * u, int gereist) char neworder[2048]; const char *token; direction_t d = NODIRECTION; - boolean paused = false; - boolean pause; + bool paused = false; + bool pause; order *norder; size_t size = sizeof(tail) - 1; @@ -1086,7 +1074,7 @@ static void cycle_route(order * ord, unit * u, int gereist) free_order(norder); } -static boolean transport(unit * ut, unit * u) +static bool transport(unit * ut, unit * u) { order *ord; @@ -1106,7 +1094,7 @@ static boolean transport(unit * ut, unit * u) return false; } -static boolean can_move(const unit * u) +static bool can_move(const unit * u) { if (u->race->flags & RCF_CANNOTMOVE) return false; @@ -1185,7 +1173,7 @@ static void init_transportation(void) } } -static boolean roadto(const region * r, direction_t dir) +static bool roadto(const region * r, direction_t dir) { /* wenn es hier genug strassen gibt, und verbunden ist, und es dort * genug strassen gibt, dann existiert eine strasse in diese richtung */ @@ -1329,7 +1317,7 @@ static int movement_speed(unit * u) { int mp; static const curse_type *speed_ct; - static boolean init = false; + static bool init = false; double dk = u->race->speed; assert(u->number); @@ -1428,7 +1416,7 @@ static const region_list *travel_route(unit * u, region *current = u->region; const region_list *iroute = route_begin; int steps = 0; - boolean landing = false; /* aquarians have landed */ + bool landing = false; /* aquarians have landed */ while (iroute && iroute != route_end) { region *next = iroute->data; @@ -1586,7 +1574,7 @@ static const region_list *travel_route(unit * u, return iroute; } -static boolean ship_ready(const region * r, unit * u) +static bool ship_ready(const region * r, unit * u) { if (!u->ship || u!=ship_owner(u->ship)) { cmistake(u, u->thisorder, 146, MSG_MOVE); @@ -1633,8 +1621,8 @@ unit *owner_buildingtyp(const region * r, const building_type * bt) return NULL; } -boolean -buildingtype_exists(const region * r, const building_type * bt, boolean working) +bool +buildingtype_exists(const region * r, const building_type * bt, bool working) { building *b; @@ -1648,7 +1636,7 @@ buildingtype_exists(const region * r, const building_type * bt, boolean working) /* Pr�ft, ob Ablegen von einer K�ste in eine der erlaubten Richtungen erfolgt. */ -static boolean check_takeoff(ship * sh, region * from, region * to) +static bool check_takeoff(ship * sh, region * from, region * to) { if (!fval(from->terrain, SEA_REGION) && sh->coast != NODIRECTION) { direction_t coast = sh->coast; @@ -1667,7 +1655,7 @@ static boolean check_takeoff(ship * sh, region * from, region * to) } static void -sail(unit * u, order * ord, boolean move_on_land, region_list ** routep) +sail(unit * u, order * ord, bool move_on_land, region_list ** routep) { region *starting_point = u->region; region *current_point, *last_point; @@ -1732,9 +1720,12 @@ sail(unit * u, order * ord, boolean move_on_land, region_list ** routep) int reason; if (gamecookie != global.cookie) { - gamedate date; - get_gamedate(turn, &date); - stormyness = storms[date.month] * 5; + bool storms_enabled = get_param_int(global.parameters, "rules.ship.storms", 1)!=0; + if (storms_enabled) { + gamedate date; + get_gamedate(turn, &date); + stormyness = storms[date.month] * 5; + } gamecookie = global.cookie; } @@ -1747,7 +1738,7 @@ sail(unit * u, order * ord, boolean move_on_land, region_list ** routep) && fval(current_point->terrain, SEA_REGION)) { if (!is_cursed(sh->attribs, C_SHIP_NODRIFT, 0)) { region *rnext = NULL; - boolean storm = true; + bool storm = true; int d_offset = rng_int() % MAXDIRECTIONS; direction_t d; /* Sturm nur, wenn n�chste Region Hochsee ist. */ @@ -1816,7 +1807,7 @@ sail(unit * u, order * ord, boolean move_on_land, region_list ** routep) } } - reason = is_ship_allowed(sh, next_point); + reason = check_ship_allowed(sh, next_point); if (reason<0) { /* for some reason or another, we aren't allowed in there.. */ if (check_leuchtturm(current_point, NULL) || reason == SA_NO_INSECT) { @@ -2035,7 +2026,7 @@ static const region_list *travel_i(unit * u, const region_list * route_begin, } else if (!can_move(ut)) { cmistake(u, ord, 99, MSG_MOVE); } else { - boolean found = false; + bool found = false; if (!fval(ut, UFL_NOTMOVING) && !LongHunger(ut)) { init_tokens(ut->thisorder); @@ -2150,7 +2141,7 @@ static void travel(unit * u, region_list ** routep) } -static void move(unit * u, boolean move_on_land) +static void move(unit * u, bool move_on_land) { region_list *route = NULL; @@ -2556,7 +2547,7 @@ void movement(void) region *r = regions; while (r != NULL) { unit **up = &r->units; - boolean repeat = false; + bool repeat = false; while (*up) { unit *u = *up; @@ -2676,7 +2667,7 @@ void follow_unit(unit * u) if (a && !fval(u, UFL_MOVED | UFL_NOTMOVING)) { unit *u2 = a->data.v; - boolean follow = false; + bool follow = false; if (!u2 || u2->region != r || !cansee(u->faction, r, u2, 0)) { return; @@ -2706,12 +2697,13 @@ void follow_unit(unit * u) attrib *a2 = a_find(u2->attribs, &at_follow); if (a2 != NULL) { unit *u3 = a2->data.v; - follow = (u3 && u2->region == u2->region); + follow = (u3 && u2->region == u3->region); } } if (follow) { fset(u, UFL_FOLLOWING); fset(u2, UFL_FOLLOWED); + /* FOLLOW unit on a (potentially) moving unit prevents long orders */ set_order(&u->thisorder, NULL); } } diff --git a/src/kernel/move.h b/src/kernel/move.h index e53764c29..c76c362c1 100644 --- a/src/kernel/move.h +++ b/src/kernel/move.h @@ -47,27 +47,32 @@ extern "C" { ** pferde, macht nur noch 100, aber samt eigenem gewicht (40) macht also 140. */ int personcapacity(const struct unit *u); - direction_t getdirection(const struct locale *); void movement(void); void run_to(struct unit *u, struct region *to); struct unit *is_guarded(struct region *r, struct unit *u, unsigned int mask); - boolean is_guard(const struct unit *u, int mask); + bool is_guard(const struct unit *u, int mask); int enoughsailors(const struct ship *sh, const struct region *r); - boolean canswim(struct unit *u); - boolean canfly(struct unit *u); + bool canswim(struct unit *u); + bool canfly(struct unit *u); struct unit *get_captain(const struct ship *sh); void travelthru(const struct unit *u, struct region *r); struct ship *move_ship(struct ship *sh, struct region *from, struct region *to, struct region_list *route); int walkingcapacity(const struct unit *u); void follow_unit(struct unit *u); - boolean buildingtype_exists(const struct region *r, - const struct building_type *bt, boolean working); + bool buildingtype_exists(const struct region *r, + const struct building_type *bt, bool working); struct unit *owner_buildingtyp(const struct region *r, const struct building_type *bt); extern struct attrib_type at_speedup; + +#define SA_HARBOUR 2 +#define SA_COAST 1 +#define SA_NO_INSECT -1 +#define SA_NO_COAST -2 + extern int check_ship_allowed(struct ship *sh, const struct region * r); #ifdef __cplusplus } #endif diff --git a/src/kernel/move_test.c b/src/kernel/move_test.c index 172012e4d..640b9ada8 100644 --- a/src/kernel/move_test.c +++ b/src/kernel/move_test.c @@ -4,12 +4,57 @@ #include <kernel/building.h> #include <kernel/move.h> #include <kernel/region.h> +#include <kernel/ship.h> +#include <kernel/terrain.h> #include <util/language.h> #include <CuTest.h> #include <tests.h> +static void test_ship_not_allowed_in_coast(CuTest * tc) +{ + region *r; + ship * sh; + terrain_type * ttype; + ship_type * stype; + const char * names[] = { "derp", "derp_p" }; + + test_cleanup(); + test_create_world(); + + ttype = test_create_terrain("glacier", LAND_REGION|ARCTIC_REGION|WALK_INTO|SAIL_INTO); + stype = test_create_shiptype(names); + stype->coasts = (const struct terrain_type **)calloc(2, sizeof(const struct terrain_type *)); + + r = test_create_region(0, 0, ttype); + sh = test_create_ship(0, stype); + + CuAssertIntEquals(tc, SA_NO_COAST, check_ship_allowed(sh, r)); + stype->coasts[0] = ttype; + CuAssertIntEquals(tc, SA_COAST, check_ship_allowed(sh, r)); +} + +static void test_ship_allowed_with_harbor(CuTest * tc) +{ + region *r; + ship * sh; + terrain_type * ttype; + building_type * btype; + + test_cleanup(); + test_create_world(); + + ttype = test_create_terrain("glacier", LAND_REGION|ARCTIC_REGION|WALK_INTO|SAIL_INTO); + btype = test_create_buildingtype("harbour"); + + r = test_create_region(0, 0, ttype); + sh = test_create_ship(0, 0); + + test_create_building(r, btype); + CuAssertIntEquals(tc, SA_HARBOUR, check_ship_allowed(sh, r)); +} + static void test_building_type_exists(CuTest * tc) { region *r; @@ -35,5 +80,7 @@ CuSuite *get_move_suite(void) { CuSuite *suite = CuSuiteNew(); SUITE_ADD_TEST(suite, test_building_type_exists); + SUITE_ADD_TEST(suite, test_ship_not_allowed_in_coast); + SUITE_ADD_TEST(suite, test_ship_allowed_with_harbor); return suite; } diff --git a/src/kernel/order.c b/src/kernel/order.c index 9547d4446..13cd7dc6d 100644 --- a/src/kernel/order.c +++ b/src/kernel/order.c @@ -260,10 +260,6 @@ static order *create_order_i(keyword_t kwd, const char *sptr, int persistent, case K_KOMMENTAR: case NOKEYWORD: return NULL; - case K_LIEFERE: - kwd = K_GIVE; - persistent = 1; - break; default: break; } @@ -373,7 +369,7 @@ order *parse_order(const char *s, const struct locale * lang) * \return true if the order is long * \sa is_exclusive(), is_repeated(), is_persistent() */ -int is_repeated(const order * ord) +bool is_repeated(const order * ord) { keyword_t kwd = ORD_KEYWORD(ord); const struct locale *lang = ORD_LOCALE(ord); @@ -439,7 +435,7 @@ int is_repeated(const order * ord) * \return true if the order is long * \sa is_exclusive(), is_repeated(), is_persistent() */ -int is_exclusive(const order * ord) +bool is_exclusive(const order * ord) { keyword_t kwd = ORD_KEYWORD(ord); const struct locale *lang = ORD_LOCALE(ord); @@ -447,8 +443,6 @@ int is_exclusive(const order * ord) switch (kwd) { case K_MOVE: - case K_WEREWOLF: - /* these should not become persistent */ case K_ROUTE: case K_DRIVE: case K_WORK: @@ -502,18 +496,17 @@ int is_exclusive(const order * ord) * \return true if the order is long * \sa is_exclusive(), is_repeated(), is_persistent() */ -int is_long(const order * ord) +bool is_long(const order * ord) { keyword_t kwd = ORD_KEYWORD(ord); const struct locale *lang = ORD_LOCALE(ord); - int result = 0; + bool result = false; switch (kwd) { case K_CAST: case K_BUY: case K_SELL: case K_MOVE: - case K_WEREWOLF: case K_ROUTE: case K_DRIVE: case K_WORK: @@ -553,7 +546,7 @@ int is_long(const order * ord) parser_popstate(); break; default: - result = 0; + result = false; } return result; } @@ -567,19 +560,17 @@ int is_long(const order * ord) * \return true if the order is persistent * \sa is_exclusive(), is_repeated(), is_persistent() */ -int is_persistent(const order * ord) +bool is_persistent(const order * ord) { keyword_t kwd = ORD_KEYWORD(ord); int persist = ord->_persistent != 0; switch (kwd) { case K_MOVE: - case K_WEREWOLF: case NOKEYWORD: /* lang, aber niemals persistent! */ return false; case K_KOMMENTAR: - case K_LIEFERE: return true; default: @@ -610,3 +601,9 @@ void push_order(order ** ordp, order * ord) ordp = &(*ordp)->next; *ordp = ord; } + +void init_tokens(const struct order *ord) +{ + char *cmd = getcommand(ord); + init_tokens_str(cmd, cmd); +} diff --git a/src/kernel/order.h b/src/kernel/order.h index 9e0ebeef5..d62f6b2ad 100644 --- a/src/kernel/order.h +++ b/src/kernel/order.h @@ -51,12 +51,13 @@ extern "C" { extern keyword_t get_keyword(const order * ord); extern void set_order(order ** destp, order * src); extern char *getcommand(const order * ord); - extern int is_persistent(const order * ord); - extern int is_exclusive(const order * ord); - extern int is_repeated(const order * ord); - extern int is_long(const order * ord); + extern bool is_persistent(const order * ord); + extern bool is_exclusive(const order * ord); + extern bool is_repeated(const order * ord); + extern bool is_long(const order * ord); extern char *write_order(const order * ord, char *buffer, size_t size); + extern void init_tokens(const struct order *ord); /* initialize token parsing */ #ifdef __cplusplus } diff --git a/src/kernel/pathfinder.c b/src/kernel/pathfinder.c index c9adf3251..875211deb 100644 --- a/src/kernel/pathfinder.c +++ b/src/kernel/pathfinder.c @@ -28,21 +28,21 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include <stdlib.h> #include <assert.h> -boolean allowed_swim(const region * src, const region * r) +bool allowed_swim(const region * src, const region * r) { if (fval(r->terrain, SWIM_INTO)) return true; return false; } -boolean allowed_walk(const region * src, const region * r) +bool allowed_walk(const region * src, const region * r) { if (fval(r->terrain, WALK_INTO)) return true; return false; } -boolean allowed_fly(const region * src, const region * r) +bool allowed_fly(const region * src, const region * r) { if (fval(r->terrain, FLY_INTO)) return true; @@ -100,7 +100,7 @@ static void free_nodes(node * root) } struct quicklist *regions_in_range(struct region *start, int maxdist, - boolean(*allowed) (const struct region *, const struct region *)) + bool(*allowed) (const struct region *, const struct region *)) { quicklist * rlist = NULL; node *root = new_node(start, 0, NULL); @@ -140,14 +140,14 @@ struct quicklist *regions_in_range(struct region *start, int maxdist, } static region **internal_path_find(region * start, const region * target, - int maxlen, boolean(*allowed) (const region *, const region *)) + int maxlen, bool(*allowed) (const region *, const region *)) { static region *path[MAXDEPTH + 2]; /* STATIC_RETURN: used for return, not across calls */ direction_t d; node *root = new_node(start, 0, NULL); node **end = &root->next; node *n = root; - boolean found = false; + bool found = false; assert(maxlen <= MAXDEPTH); fset(start, RF_MARK); @@ -190,9 +190,9 @@ static region **internal_path_find(region * start, const region * target, return NULL; } -boolean +bool path_exists(region * start, const region * target, int maxlen, - boolean(*allowed) (const region *, const region *)) + bool(*allowed) (const region *, const region *)) { assert((!fval(start, RF_MARK) && !fval(target, RF_MARK)) || !"Some Algorithm did not clear its RF_MARKs!"); @@ -204,7 +204,7 @@ path_exists(region * start, const region * target, int maxlen, } region **path_find(region * start, const region * target, int maxlen, - boolean(*allowed) (const region *, const region *)) + bool(*allowed) (const region *, const region *)) { assert((!fval(start, RF_MARK) && !fval(target, RF_MARK)) || !"Did you call path_init()?"); diff --git a/src/kernel/pathfinder.h b/src/kernel/pathfinder.h index ac372dc34..6c9edb94e 100644 --- a/src/kernel/pathfinder.h +++ b/src/kernel/pathfinder.h @@ -29,18 +29,18 @@ extern "C" { extern struct region **path_find(struct region *start, const struct region *target, int maxlen, - boolean(*allowed) (const struct region *, const struct region *)); - extern boolean path_exists(struct region *start, const struct region *target, - int maxlen, boolean(*allowed) (const struct region *, + bool(*allowed) (const struct region *, const struct region *)); + extern bool path_exists(struct region *start, const struct region *target, + int maxlen, bool(*allowed) (const struct region *, const struct region *)); - extern boolean allowed_swim(const struct region *src, + extern bool allowed_swim(const struct region *src, const struct region *target); - extern boolean allowed_fly(const struct region *src, + extern bool allowed_fly(const struct region *src, const struct region *target); - extern boolean allowed_walk(const struct region *src, + extern bool allowed_walk(const struct region *src, const struct region *target); extern struct quicklist *regions_in_range(struct region *src, int maxdist, - boolean(*allowed) (const struct region *, const struct region *)); + bool(*allowed) (const struct region *, const struct region *)); extern void pathfinder_cleanup(void); diff --git a/src/kernel/plane.c b/src/kernel/plane.c index 111ebb675..13ea38ce9 100644 --- a/src/kernel/plane.c +++ b/src/kernel/plane.c @@ -309,7 +309,7 @@ int read_plane_reference(plane ** pp, struct storage *store) return AT_READ_OK; } -boolean is_watcher(const struct plane * p, const struct faction * f) +bool is_watcher(const struct plane * p, const struct faction * f) { struct watcher *w; if (!p) diff --git a/src/kernel/plane.h b/src/kernel/plane.h index 685a36c71..c573c096b 100644 --- a/src/kernel/plane.h +++ b/src/kernel/plane.h @@ -73,7 +73,7 @@ extern "C" { struct plane *get_homeplane(void); extern int rel_to_abs(const struct plane *pl, const struct faction *f, int rel, unsigned char index); - extern boolean is_watcher(const struct plane *p, const struct faction *f); + extern bool is_watcher(const struct plane *p, const struct faction *f); extern int resolve_plane(variant data, void *addr); extern void write_plane_reference(const plane * p, struct storage *store); extern int read_plane_reference(plane ** pp, struct storage *store); diff --git a/src/kernel/pool.c b/src/kernel/pool.c index b150f9f9f..f738bc0d6 100644 --- a/src/kernel/pool.c +++ b/src/kernel/pool.c @@ -96,7 +96,7 @@ int change_resource(unit * u, const resource_type * rtype, int change) int get_reservation(const unit * u, const resource_type * rtype) { - struct reservation *res = u->reservations; + reservation *res = u->reservations; if (rtype == oldresourcetype[R_STONE] && (u->race->flags & RCF_STONEGOLEM)) return (u->number * GOLEM_STONE); @@ -111,7 +111,7 @@ int get_reservation(const unit * u, const resource_type * rtype) int change_reservation(unit * u, const resource_type * rtype, int value) { - struct reservation *res, **rp = &u->reservations; + reservation *res, **rp = &u->reservations; if (!value) return 0; @@ -120,7 +120,7 @@ int change_reservation(unit * u, const resource_type * rtype, int value) rp = &(*rp)->next; res = *rp; if (!res) { - *rp = res = calloc(sizeof(struct reservation), 1); + *rp = res = calloc(sizeof(reservation), 1); res->type = rtype; res->value = value; } else if (res && res->value + value <= 0) { @@ -133,9 +133,9 @@ int change_reservation(unit * u, const resource_type * rtype, int value) return res->value; } -static int new_set_resvalue(unit * u, const resource_type * rtype, int value) +int set_resvalue(unit * u, const resource_type * rtype, int value) { - struct reservation *res, **rp = &u->reservations; + reservation *res, **rp = &u->reservations; while (*rp && (*rp)->type != rtype) rp = &(*rp)->next; @@ -143,7 +143,7 @@ static int new_set_resvalue(unit * u, const resource_type * rtype, int value) if (!res) { if (!value) return 0; - *rp = res = calloc(sizeof(struct reservation), 1); + *rp = res = calloc(sizeof(reservation), 1); res->type = rtype; res->value = value; } else if (res && value <= 0) { @@ -253,34 +253,3 @@ use_pooled(unit * u, const resource_type * rtype, unsigned int mode, int count) } return count - use; } - -int reserve_cmd(unit * u, struct order *ord) -{ - if (u->number > 0 && (urace(u)->ec_flags & GETITEM)) { - int use, count; - const resource_type *rtype; - const char *s; - - init_tokens(ord); - skip_token(); - s = getstrtoken(); - count = atoip((const char *)s); - - if (count == 0 && findparam(s, u->faction->locale) == P_EACH) { - count = getint() * u->number; - } - - rtype = findresourcetype(getstrtoken(), u->faction->locale); - if (rtype == NULL) - return 0; - - new_set_resvalue(u, rtype, 0); /* make sure the pool is empty */ - use = use_pooled(u, rtype, GET_DEFAULT, count); - if (use) { - new_set_resvalue(u, rtype, use); - change_resource(u, rtype, use); - return use; - } - } - return 0; -} diff --git a/src/kernel/pool.h b/src/kernel/pool.h index b6a5e6833..6de15bf3c 100644 --- a/src/kernel/pool.h +++ b/src/kernel/pool.h @@ -54,11 +54,7 @@ extern "C" { int change_reservation(struct unit *u, const struct resource_type *res, int value); - int reserve_cmd(struct unit *u, struct order *ord); - -/** init_pool - * initialisiert den regionalen Pool. - */ + int set_resvalue(struct unit * u, const struct resource_type * rtype, int value); #ifdef __cplusplus } diff --git a/src/kernel/race.c b/src/kernel/race.c index 48c8b3a4a..95686c56f 100644 --- a/src/kernel/race.c +++ b/src/kernel/race.c @@ -153,7 +153,7 @@ race *rc_find(const char *name) } /** dragon movement **/ -boolean allowed_dragon(const region * src, const region * target) +bool allowed_dragon(const region * src, const region * target) { if (fval(src->terrain, ARCTIC_REGION) && fval(target->terrain, SEA_REGION)) return false; @@ -187,7 +187,7 @@ void set_show_item(faction * f, item_t i) a->data.v = (void *)olditemtype[i]; } -boolean r_insectstalled(const region * r) +bool r_insectstalled(const region * r) { return fval(r->terrain, ARCTIC_REGION); } diff --git a/src/kernel/race.h b/src/kernel/race.h index c7c7c43fc..c6f511d44 100644 --- a/src/kernel/race.h +++ b/src/kernel/race.h @@ -80,7 +80,7 @@ extern "C" { struct att attack[10]; char bonus[MAXSKILLS]; signed char *study_speed; /* study-speed-bonus in points/turn (0=30 Tage) */ - boolean __remove_me_nonplayer; + bool __remove_me_nonplayer; int flags; int battle_flags; int ec_flags; @@ -89,7 +89,7 @@ extern "C" { const char *(*generate_name) (const struct unit *); const char *(*describe) (const struct unit *, const struct locale *); void (*age) (struct unit * u); - boolean(*move_allowed) (const struct region *, const struct region *); + bool(*move_allowed) (const struct region *, const struct region *); struct item *(*itemdrop) (const struct race *, int size); void (*init_familiar) (struct unit *); @@ -176,10 +176,10 @@ extern "C" { #define humanoidrace(rc) (fval((rc), RCF_UNDEAD) || (rc)==new_race[RC_DRACOID] || playerrace(rc)) #define illusionaryrace(rc) (fval(rc, RCF_ILLUSIONARY)) - extern boolean allowed_dragon(const struct region *src, + extern bool allowed_dragon(const struct region *src, const struct region *target); - extern boolean r_insectstalled(const struct region *r); + extern bool r_insectstalled(const struct region *r); extern void add_raceprefix(const char *); extern char **race_prefixes; diff --git a/src/kernel/region.c b/src/kernel/region.c index 6996d959f..c2d5e6587 100644 --- a/src/kernel/region.c +++ b/src/kernel/region.c @@ -431,7 +431,7 @@ static int hash_requests; static int hash_misses; #endif -boolean pnormalize(int *x, int *y, const plane * pl) +bool pnormalize(int *x, int *y, const plane * pl) { if (pl) { if (x) { @@ -628,13 +628,13 @@ int distance(const region * r1, const region * r2) static direction_t koor_reldirection(int ax, int ay, int bx, int by, const struct plane *pl) { - direction_t dir; + int dir; for (dir = 0; dir != MAXDIRECTIONS; ++dir) { int x = ax + delta_x[dir]; int y = ay + delta_y[dir]; pnormalize(&x, &y, pl); if (bx == x && by == y) - return dir; + return (direction_t)dir; } return NODIRECTION; } @@ -806,7 +806,7 @@ short rroad(const region * r, direction_t d) return (r == b->from) ? b->data.sa[0] : b->data.sa[1]; } -boolean r_isforest(const region * r) +bool r_isforest(const region * r) { if (fval(r->terrain, FOREST_REGION)) { /* needs to be covered with at leas 48% trees */ @@ -817,17 +817,17 @@ boolean r_isforest(const region * r) return false; } -int is_coastregion(region * r) +bool is_coastregion(region * r) { direction_t i; int res = 0; - for (i = 0; i < MAXDIRECTIONS; i++) { + for (i = 0; !res && i < MAXDIRECTIONS; i++) { region *rn = rconnect(r, i); if (rn && fval(rn->terrain, SEA_REGION)) res++; } - return res; + return res!=0; } int rpeasants(const region * r) @@ -1593,9 +1593,9 @@ void region_set_morale(region * r, int morale, int turn) void get_neighbours(const region * r, region ** list) { - direction_t dir; + int dir; for (dir = 0; dir != MAXDIRECTIONS; ++dir) { - list[dir] = rconnect(r, dir); + list[dir] = rconnect(r, (direction_t)dir); } } @@ -1607,7 +1607,7 @@ int owner_change(const region * r) return -1; } -boolean is_mourning(const region * r, int in_turn) +bool is_mourning(const region * r, int in_turn) { int change = owner_change(r); return (change == in_turn - 1 diff --git a/src/kernel/region.h b/src/kernel/region.h index 4afbfa2f6..2cdd3dd95 100644 --- a/src/kernel/region.h +++ b/src/kernel/region.h @@ -157,7 +157,7 @@ extern "C" { typedef struct spec_direction { int x, y; int duration; - boolean active; + bool active; char *desc; char *keyword; } spec_direction; @@ -210,7 +210,7 @@ extern "C" { short rroad(const struct region *r, direction_t d); void rsetroad(struct region *r, direction_t d, short value); - int is_coastregion(struct region *r); + bool is_coastregion(struct region *r); int rtrees(const struct region *r, int ageclass); enum { @@ -236,7 +236,7 @@ extern "C" { #define rherbs(r) ((r)->land?(r)->land->herbs:0) #define rsetherbs(r, value) if ((r)->land) ((r)->land->herbs=(short)(value)) - boolean r_isforest(const struct region *r); + bool r_isforest(const struct region *r); #define rterrain(r) (oldterrain((r)->terrain)) #define rsetterrain(r, t) ((r)->terrain = newterrain(t)) @@ -255,7 +255,7 @@ extern "C" { struct region *new_region(int x, int y, struct plane *pl, unsigned int uid); void remove_region(region ** rlist, region * r); void terraform_region(struct region *r, const struct terrain_type *terrain); - boolean pnormalize(int *x, int *y, const struct plane *pl); + bool pnormalize(int *x, int *y, const struct plane *pl); extern const int delta_x[MAXDIRECTIONS]; extern const int delta_y[MAXDIRECTIONS]; @@ -295,7 +295,7 @@ extern "C" { void region_setresource(struct region *r, const struct resource_type *rtype, int value); int owner_change(const region * r); - boolean is_mourning(const region * r, int in_turn); + bool is_mourning(const region * r, int in_turn); const struct item_type *r_luxury(struct region *r); void get_neighbours(const struct region *r, struct region **list); diff --git a/src/kernel/reports.c b/src/kernel/reports.c index e6ae19581..54cdbb011 100644 --- a/src/kernel/reports.c +++ b/src/kernel/reports.c @@ -69,9 +69,9 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include <attributes/otherfaction.h> #include <attributes/racename.h> -boolean nocr = false; -boolean nonr = false; -boolean noreports = false; +bool nocr = false; +bool nonr = false; +bool noreports = false; const char *visibility[] = { "none", @@ -141,7 +141,7 @@ const char *hp_status(const unit * u) void report_item(const unit * owner, const item * i, const faction * viewer, - const char **name, const char **basename, int *number, boolean singular) + const char **name, const char **basename, int *number, bool singular) { assert(!owner || owner->number); if (owner && owner->faction == viewer) { @@ -379,7 +379,7 @@ report_resources(const seen_region * sr, resource_report * result, int size, int horses = rhorses(r); int trees = rtrees(r, 2); int saplings = rtrees(r, 1); - boolean mallorn = fval(r, RF_MALLORN) != 0; + bool mallorn = fval(r, RF_MALLORN) != 0; if (money) { if (n >= size) @@ -457,16 +457,16 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char *buf, int getarnt = fval(u, UFL_ANON_FACTION); const char *pzTmp, *str; building *b; - boolean isbattle = (boolean) (mode == see_battle); + bool isbattle = (bool) (mode == see_battle); int telepath_see = 0; attrib *a_fshidden = NULL; item *itm; item *show; faction *fv = visible_faction(f, u); char *bufp = buf; - boolean itemcloak = false; + bool itemcloak = false; static const curse_type *itemcloak_ct = 0; - static boolean init = false; + static bool init = false; int bytes; item result[MAX_INVENTORY]; @@ -620,10 +620,12 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char *buf, WARN_STATIC_BUFFER(); } if (fval(u, UFL_HUNGER)) { - if (c) - bytes = (int)strlcpy(bufp, ", hungert", size); - else - bytes = (int)strlcpy(bufp, "hungert", size); + if (c) { + bytes = (int)strlcpy(bufp, ", ", size); + if (wrptr(&bufp, &size, bytes) != 0) + WARN_STATIC_BUFFER(); + } + bytes = (int)strlcpy(bufp, LOC(f->locale, "unit_hungers"), size); if (wrptr(&bufp, &size, bytes) != 0) WARN_STATIC_BUFFER(); } @@ -774,7 +776,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char *buf, } } if (!isbattle) { - boolean printed = 0; + bool printed = 0; order *ord;; for (ord = u->old_orders; ord; ord = ord->next) { if (is_repeated(ord)) { @@ -1095,7 +1097,7 @@ static void get_addresses(report_context * ctx) while (u != NULL) { if (u->faction != ctx->f) { faction *sf = visible_faction(ctx->f, u); - boolean ballied = sf && sf != ctx->f && sf != lastf + bool ballied = sf && sf != ctx->f && sf != lastf && !fval(u, UFL_ANON_FACTION) && cansee(ctx->f, r, u, stealthmod); if (ballied || ALLIED(ctx->f, sf)) { ql_set_insert(&flist, sf); @@ -1208,9 +1210,9 @@ static void get_seen_interval(report_context * ctx) link_seen(ctx->seen, ctx->first, ctx->last); } -boolean +bool add_seen(struct seen_region *seehash[], struct region *r, unsigned char mode, - boolean dis) + bool dis) { seen_region *find = find_seen(seehash, r); if (find == NULL) { @@ -1590,7 +1592,7 @@ static seen_region **prepare_report(faction * f) int write_reports(faction * f, time_t ltime) { int backup = 1, maxbackup = 128; - boolean gotit = false; + bool gotit = false; struct report_context ctx; const char *encoding = "UTF-8"; @@ -2321,7 +2323,7 @@ int report_action(region * r, unit * actor, message * msg, int flags) if (view) { for (u = r->units; u; u = u->next) { if (!fval(u->faction, FFL_SELECT)) { - boolean show = u->faction == actor->faction; + bool show = u->faction == actor->faction; fset(u->faction, FFL_SELECT); if (view == ACTION_CANSEE) { /* Bei Fernzaubern sieht nur die eigene Partei den Magier */ diff --git a/src/kernel/reports.h b/src/kernel/reports.h index e2669de6f..ffd4ee42c 100644 --- a/src/kernel/reports.h +++ b/src/kernel/reports.h @@ -33,12 +33,12 @@ extern "C" { extern const char *directions[]; extern const char *coasts[]; - extern boolean nonr; - extern boolean nocr; - extern boolean noreports; + extern bool nonr; + extern bool nocr; + extern bool noreports; /* kann_finden speedups */ - extern boolean kann_finden(struct faction *f1, struct faction *f2); + extern bool kann_finden(struct faction *f1, struct faction *f2); extern struct unit *can_find(struct faction *, struct faction *); /* funktionen zum schreiben eines reports */ @@ -77,13 +77,13 @@ extern "C" { struct seen_region *next; struct region *r; unsigned char mode; - boolean disbelieves; + bool disbelieves; } seen_region; extern struct seen_region *find_seen(struct seen_region *seehash[], const struct region *r); - extern boolean add_seen(struct seen_region *seehash[], struct region *r, - unsigned char mode, boolean dis); + extern bool add_seen(struct seen_region *seehash[], struct region *r, + unsigned char mode, bool dis); extern struct seen_region **seen_init(void); extern void seen_done(struct seen_region *seehash[]); extern void free_seen(void); @@ -137,7 +137,7 @@ extern "C" { const struct unit *owner, const struct faction *viewer); void report_item(const struct unit *owner, const struct item *i, const struct faction *viewer, const char **name, const char **basename, - int *number, boolean singular); + int *number, bool singular); void report_building(const struct building *b, const char **btype, const char **billusion); void report_race(const struct unit *u, const char **rcname, diff --git a/src/kernel/resources.c b/src/kernel/resources.c index 0cd731869..4a3607d7b 100644 --- a/src/kernel/resources.c +++ b/src/kernel/resources.c @@ -118,7 +118,7 @@ static void terraform_default(struct rawmaterial *res, const region * r) } #ifdef RANDOM_CHANGE -static void resource_random_change(int *pvalue, boolean used) +static void resource_random_change(int *pvalue, bool used) { int split = 5; int rnd = rng_int() % 100; diff --git a/src/kernel/save.c b/src/kernel/save.c index cf7724a96..1ba845cc0 100644 --- a/src/kernel/save.c +++ b/src/kernel/save.c @@ -22,6 +22,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include "alchemy.h" #include "alliance.h" +#include "ally.h" #include "connection.h" #include "building.h" #include "faction.h" @@ -132,7 +133,7 @@ FILE *cfopen(const char *filename, const char *mode) int freadstr(FILE * F, int encoding, char *start, size_t size) { char *str = start; - boolean quote = false; + bool quote = false; for (;;) { int c = fgetc(F); @@ -298,7 +299,7 @@ static unit *unitorders(FILE * F, int enc, struct faction *f) stok = parse_token(&stok); if (stok) { - boolean quit = false; + bool quit = false; param_t param = findparam(stok, u->faction->locale); switch (param) { case P_UNIT: diff --git a/src/kernel/ship.c b/src/kernel/ship.c index 141bd4ba9..96745c59e 100644 --- a/src/kernel/ship.c +++ b/src/kernel/ship.c @@ -171,7 +171,6 @@ ship *new_ship(const ship_type * stype, region * r, const struct locale *lang) const char *sname = 0; assert(stype); - assert(r); sh->no = newcontainerid(); sh->coast = NODIRECTION; sh->type = stype; @@ -188,7 +187,9 @@ ship *new_ship(const ship_type * stype, region * r, const struct locale *lang) slprintf(buffer, sizeof(buffer), "%s %s", sname, shipid(sh)); sh->name = strdup(buffer); shash(sh); - addlist(&r->ships, sh); + if (r) { + addlist(&r->ships, sh); + } return sh; } diff --git a/src/kernel/skill.c b/src/kernel/skill.c index c25954182..2cdc3d25b 100644 --- a/src/kernel/skill.c +++ b/src/kernel/skill.c @@ -73,7 +73,7 @@ const char *skillnames[MAXSKILLS] = { "unarmed" }; -boolean skill_enabled[MAXSKILLS]; +bool skill_enabled[MAXSKILLS]; const char *skillname(skill_t sk, const struct locale *lang) { @@ -83,7 +83,7 @@ const char *skillname(skill_t sk, const struct locale *lang) return NULL; } -void enable_skill(const char *skname, boolean value) +void enable_skill(const char *skname, bool value) { skill_t sk; for (sk = 0; sk != MAXSKILLS; ++sk) { @@ -260,7 +260,7 @@ int level(int days) { int i; static int ldays[64]; - static boolean init = false; + static bool init = false; if (!init) { init = true; for (i = 0; i != 64; ++i) diff --git a/src/kernel/skill.h b/src/kernel/skill.h index dde1c0721..4db618f5a 100644 --- a/src/kernel/skill.h +++ b/src/kernel/skill.h @@ -48,7 +48,7 @@ extern "C" { extern const char *skillname(skill_t, const struct locale *); extern skill_t sk_find(const char *name); - extern void enable_skill(const char *name, boolean value); + extern void enable_skill(const char *name, bool value); extern int level_days(int level); extern int level(int days); @@ -60,7 +60,7 @@ extern "C" { extern void sk_set(skill * sv, int level); extern const char *skillnames[]; - extern boolean skill_enabled[]; + extern bool skill_enabled[]; #ifdef __cplusplus } diff --git a/src/kernel/sqlite.c b/src/kernel/sqlite.c index 6e6cc5014..b7c9951a3 100644 --- a/src/kernel/sqlite.c +++ b/src/kernel/sqlite.c @@ -73,9 +73,9 @@ typedef struct db_faction { static int db_update_email(sqlite3 * db, const faction * f, const db_faction * dbstate, - boolean force, /* [OUT] */ sqlite3_uint64 * id_email) + bool force, /* [OUT] */ sqlite3_uint64 * id_email) { - boolean update = force; + bool update = force; int res = SQLITE_OK; char email_lc[MAX_EMAIL_LENGTH]; @@ -129,7 +129,7 @@ db_update_email(sqlite3 * db, const faction * f, const db_faction * dbstate, return SQLITE_OK; } -int db_update_factions(sqlite3 * db, boolean force) +int db_update_factions(sqlite3 * db, bool force) { int game_id = 6; const char sql_select[] = @@ -172,7 +172,7 @@ int db_update_factions(sqlite3 * db, boolean force) int i; char passwd_md5[MD5_LENGTH_0]; sqlite3_uint64 id_email; - boolean update = force; + bool update = force; db_faction dbstate; const char *no_b36; @@ -241,7 +241,7 @@ int db_update_factions(sqlite3 * db, boolean force) return SQLITE_OK; } -int db_update_scores(sqlite3 * db, boolean force) +int db_update_scores(sqlite3 * db, bool force) { const char *sql_ins = "INSERT OR FAIL INTO score (value,faction_id,turn) VALUES (?,?,?)"; diff --git a/src/kernel/teleport.c b/src/kernel/teleport.c index 51428f7b8..db5cc646b 100644 --- a/src/kernel/teleport.c +++ b/src/kernel/teleport.c @@ -61,7 +61,7 @@ static region *tpregion(const region * r) return rt; } -region_list *astralregions(const region * r, boolean(*valid) (const region *)) +region_list *astralregions(const region * r, bool(*valid) (const region *)) { region_list *rlist = NULL; int x, y; @@ -116,7 +116,7 @@ region *r_astral_to_standard(const region * r) } region_list *all_in_range(const region * r, int n, - boolean(*valid) (const region *)) + bool(*valid) (const region *)) { int x, y; region_list *rlist = NULL; @@ -171,7 +171,7 @@ plane *get_normalplane(void) return NULL; } -boolean is_astral(const region * r) +bool is_astral(const region * r) { plane *pl = get_astralplane(); return (pl && rplane(r) == pl); @@ -227,7 +227,7 @@ void create_teleport_plane(void) } } -boolean inhabitable(const region * r) +bool inhabitable(const region * r) { return fval(r->terrain, LAND_REGION); } diff --git a/src/kernel/teleport.h b/src/kernel/teleport.h index 2f3a5bcc0..75be6b5d1 100644 --- a/src/kernel/teleport.h +++ b/src/kernel/teleport.h @@ -25,11 +25,11 @@ extern "C" { struct region *r_standard_to_astral(const struct region *r); struct region *r_astral_to_standard(const struct region *); extern struct region_list *astralregions(const struct region *rastral, - boolean(*valid) (const struct region *)); + bool(*valid) (const struct region *)); extern struct region_list *all_in_range(const struct region *r, int n, - boolean(*valid) (const struct region *)); - extern boolean inhabitable(const struct region *r); - extern boolean is_astral(const struct region *r); + bool(*valid) (const struct region *)); + extern bool inhabitable(const struct region *r); + extern bool is_astral(const struct region *r); extern struct plane *get_astralplane(void); extern struct plane *get_normalplane(void); diff --git a/src/kernel/types.h b/src/kernel/types.h index 820f4b698..f023e435a 100644 --- a/src/kernel/types.h +++ b/src/kernel/types.h @@ -35,6 +35,7 @@ typedef short item_t; struct attrib; struct attrib_type; +struct ally; struct building; struct building_type; struct curse; @@ -90,8 +91,6 @@ typedef enum { K_END, K_DRIVE, K_NUMBER, - K_WAR, - K_PEACE, K_FOLLOW, K_RESEARCH, K_GIVE, @@ -102,7 +101,6 @@ typedef enum { K_CONTACT, K_TEACH, K_STUDY, - K_LIEFERE, K_MAKE, K_MOVE, K_PASSWORD, @@ -128,18 +126,12 @@ typedef enum { K_URSPRUNG, K_EMAIL, K_PIRACY, - K_RESTART, K_GROUP, - K_SACRIFICE, - K_PRAY, K_SORT, - K_SETJIHAD, K_GM, /* perform GM commands */ K_INFO, /* set player-info */ K_PREFIX, K_PLANT, - K_WEREWOLF, - K_XE, K_ALLIANCE, K_CLAIM, K_PROMOTION, @@ -402,10 +394,6 @@ typedef enum { /* ------------------------------------------------------------- */ /* Prototypen */ -#define ALLIED_TAX 1 -#define ALLIED_NOBLOCK 2 -#define ALLIED_HELP 4 - /* alle vierstelligen zahlen: */ #define MAX_UNIT_NR (36*36*36*36-1) #define MAX_CONTAINER_NR (36*36*36*36-1) diff --git a/src/kernel/unit.c b/src/kernel/unit.c index c24902076..16901d34b 100644 --- a/src/kernel/unit.c +++ b/src/kernel/unit.c @@ -612,7 +612,7 @@ void usetcontact(unit * u, const unit * u2) a_add(&u->attribs, a_new(&at_contact))->data.v = (void *)u2; } -boolean ucontact(const unit * u, const unit * u2) +bool ucontact(const unit * u, const unit * u2) /* Pr�ft, ob u den Kontaktiere-Befehl zu u2 gesetzt hat. */ { attrib *ru; @@ -820,23 +820,27 @@ void leave_building(unit * u) } } -boolean can_leave(unit * u) +bool can_leave(unit * u) { + static int gamecookie = -1; static int rule_leave = -1; if (!u->building) { return true; } - if (rule_leave < 0) { + + if (rule_leave < 0 || gamecookie != global.cookie) { + gamecookie = global.cookie; rule_leave = get_param_int(global.parameters, "rules.move.owner_leave", 0); } + if (rule_leave && u->building && u == building_owner(u->building)) { return false; } return true; } -boolean leave(unit * u, boolean force) +bool leave(unit * u, bool force) { if (!force) { if (!can_leave(u)) { @@ -856,7 +860,7 @@ const struct race *urace(const struct unit *u) return u->race; } -boolean can_survive(const unit * u, const region * r) +bool can_survive(const unit * u, const region * r) { if ((fval(r->terrain, WALK_INTO) && (u->race->flags & RCF_WALK)) || (fval(r->terrain, SWIM_INTO) && (u->race->flags & RCF_SWIM)) @@ -891,7 +895,7 @@ void move_unit(unit * u, region * r, unit ** ulist) if (u->ship || u->building) { /* can_leave must be checked in travel_i */ #ifndef NDEBUG - boolean result = leave(u, false); + bool result = leave(u, false); assert(result); #else leave(u, false); @@ -1117,7 +1121,7 @@ void set_number(unit * u, int count) u->number = (unsigned short)count; } -boolean learn_skill(unit * u, skill_t sk, double chance) +bool learn_skill(unit * u, skill_t sk, double chance) { skill *sv = u->skills; if (chance < 1.0 && rng_int() % 10000 >= chance * 10000) @@ -1183,7 +1187,7 @@ skill *get_skill(const unit * u, skill_t sk) return NULL; } -boolean has_skill(const unit * u, skill_t sk) +bool has_skill(const unit * u, skill_t sk) { skill *sv = u->skills; while (sv != u->skills + u->skill_size) { @@ -1224,7 +1228,7 @@ static int item_modification(const unit * u, skill_t sk, int val) static int att_modification(const unit * u, skill_t sk) { double result = 0; - static boolean init = false; + static bool init = false; static const curse_type *skillmod_ct, *gbdream_ct, *worse_ct; curse *c; @@ -1283,7 +1287,7 @@ static int att_modification(const unit * u, skill_t sk) int get_modifier(const unit * u, skill_t sk, int level, const region * r, - boolean noitem) + bool noitem) { int bskill = level; int skill = bskill; diff --git a/src/kernel/unit.h b/src/kernel/unit.h index 7c9e3d8d3..727c476ba 100644 --- a/src/kernel/unit.h +++ b/src/kernel/unit.h @@ -71,6 +71,12 @@ extern "C" { extern int maxheroes(const struct faction *f); extern int countheroes(const struct faction *f); + typedef struct reservation { + struct reservation *next; + const struct resource_type *type; + int value; + } reservation; + typedef struct unit { struct unit *next; /* needs to be first entry, for region's unitlist */ struct unit *nextF; /* n�chste Einheit der Partei */ @@ -90,11 +96,7 @@ extern "C" { short skill_size; struct skill *skills; struct item *items; - struct reservation { - struct reservation *next; - const struct resource_type *type; - int value; - } *reservations; + reservation *reservations; /* orders */ struct order *orders; @@ -145,7 +147,7 @@ extern "C" { const struct potion_type *ugetpotionuse(const struct unit *u); /* benutzt u einein trank? */ void usetpotionuse(struct unit *u, const struct potion_type *p); /* u benutzt trank p (es darf halt nur einer pro runde) */ - boolean ucontact(const struct unit *u, const struct unit *u2); + bool ucontact(const struct unit *u, const struct unit *u2); void usetcontact(struct unit *u, const struct unit *c); struct unit *findnewunit(const struct region *r, const struct faction *f, @@ -155,7 +157,7 @@ extern "C" { extern struct skill *add_skill(struct unit *u, skill_t id); extern void remove_skill(struct unit *u, skill_t sk); extern struct skill *get_skill(const struct unit *u, skill_t id); - extern boolean has_skill(const unit * u, skill_t sk); + extern bool has_skill(const unit * u, skill_t sk); extern void set_level(struct unit *u, skill_t id, int level); extern int get_level(const struct unit *u, skill_t id); @@ -167,7 +169,7 @@ extern "C" { const struct region *r); extern int get_modifier(const struct unit *u, skill_t sk, int lvl, - const struct region *r, boolean noitem); + const struct region *r, bool noitem); extern int remove_unit(struct unit **ulist, struct unit *u); #define GIFT_SELF 1<<0 @@ -181,8 +183,8 @@ extern "C" { extern void write_unit_reference(const struct unit *u, struct storage *store); extern variant read_unit_reference(struct storage *store); - extern boolean leave(struct unit *u, boolean force); - extern boolean can_leave(struct unit *u); + extern bool leave(struct unit *u, bool force); + extern bool can_leave(struct unit *u); extern void u_set_building(struct unit * u, struct building * b); extern void u_set_ship(struct unit * u, struct ship * sh); @@ -191,7 +193,7 @@ extern "C" { extern void set_leftship(struct unit *u, struct ship *sh); extern struct ship *leftship(const struct unit *); - extern boolean can_survive(const struct unit *u, const struct region *r); + extern bool can_survive(const struct unit *u, const struct region *r); extern void move_unit(struct unit *u, struct region *target, struct unit **ulist); @@ -203,7 +205,7 @@ extern "C" { extern void u_setfaction(struct unit *u, struct faction *f); extern void set_number(struct unit *u, int count); - extern boolean learn_skill(struct unit *u, skill_t sk, double chance); + extern bool learn_skill(struct unit *u, skill_t sk, double chance); extern int invisible(const struct unit *target, const struct unit *viewer); extern void free_unit(struct unit *u); diff --git a/src/kernel/xmlreader.c b/src/kernel/xmlreader.c index c87f7449a..70da69915 100644 --- a/src/kernel/xmlreader.c +++ b/src/kernel/xmlreader.c @@ -51,7 +51,7 @@ without prior permission by the authors of Eressea. #include <limits.h> #include <string.h> -static boolean gamecode_enabled = false; +static bool gamecode_enabled = false; static building_type *bt_get_or_create(const char *name) { @@ -824,7 +824,7 @@ static weapon_type *xml_readweapon(xmlXPathContextPtr xpath, item_type * itype) assert(propValue != NULL); if (strcmp((const char *)propValue, "attack") == 0) { wtype->attack = - (boolean(*)(const struct troop *, const struct weapon_type *, + (bool(*)(const struct troop *, const struct weapon_type *, int *))fun; } else { log_error("unknown function type '%s' for item '%s'\n", (const char *)propValue, itype->rtype->_name[0]); @@ -938,7 +938,7 @@ static item_type *xml_readitem(xmlXPathContextPtr xpath, resource_type * rtype) struct order *))fun; } else if (strcmp((const char *)propValue, "canuse") == 0) { itype->canuse = - (boolean(*)(const struct unit *, const struct item_type *))fun; + (bool(*)(const struct unit *, const struct item_type *))fun; } else if (strcmp((const char *)propValue, "useonother") == 0) { itype->useonother = (int (*)(struct unit *, int, const struct item_type *, int, @@ -1893,7 +1893,7 @@ static int parse_races(xmlDocPtr doc) rc->age = (void (*)(struct unit *))fun; } else if (strcmp((const char *)propValue, "move") == 0) { rc->move_allowed = - (boolean(*)(const struct region *, const struct region *))fun; + (bool(*)(const struct region *, const struct region *))fun; } else if (strcmp((const char *)propValue, "itemdrop") == 0) { rc->itemdrop = (struct item * (*)(const struct race *, int))fun; } else if (strcmp((const char *)propValue, "initfamiliar") == 0) { @@ -2206,7 +2206,7 @@ static int parse_messages(xmlDocPtr doc) static void xml_readstrings(xmlXPathContextPtr xpath, xmlNodePtr * nodeTab, int nodeNr, - boolean names) + bool names) { int i; @@ -2274,7 +2274,7 @@ static int parse_strings(xmlDocPtr doc) static void xml_readprefixes(xmlXPathContextPtr xpath, xmlNodePtr * nodeTab, int nodeNr, - boolean names) + bool names) { int i; @@ -2344,7 +2344,7 @@ static int parse_main(xmlDocPtr doc) for (i = 0; i != nodes->nodeNr; ++i) { xmlNodePtr node = nodes->nodeTab[i]; xmlChar *propName = xmlGetProp(node, BAD_CAST "name"); - boolean disable = xml_bvalue(node, "disable", false); + bool disable = xml_bvalue(node, "disable", false); if (disable) { int k; @@ -2369,7 +2369,7 @@ static int parse_main(xmlDocPtr doc) for (i = 0; i != nodes->nodeNr; ++i) { xmlNodePtr node = nodes->nodeTab[i]; xmlChar *propName = xmlGetProp(node, BAD_CAST "name"); - boolean enable = xml_bvalue(node, "enable", true); + bool enable = xml_bvalue(node, "enable", true); enable_skill((const char *)propName, enable); xmlFree(propName); } diff --git a/src/modules/autoseed.c b/src/modules/autoseed.c index 9a0b5d233..4a004a0ab 100644 --- a/src/modules/autoseed.c +++ b/src/modules/autoseed.c @@ -104,7 +104,7 @@ static int count_demand(const region * r) static int recurse_regions(region * r, region_list ** rlist, - boolean(*fun) (const region * r)) + bool(*fun) (const region * r)) { if (!fun(r)) return 0; @@ -125,7 +125,7 @@ recurse_regions(region * r, region_list ** rlist, } } -static boolean f_nolux(const region * r) +static bool f_nolux(const region * r) { if (r->land && count_demand(r) != get_maxluxuries()) return true; @@ -337,7 +337,7 @@ static const terrain_type *preferred_terrain(const struct race *rc) #define MINFACTIONS 1 #define VOLCANO_CHANCE 100 -static boolean virgin_region(const region * r) +static bool virgin_region(const region * r) { direction_t d; if (r == NULL) diff --git a/src/modules/autoseed.h b/src/modules/autoseed.h index 254608803..923534020 100644 --- a/src/modules/autoseed.h +++ b/src/modules/autoseed.h @@ -26,7 +26,7 @@ extern "C" { const struct race *race; int bonus; int subscription; - boolean oldregions; + bool oldregions; struct alliance *allies; } newfaction; diff --git a/src/modules/gmcmd.c b/src/modules/gmcmd.c index 5f6caeb0c..78c26e235 100644 --- a/src/modules/gmcmd.c +++ b/src/modules/gmcmd.c @@ -157,7 +157,7 @@ static void gm_create(const void *tnext, struct unit *u, struct order *ord) } } -static boolean has_permission(const attrib * permissions, unsigned int key) +static bool has_permission(const attrib * permissions, unsigned int key) { return (find_key((attrib *) permissions->data.v, key) || find_key((attrib *) permissions->data.v, atoi36("master"))); @@ -600,7 +600,7 @@ faction *gm_addquest(const char *email, const char *name, int radius, plane *pl; watcher *w = calloc(sizeof(watcher), 1); region *center; - boolean invalid = false; + bool invalid = false; int minx, miny, maxx, maxy, cx, cy; int x; faction *f; @@ -716,7 +716,7 @@ plane *gm_addplane(int radius, unsigned int flags, const char *name) { region *center; plane *pl; - boolean invalid = false; + bool invalid = false; int minx, miny, maxx, maxy, cx, cy; int x; diff --git a/src/modules/wormhole.c b/src/modules/wormhole.c index d018c358f..4a4730df3 100644 --- a/src/modules/wormhole.c +++ b/src/modules/wormhole.c @@ -37,7 +37,7 @@ #include <assert.h> #include <stdlib.h> -static boolean good_region(const region * r) +static bool good_region(const region * r) { return (!fval(r, RF_CHAOTIC) && r->age > 30 && rplane(r) == NULL && r->units != NULL && r->land != NULL); diff --git a/src/modules/xecmd.c b/src/modules/xecmd.c deleted file mode 100644 index e45c611cd..000000000 --- a/src/modules/xecmd.c +++ /dev/null @@ -1,108 +0,0 @@ -/* vi: set ts=2: - +-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de> - | | Enno Rehling <enno@eressea.de> - | Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de> - | (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de> - | | Ingo Wilken <Ingo.Wilken@informatik.uni-oldenburg.de> - +-------------------+ Stefan Reich <reich@halbling.de> - - This program may not be used, modified or distributed - without prior permission by the authors of Eressea. -*/ - -#include <platform.h> -#include <kernel/config.h> - -#if XECMD_MODULE -#include "xecmd.h" - -#include <items/xerewards.h> - -#include "xecmd.h" - -/* kernel includes */ -#include <kernel/faction.h> -#include <kernel/item.h> -#include <kernel/message.h> -#include <kernel/order.h> -#include <kernel/region.h> -#include <kernel/save.h> -#include <kernel/ship.h> -#include <kernel/unit.h> - -/* util includes */ -#include <util/attrib.h> -#include <util/base36.h> -#include <util/parser.h> - -/* libc includes */ -#include <stdlib.h> -#include <string.h> -#include <assert.h> - -static void xe_givelaen(unit * u, struct order *ord) -{ - unit *u2 = getunitg(u->region, u->faction); - - if (!u2) { - ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "feedback_unit_not_found", - "")); - return; - } - i_change(&u2->items, olditemtype[I_LAEN], 5); -} - -static void xe_givepotion(unit * u, struct order *ord) -{ - unit *u2 = getunitg(u->region, u->faction); - - if (!u2) { - ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "feedback_unit_not_found", - "")); - return; - } - i_change(&u2->items, it_find("skillpotion"), 1); -} - -static void xe_giveballon(unit * u, struct order *ord) -{ - unit *u2 = getunitg(u->region, u->faction); - ship *sh; - - if (!u2) { - ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "feedback_unit_not_found", - "")); - return; - } - - sh = new_ship(st_find("balloon"), u2->region, u2->faction->locale); - sh->size = 5; - ship_setname(sh, "Xontormia-Ballon"); - leave(u2, true); - u_set_ship(u2, sh); -} - -int xecmd(unit * u, order * ord) -{ - faction *f = u->faction; - - if (a_find(f->attribs, &at_xontormiaexpress)) { - if (get_keyword(ord) == K_XE) { - param_t param; - - init_tokens(ord); - skip_token(); - param = findparam(getstrtoken(), f->locale); - if (param == P_XEPOTION) { - xe_givepotion(u, ord); - } else if (param == P_XEBALLOON) { - xe_giveballon(u, ord); - } else if (param == P_XELAEN) { - xe_givelaen(u, ord); - } - } - } - return 0; -} - -#endif diff --git a/src/modules/xecmd.h b/src/modules/xecmd.h deleted file mode 100644 index cf1beef00..000000000 --- a/src/modules/xecmd.h +++ /dev/null @@ -1,26 +0,0 @@ -/* vi: set ts=2: - +-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de> - | | Enno Rehling <enno@eressea.de> - | Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de> - | (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de> - | | Ingo Wilken <Ingo.Wilken@informatik.uni-oldenburg.de> - +-------------------+ Stefan Reich <reich@halbling.de> - - This program may not be used, modified or distributed - without prior permission by the authors of Eressea. -*/ - -#ifndef H_MOD_XECMD_H -#define H_MOD_XECMD_H -#ifdef __cplusplus -extern "C" { -#endif - -#if XECMD_MODULE - int xecmd(struct unit *u, struct order *ord); -#endif - -#ifdef __cplusplus -} -#endif -#endif diff --git a/src/platform.h b/src/platform.h index d72545cc6..7e1fd72b4 100644 --- a/src/platform.h +++ b/src/platform.h @@ -246,22 +246,8 @@ extern char *strdup(const char *s); # define unused(a) (a) #endif /* ghs || __GNUC__ || ..... */ -/**** **** - ** The Eressea boolean type ** - **** ****/ -#if defined(BOOLEAN) -# define boolean BOOLEAN -#else -typedef int boolean; /* not bool! wrong size. */ -#endif -#ifndef __cplusplus -# define false ((boolean)0) -# define true ((boolean)!false) -#endif -#ifdef __cplusplus -} -#endif - +#include "util/bool.h" + #ifndef INLINE_FUNCTION # define INLINE_FUNCTION #endif diff --git a/src/settings.h b/src/settings.h index fd0607625..552e4c1c9 100644 --- a/src/settings.h +++ b/src/settings.h @@ -44,14 +44,10 @@ #define SCORE_MODULE 1 #define MUSEUM_MODULE 1 #define ARENA_MODULE 1 -#define XECMD_MODULE 1 #define DUNGEON_MODULE 0 #define CHANGED_CROSSBOWS 0 /* use the WTF_ARMORPIERCING flag */ #undef GLOBAL_WARMING /* number of turns before global warming sets in */ -#define SIMPLE_COMBAT -#define SIMPLE_ESCAPE - #if defined(BINDINGS_LUABIND) # undef BINDINGS_TOLUA #elif defined(BINDINGS_TOLUA) diff --git a/src/tests.c b/src/tests.c index b269663dc..dd05c7d93 100644 --- a/src/tests.c +++ b/src/tests.c @@ -51,6 +51,7 @@ int RunAllTests(void) CuSuiteAddSuite(suite, get_building_suite()); CuSuiteAddSuite(suite, get_spell_suite()); CuSuiteAddSuite(suite, get_battle_suite()); + CuSuiteAddSuite(suite, get_ally_suite()); /* gamecode */ CuSuiteAddSuite(suite, get_market_suite()); CuSuiteAddSuite(suite, get_laws_suite()); @@ -137,6 +138,26 @@ ship * test_create_ship(region * r, const ship_type * stype) return s; } +ship_type * test_create_shiptype(const char ** names) +{ + ship_type * stype = (ship_type*)calloc(sizeof(ship_type), 1); + stype->name[0] = strdup(names[0]); + stype->name[1] = strdup(names[1]); + locale_setstring(default_locale, names[0], names[0]); + st_register(stype); + return stype; +} + +building_type * test_create_buildingtype(const char * name) +{ + building_type * btype = (building_type*)calloc(sizeof(building_type), 1); + btype->flags = BTF_NAMECHANGE; + btype->_name = strdup(name); + locale_setstring(default_locale, name, name); + bt_register(btype); + return btype; +} + item_type * test_create_itemtype(const char ** names) { resource_type * rtype; item_type * itype; @@ -159,16 +180,14 @@ void test_create_world(void) terrain_type *t_plain, *t_ocean; region *island[2]; int i; - building_type *btype; - ship_type *stype; item_type * itype; - const char * horses[2] = { "horse", "horse_p" }; + const char * names[] = { "horse", "horse_p", "boat", "boat_p" }; make_locale("de"); init_resources(); assert(!olditemtype[I_HORSE]); - itype = test_create_itemtype(horses); + itype = test_create_itemtype(names); olditemtype[I_HORSE] = itype; t_plain = test_create_terrain("plain", LAND_REGION | FOREST_REGION | WALK_INTO | CAVALRY_REGION); @@ -191,17 +210,8 @@ void test_create_world(void) test_create_race("human"); - btype = (building_type*)calloc(sizeof(building_type), 1); - btype->flags = BTF_NAMECHANGE; - btype->_name = strdup("castle"); - locale_setstring(default_locale, "castle", "castle"); - bt_register(btype); - - stype = (ship_type*)calloc(sizeof(ship_type), 1); - stype->name[0] = strdup("boat"); - stype->name[1] = strdup("boat_p"); - locale_setstring(default_locale, "boat", "boat"); - st_register(stype); + test_create_buildingtype("castle"); + test_create_shiptype(names+2); } int main(int argc, char ** argv) { diff --git a/src/tests.h b/src/tests.h index 2b6b91cce..15aa7a230 100644 --- a/src/tests.h +++ b/src/tests.h @@ -25,6 +25,7 @@ extern "C" { CuSuite *get_bsdstring_suite(void); CuSuite *get_functions_suite(void); CuSuite *get_umlaut_suite(void); + CuSuite *get_ally_suite(void); void test_cleanup(void); @@ -38,6 +39,9 @@ extern "C" { struct building * test_create_building(struct region * r, const struct building_type * btype); struct ship * test_create_ship(struct region * r, const struct ship_type * stype); struct item_type * test_create_itemtype(const char ** names); + struct ship_type *test_create_shiptype(const char **names); + struct building_type *test_create_buildingtype(const char *name); + int RunAllTests(void); #ifdef __cplusplus diff --git a/src/util/attrib.c b/src/util/attrib.c index 147b006b5..ef7674534 100644 --- a/src/util/attrib.c +++ b/src/util/attrib.c @@ -22,6 +22,8 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include "log.h" #include "storage.h" +#include <critbit.h> + #include <assert.h> #include <string.h> #include <stdlib.h> @@ -83,7 +85,7 @@ static attrib_type *at_find(unsigned int hk) } attrib *a_select(attrib * a, const void *data, - boolean(*compare) (const attrib *, const void *)) + bool(*compare) (const attrib *, const void *)) { while (a && !compare(a, data)) a = a->next; @@ -261,6 +263,16 @@ int a_age(attrib ** p) return (*p != NULL); } +static critbit_tree cb_deprecated = { 0 }; + +void at_deprecate(const char * name, int (*reader)(attrib *, void *, struct storage *)) +{ + char buffer[64]; + size_t len = strlen(name); + len = cb_new_kv(name, len, &reader, sizeof(reader), buffer); + cb_insert(&cb_deprecated, buffer, len); +} + int a_read(struct storage *store, attrib ** attribs, void *owner) { int key, retval = AT_READ_OK; @@ -275,25 +287,38 @@ int a_read(struct storage *store, attrib ** attribs, void *owner) key = __at_hashkey(zText); while (key != -1) { + int (*reader)(attrib *, void *, struct storage *) = 0; attrib_type *at = at_find(key); - if (!at) { - fprintf(stderr, "attribute hash: %d (%s)\n", key, zText); - assert(at || !"attribute not registered"); + attrib * na = 0; + + if (at) { + reader = at->read; + na = a_new(at); + } else { + const void * kv; + cb_find_prefix(&cb_deprecated, zText, strlen(zText)+1, &kv, 1, 0); + if (kv) { + cb_get_kv(kv, &reader, sizeof(reader)); + } else { + fprintf(stderr, "attribute hash: %d (%s)\n", key, zText); + assert(at || !"attribute not registered"); + } } - if (at->read) { - attrib *na = a_new(at); - int i = at->read(na, owner, store); - switch (i) { - case AT_READ_OK: - a_add(attribs, na); - break; - case AT_READ_FAIL: - retval = AT_READ_FAIL; - a_free(na); - break; - default: - assert(!"invalid return value"); - break; + if (reader) { + int i = reader(na, owner, store); + if (na) { + switch (i) { + case AT_READ_OK: + a_add(attribs, na); + break; + case AT_READ_FAIL: + retval = AT_READ_FAIL; + a_free(na); + break; + default: + assert(!"invalid return value"); + break; + } } } else { assert(!"fehler: keine laderoutine f�r attribut"); diff --git a/src/util/attrib.h b/src/util/attrib.h index a2805e8c7..6096a4cbe 100644 --- a/src/util/attrib.h +++ b/src/util/attrib.h @@ -61,9 +61,10 @@ extern "C" { } attrib_type; extern void at_register(attrib_type * at); + extern void at_deprecate(const char * name, int (*reader)(attrib *, void *, struct storage *)); extern attrib *a_select(attrib * a, const void *data, - boolean(*compare) (const attrib *, const void *)); + bool(*compare) (const attrib *, const void *)); extern attrib *a_find(attrib * a, const attrib_type * at); extern const attrib *a_findc(const attrib * a, const attrib_type * at); extern attrib *a_add(attrib ** pa, attrib * at); diff --git a/src/util/bool.h b/src/util/bool.h new file mode 100644 index 000000000..0bdebc9ec --- /dev/null +++ b/src/util/bool.h @@ -0,0 +1,15 @@ +#if HAVE_STDBOOL_H +# include <stdbool.h> +#else +# if ! HAVE__BOOL +# ifdef __cplusplus +typedef bool _Bool; +# else +typedef unsigned char _Bool; +# endif +# endif +# define bool _Bool +# define false 0 +# define true 1 +# define __bool_true_false_are_defined 1 +#endif diff --git a/src/util/console.c b/src/util/console.c index 28586f704..b850678c5 100644 --- a/src/util/console.c +++ b/src/util/console.c @@ -23,6 +23,10 @@ #define LUA_MAXINPUT 512 #endif +#if LUA_VERSION_NUM >= 502 +#define lua_strlen(L, idx) lua_rawlen(L, idx) +#endif + #if defined(LUA_USE_READLINE) #include <stdio.h> #include <readline/readline.h> @@ -109,7 +113,7 @@ static int report(lua_State * L, int status) static int traceback(lua_State * L) { - lua_getfield(L, LUA_GLOBALSINDEX, "debug"); + lua_getglobal(L, "debug"); if (!lua_istable(L, -1)) { lua_pop(L, 1); return 1; @@ -149,8 +153,7 @@ static int docall(lua_State * L, int narg, int clear) static const char *get_prompt(lua_State * L, int firstline) { const char *p = NULL; - lua_pushstring(L, firstline ? "_PROMPT" : "_PROMPT2"); - lua_rawget(L, LUA_GLOBALSINDEX); + lua_getglobal(L, firstline ? "_PROMPT" : "_PROMPT2"); p = lua_tostring(L, -1); if (p == NULL) p = (firstline ? PROMPT : PROMPT2); diff --git a/src/util/eventbus.c b/src/util/eventbus.c deleted file mode 100644 index d4c7829fd..000000000 --- a/src/util/eventbus.c +++ /dev/null @@ -1,57 +0,0 @@ -#include <platform.h> -#include "eventbus.h" - -/* -** first iteration. it is slow, and a proof of the concept - the simplest -** thing that would work, a.k.a. should be refectored when required. -*/ - -typedef struct listener { - struct listener *next; - event_handler callback; - event_arg_free destroy; - void *sender; - char *event; - void *arguments; -} listener; - -static listener *listeners; - -void eventbus_fire(void *sender, const char *event, void *args) -{ - listener *lst = listeners; - while (lst) { - int i = strcmp(lst->event, event); - if (i > 0) - break; - if (i == 0) { - if (!lst->sender || lst->sender == sender) { - lst->callback(sender, event, args); - } - } - lst = lst->next; - } -} - -void -eventbus_register(void *sender, const char *event, event_handler cb, - event_arg_free arg_free, void *args) -{ - listener *lst; - listener **lstp = &listeners; - while (*lstp) { - lst = *lstp; - if (strcmp(lst->event, event) >= 0) { - break; - } - lstp = &lst->next; - } - lst = malloc(sizeof(listener)); - lst->sender = sender; - lst->arguments = args; - lst->callback = cb; - lst->destroy = arg_free; - lst->event = strdup(event); - lst->next = *lstp; - *lstp = lst; -} diff --git a/src/util/eventbus.h b/src/util/eventbus.h deleted file mode 100644 index 6bd266e51..000000000 --- a/src/util/eventbus.h +++ /dev/null @@ -1,29 +0,0 @@ -/* vi: set ts=2: - +-------------------+ - | | Enno Rehling <enno@eressea.de> - | Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de> - | (c) 1998 - 2010 | Christian Schlittchen <corwin@amber.kn-bremen.de> - | | - +-------------------+ - - This program may not be used, modified or distributed - without prior permission by the authors of Eressea. -*/ - -#ifndef H_UTIL_EVTBUS -#define H_UTIL_EVTBUS - -#ifdef __cplusplus -extern "C" { -#endif - - typedef void (*event_handler) (void *, const char *, void *); - typedef void (*event_arg_free) (void *); - void eventbus_fire(void *sender, const char *event, void *args); - void eventbus_register(void *sender, const char *event, - event_handler callback, event_arg_free arg_free, void *args); - -#ifdef __cplusplus -} -#endif -#endif diff --git a/src/util/filereader.c b/src/util/filereader.c index 1b6f79488..12ef3add4 100644 --- a/src/util/filereader.c +++ b/src/util/filereader.c @@ -42,9 +42,9 @@ INLINE_FUNCTION int eatwhite(const char *ptr, size_t * total_size) static const char *getbuf_latin1(FILE * F) { - boolean cont = false; + bool cont = false; char quote = 0; - boolean comment = false; + bool comment = false; char *cp = fbuf; char *tail = lbuf + MAXLINE - 2; @@ -57,8 +57,8 @@ static const char *getbuf_latin1(FILE * F) while (*bp && isxspace(*(unsigned char *)bp)) ++bp; /* eatwhite */ - comment = (boolean) (comment && cont); - quote = (boolean) (quote && cont); + comment = (bool) (comment && cont); + quote = (bool) (quote && cont); if (tail[1] == 0) { /* we read he maximum number of bytes! */ @@ -178,9 +178,9 @@ static const char *getbuf_latin1(FILE * F) static const char *getbuf_utf8(FILE * F) { - boolean cont = false; + bool cont = false; char quote = 0; - boolean comment = false; + bool comment = false; char *cp = fbuf; char *tail = lbuf + MAXLINE - 2; @@ -195,8 +195,8 @@ static const char *getbuf_utf8(FILE * F) eatwhite(bp, &white); /* decoding errors will get caught later on, don't have to check */ bp += white; - comment = (boolean) (comment && cont); - quote = (boolean) (quote && cont); + comment = (bool) (comment && cont); + quote = (bool) (quote && cont); if (tail[1] == 0) { /* we read the maximum number of bytes! */ diff --git a/src/util/listbox.c b/src/util/listbox.c index 0b7403860..ab3dd9eb9 100644 --- a/src/util/listbox.c +++ b/src/util/listbox.c @@ -75,7 +75,7 @@ list_selection *do_selection(list_selection * sel, const char *title, void (*perform) (list_selection *, void *), void *data) { WINDOW *wn; - boolean update = true; + bool update = true; list_selection *s; list_selection *top = sel; list_selection *current = top; diff --git a/src/util/log.c b/src/util/log.c index 40222bdd8..0c14a6bd7 100644 --- a/src/util/log.c +++ b/src/util/log.c @@ -253,7 +253,7 @@ void log_error(const char *format, ...) } } -void _log_info(const char *format, ...) +void log_info(const char *format, ...) { const char * prefix = "INFO"; const int mask = LOG_CPINFO; diff --git a/src/util/os.c b/src/util/os.c index 1278e0f7c..5a7220e7d 100644 --- a/src/util/os.c +++ b/src/util/os.c @@ -2,20 +2,17 @@ #if defined(WIN32) #include <direct.h> -#else /* */ +#else /* WIN32 */ +#include <sys/types.h> #include <sys/stat.h> -#endif /* */ - int os_mkdir(const char *path, int mode) -{ +#endif /* WIN32 */ +int os_mkdir(const char *path, int mode) +{ #ifdef WIN32 - mode = mode; - return _mkdir(path); - + mode = mode; + return _mkdir(path); #else /* POSIX is our last hope */ - return mkdir(path, (mode_t) mode); - -#endif /* */ -} - - + return mkdir(path, (mode_t) mode); +#endif /* WIN32 */ +} diff --git a/src/util/parser.c b/src/util/parser.c index 46d6ba8a8..3634ba541 100644 --- a/src/util/parser.c +++ b/src/util/parser.c @@ -76,7 +76,7 @@ void parser_popstate(void) state = new_state; } -boolean parser_end(void) +bool parser_end(void) { eatwhitespace_c(&state->current_token); return *state->current_token == 0; @@ -126,7 +126,7 @@ const char *parse_token(const char **str) static char lbuf[MAXTOKENSIZE]; /* STATIC_RESULT: used for return, not across calls */ char *cursor = lbuf; char quotechar = 0; - boolean escape = false; + bool escape = false; const char *ctoken = *str; assert(ctoken); @@ -135,7 +135,7 @@ const char *parse_token(const char **str) while (*ctoken && cursor - lbuf < MAXTOKENSIZE - 1) { ucs4_t ucs; size_t len; - boolean copy = false; + bool copy = false; unsigned char utf8_character = *(unsigned char *)ctoken; if (~utf8_character & 0x80) { diff --git a/src/util/parser.h b/src/util/parser.h index dc1ab3717..521987174 100644 --- a/src/util/parser.h +++ b/src/util/parser.h @@ -19,7 +19,7 @@ extern "C" { extern const char *parse_token(const char **str); extern void parser_pushstate(void); extern void parser_popstate(void); - extern boolean parser_end(void); + extern bool parser_end(void); extern const char *getstrtoken(void); #ifdef __cplusplus diff --git a/src/util/rand.c b/src/util/rand.c index ac02786b7..b26bf0c12 100644 --- a/src/util/rand.c +++ b/src/util/rand.c @@ -61,7 +61,7 @@ int ntimespprob(int n, double p, double mod) return count; } -boolean chance(double x) +bool chance(double x) { if (x >= 1.0) return true; diff --git a/src/util/rand.h b/src/util/rand.h index 2c9d6e96b..9223923b9 100644 --- a/src/util/rand.h +++ b/src/util/rand.h @@ -29,7 +29,7 @@ extern "C" { /* in rand.c: */ extern double normalvariate(double mu, double sigma); extern int ntimespprob(int n, double p, double mod); - extern boolean chance(double x); + extern bool chance(double x); #ifdef __cplusplus } diff --git a/src/util/translation.c b/src/util/translation.c index 411b8aee0..e3493f434 100644 --- a/src/util/translation.c +++ b/src/util/translation.c @@ -186,7 +186,7 @@ static const char *parse_symbol(opstack ** stack, const char *in, * result goes on the stack */ { - boolean braces = false; + bool braces = false; char symbol[32]; char *cp = symbol; /* current position */ @@ -239,8 +239,8 @@ static const char *parse_string(opstack ** stack, const char *in, const char *ic = in; char *oc = buffer; /* mode flags */ - boolean f_escape = false; - boolean bDone = false; + bool f_escape = false; + bool bDone = false; variant var; while (*ic && !bDone) { @@ -310,7 +310,7 @@ static const char *parse_int(opstack ** stack, const char *in) { int k = 0; int vz = 1; - boolean ok = false; + bool ok = false; variant var; do { switch (*in) { diff --git a/src/util/xml.c b/src/util/xml.c index 297d8c89b..31a1bb542 100644 --- a/src/util/xml.c +++ b/src/util/xml.c @@ -43,9 +43,9 @@ int xml_ivalue(xmlNodePtr node, const char *name, int dflt) return i; } -boolean xml_bvalue(xmlNodePtr node, const char *name, boolean dflt) +bool xml_bvalue(xmlNodePtr node, const char *name, bool dflt) { - boolean result = dflt; + bool result = dflt; xmlChar *propValue = xmlGetProp(node, BAD_CAST name); if (propValue != NULL) { if (strcmp((const char *)propValue, "no") == 0) @@ -57,10 +57,10 @@ boolean xml_bvalue(xmlNodePtr node, const char *name, boolean dflt) else if (strcmp((const char *)propValue, "true") == 0) result = true; else if (strcmp((const char *)propValue, "1") == 0) { - log_warning("boolean value is '1': %s::%s\n", node->name, name); + log_warning("bool value is '1': %s::%s\n", node->name, name); result = true; } else if (strcmp((const char *)propValue, "0") == 0) { - log_warning("boolean value is '0': %s::%s\n", node->name, name); + log_warning("bool value is '0': %s::%s\n", node->name, name); result = false; } xmlFree(propValue); diff --git a/src/util/xml.h b/src/util/xml.h index f14cbedeb..42b9178bb 100644 --- a/src/util/xml.h +++ b/src/util/xml.h @@ -25,7 +25,7 @@ extern "C" { extern int read_xml(const char *filename, const char *catalog); extern double xml_fvalue(xmlNodePtr node, const char *name, double dflt); extern int xml_ivalue(xmlNodePtr node, const char *name, int dflt); - extern boolean xml_bvalue(xmlNodePtr node, const char *name, boolean dflt); + extern bool xml_bvalue(xmlNodePtr node, const char *name, bool dflt); const xmlChar *xml_i(double number);