diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 000000000..9cebe6d6d --- /dev/null +++ b/.editorconfig @@ -0,0 +1,26 @@ +# EditorConfig is awesome: http://EditorConfig.org + +# top-most EditorConfig file +root = true + +# Unix-style newlines with a newline ending every file +[*] +end_of_line = lf +insert_final_newline = true + +# 4 space indentation +[*.{c,h,lua}] +indent_style = space +indent_size = 4 + +[*.{xml,json}] +charset = utf-8 + +# Tab indentation (no size specified) +[Makefile] +indent_style = tab + +# Matches exact files +[.travis.yml] +indent_style = space +indent_size = 2 diff --git a/res/adamantium.xml b/res/adamantium.xml index d5cdd4fae..cc1cedadc 100644 --- a/res/adamantium.xml +++ b/res/adamantium.xml @@ -3,7 +3,7 @@ - + @@ -13,7 +13,7 @@ - + @@ -26,7 +26,7 @@ - + diff --git a/res/buildings/castle-2.xml b/res/buildings/castle-2.xml index a54957415..593e9ae5e 100644 --- a/res/buildings/castle-2.xml +++ b/res/buildings/castle-2.xml @@ -3,22 +3,22 @@ - + - + - + - + - + - + diff --git a/res/buildings/castle.xml b/res/buildings/castle.xml index 9a63d7dc8..253f49811 100644 --- a/res/buildings/castle.xml +++ b/res/buildings/castle.xml @@ -2,25 +2,25 @@ - + - + - + - + - + - + - + diff --git a/res/core/armor/chainmail.xml b/res/core/armor/chainmail.xml index 81152f89e..b03221b35 100644 --- a/res/core/armor/chainmail.xml +++ b/res/core/armor/chainmail.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/armor/laenmail.xml b/res/core/armor/laenmail.xml index bdcf6b7e1..0e1411945 100644 --- a/res/core/armor/laenmail.xml +++ b/res/core/armor/laenmail.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/armor/laenshield.xml b/res/core/armor/laenshield.xml index f5eb2d783..8a9d6d5c3 100644 --- a/res/core/armor/laenshield.xml +++ b/res/core/armor/laenshield.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/armor/plate.xml b/res/core/armor/plate.xml index eb10f6359..a22064e90 100644 --- a/res/core/armor/plate.xml +++ b/res/core/armor/plate.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/armor/rustychainmail.xml b/res/core/armor/rustychainmail.xml index a52b4db7b..b46380634 100644 --- a/res/core/armor/rustychainmail.xml +++ b/res/core/armor/rustychainmail.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/armor/rustyshield.xml b/res/core/armor/rustyshield.xml index 4c34f7ee1..56a8abe5a 100644 --- a/res/core/armor/rustyshield.xml +++ b/res/core/armor/rustyshield.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/armor/shield.xml b/res/core/armor/shield.xml index 9a72baf9a..b0ee7de3a 100644 --- a/res/core/armor/shield.xml +++ b/res/core/armor/shield.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/common/buildings.xml b/res/core/common/buildings.xml index 63ac3e650..423e90deb 100644 --- a/res/core/common/buildings.xml +++ b/res/core/common/buildings.xml @@ -66,7 +66,7 @@ - + @@ -76,7 +76,7 @@ - + @@ -86,7 +86,7 @@ - + @@ -98,7 +98,7 @@ - + @@ -139,7 +139,7 @@ - + @@ -149,7 +149,7 @@ - + @@ -159,7 +159,7 @@ - + diff --git a/res/core/common/construction.xml b/res/core/common/construction.xml index 95dcb6a33..089ddfe1c 100644 --- a/res/core/common/construction.xml +++ b/res/core/common/construction.xml @@ -1,10 +1,10 @@ - + - + diff --git a/res/core/common/items.xml b/res/core/common/items.xml index c8910e695..6afd220ff 100644 --- a/res/core/common/items.xml +++ b/res/core/common/items.xml @@ -143,7 +143,7 @@ - + diff --git a/res/core/common/potions.xml b/res/core/common/potions.xml index f444e5a94..84b1e5f52 100644 --- a/res/core/common/potions.xml +++ b/res/core/common/potions.xml @@ -7,7 +7,7 @@ - + @@ -18,7 +18,7 @@ - + @@ -29,7 +29,7 @@ - + @@ -40,7 +40,7 @@ - + @@ -51,7 +51,7 @@ - + @@ -64,7 +64,7 @@ - + @@ -77,7 +77,7 @@ - + @@ -90,7 +90,7 @@ - + @@ -103,7 +103,7 @@ - + @@ -116,7 +116,7 @@ - + @@ -129,7 +129,7 @@ - + @@ -142,7 +142,7 @@ - + @@ -155,7 +155,7 @@ - + @@ -169,7 +169,7 @@ - + @@ -184,7 +184,7 @@ - + diff --git a/res/core/resources/cart.xml b/res/core/resources/cart.xml index af3860c9c..17dbdcb41 100644 --- a/res/core/resources/cart.xml +++ b/res/core/resources/cart.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/resources/horse.xml b/res/core/resources/horse.xml index abf6d856d..53699c696 100644 --- a/res/core/resources/horse.xml +++ b/res/core/resources/horse.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/resources/iron.xml b/res/core/resources/iron.xml index 94dbc6390..7bc4cb428 100644 --- a/res/core/resources/iron.xml +++ b/res/core/resources/iron.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/resources/laen.xml b/res/core/resources/laen.xml index efb13c5ed..571026a0a 100644 --- a/res/core/resources/laen.xml +++ b/res/core/resources/laen.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/resources/log.xml b/res/core/resources/log.xml index c017682fc..012fe9a20 100644 --- a/res/core/resources/log.xml +++ b/res/core/resources/log.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/resources/mallorn.xml b/res/core/resources/mallorn.xml index e5c01506b..2d301758e 100644 --- a/res/core/resources/mallorn.xml +++ b/res/core/resources/mallorn.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/resources/mallornseed.xml b/res/core/resources/mallornseed.xml index 1c7c1a800..7a5a0310f 100644 --- a/res/core/resources/mallornseed.xml +++ b/res/core/resources/mallornseed.xml @@ -1,6 +1,6 @@ - + diff --git a/res/core/resources/seed.xml b/res/core/resources/seed.xml index 2193fb8c8..99f5f5804 100644 --- a/res/core/resources/seed.xml +++ b/res/core/resources/seed.xml @@ -1,6 +1,6 @@ - + diff --git a/res/core/resources/stone.xml b/res/core/resources/stone.xml index eed2fd2df..c227dcc5c 100644 --- a/res/core/resources/stone.xml +++ b/res/core/resources/stone.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/ships.xml b/res/core/ships.xml index 0ce254328..fc87bc3d3 100644 --- a/res/core/ships.xml +++ b/res/core/ships.xml @@ -2,28 +2,28 @@ - + - + - + - + @@ -39,7 +39,7 @@ - + @@ -53,7 +53,7 @@ - + @@ -69,7 +69,7 @@ - + diff --git a/res/core/weapons/axe.xml b/res/core/weapons/axe.xml index 7ee77b21e..80a872ad7 100644 --- a/res/core/weapons/axe.xml +++ b/res/core/weapons/axe.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/bow.xml b/res/core/weapons/bow.xml index c64392966..4fb9b2000 100644 --- a/res/core/weapons/bow.xml +++ b/res/core/weapons/bow.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/catapult.xml b/res/core/weapons/catapult.xml index 08dc83457..e05c5a025 100644 --- a/res/core/weapons/catapult.xml +++ b/res/core/weapons/catapult.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/crossbow.xml b/res/core/weapons/crossbow.xml index 318628b81..c7bf4715d 100644 --- a/res/core/weapons/crossbow.xml +++ b/res/core/weapons/crossbow.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/greatbow.xml b/res/core/weapons/greatbow.xml index 542bd41a8..10b270e55 100644 --- a/res/core/weapons/greatbow.xml +++ b/res/core/weapons/greatbow.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/greatsword.xml b/res/core/weapons/greatsword.xml index 481ff680c..cd48b8296 100644 --- a/res/core/weapons/greatsword.xml +++ b/res/core/weapons/greatsword.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/halberd.xml b/res/core/weapons/halberd.xml index bf3fb4af7..5025f4793 100644 --- a/res/core/weapons/halberd.xml +++ b/res/core/weapons/halberd.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/laensword.xml b/res/core/weapons/laensword.xml index 31ec8b9e6..3053d5f1b 100644 --- a/res/core/weapons/laensword.xml +++ b/res/core/weapons/laensword.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/lance.xml b/res/core/weapons/lance.xml index 1271c48f9..abbb7f31f 100644 --- a/res/core/weapons/lance.xml +++ b/res/core/weapons/lance.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/mallornbow.xml b/res/core/weapons/mallornbow.xml index f61ea8e97..abdcc4810 100644 --- a/res/core/weapons/mallornbow.xml +++ b/res/core/weapons/mallornbow.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/mallorncrossbow.xml b/res/core/weapons/mallorncrossbow.xml index fb7be26c0..385720d8c 100644 --- a/res/core/weapons/mallorncrossbow.xml +++ b/res/core/weapons/mallorncrossbow.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/mallornlance.xml b/res/core/weapons/mallornlance.xml index 88973f3e0..0186143e4 100644 --- a/res/core/weapons/mallornlance.xml +++ b/res/core/weapons/mallornlance.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/mallornspear.xml b/res/core/weapons/mallornspear.xml index 8c3782e4c..66d41a943 100644 --- a/res/core/weapons/mallornspear.xml +++ b/res/core/weapons/mallornspear.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/rep_crossbow.xml b/res/core/weapons/rep_crossbow.xml index 1e550a190..66e3f9fc2 100644 --- a/res/core/weapons/rep_crossbow.xml +++ b/res/core/weapons/rep_crossbow.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/rustyaxe.xml b/res/core/weapons/rustyaxe.xml index 5399de62d..2ff19570c 100644 --- a/res/core/weapons/rustyaxe.xml +++ b/res/core/weapons/rustyaxe.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/rustygreatsword.xml b/res/core/weapons/rustygreatsword.xml index ac1385b11..7f21cce17 100644 --- a/res/core/weapons/rustygreatsword.xml +++ b/res/core/weapons/rustygreatsword.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/rustyhalberd.xml b/res/core/weapons/rustyhalberd.xml index 4f237b989..c1b1f69a9 100644 --- a/res/core/weapons/rustyhalberd.xml +++ b/res/core/weapons/rustyhalberd.xml @@ -2,7 +2,7 @@ - + diff --git a/res/core/weapons/rustysword.xml b/res/core/weapons/rustysword.xml index f73dcd6e2..2a76c109b 100644 --- a/res/core/weapons/rustysword.xml +++ b/res/core/weapons/rustysword.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/spear.xml b/res/core/weapons/spear.xml index c6479707a..32a79b9a2 100644 --- a/res/core/weapons/spear.xml +++ b/res/core/weapons/spear.xml @@ -1,7 +1,7 @@ - + diff --git a/res/core/weapons/sword.xml b/res/core/weapons/sword.xml index 0d3830e2e..4bd2ebdb1 100644 --- a/res/core/weapons/sword.xml +++ b/res/core/weapons/sword.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/armor/chainmail.xml b/res/e3a/armor/chainmail.xml index 39743d754..509df07e6 100644 --- a/res/e3a/armor/chainmail.xml +++ b/res/e3a/armor/chainmail.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/armor/laenmail.xml b/res/e3a/armor/laenmail.xml index d3b1dd533..f03add574 100644 --- a/res/e3a/armor/laenmail.xml +++ b/res/e3a/armor/laenmail.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/armor/laenshield.xml b/res/e3a/armor/laenshield.xml index 1ce6216b2..8d003bccc 100644 --- a/res/e3a/armor/laenshield.xml +++ b/res/e3a/armor/laenshield.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/armor/plate.xml b/res/e3a/armor/plate.xml index 550e83173..29cabbf1a 100644 --- a/res/e3a/armor/plate.xml +++ b/res/e3a/armor/plate.xml @@ -2,7 +2,7 @@ - + diff --git a/res/e3a/armor/rustychainmail.xml b/res/e3a/armor/rustychainmail.xml index ac2628c62..361564c76 100644 --- a/res/e3a/armor/rustychainmail.xml +++ b/res/e3a/armor/rustychainmail.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/armor/rustyshield.xml b/res/e3a/armor/rustyshield.xml index 2becae180..d9d8a54ef 100644 --- a/res/e3a/armor/rustyshield.xml +++ b/res/e3a/armor/rustyshield.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/armor/scale.xml b/res/e3a/armor/scale.xml index 809d08bca..7039b4008 100644 --- a/res/e3a/armor/scale.xml +++ b/res/e3a/armor/scale.xml @@ -2,7 +2,7 @@ - + diff --git a/res/e3a/armor/shield.xml b/res/e3a/armor/shield.xml index 9b4ad9174..5770711e2 100644 --- a/res/e3a/armor/shield.xml +++ b/res/e3a/armor/shield.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/armor/towershield.xml b/res/e3a/armor/towershield.xml index 5a7edcabe..e80c03523 100644 --- a/res/e3a/armor/towershield.xml +++ b/res/e3a/armor/towershield.xml @@ -2,7 +2,7 @@ - + diff --git a/res/e3a/buildings.xml b/res/e3a/buildings.xml index 231596dc6..8ca30d27d 100644 --- a/res/e3a/buildings.xml +++ b/res/e3a/buildings.xml @@ -3,24 +3,24 @@ - + - + + + + + + + - - - - - - - + diff --git a/res/e3a/items.xml b/res/e3a/items.xml index 706bd0d67..7d7e6b286 100644 --- a/res/e3a/items.xml +++ b/res/e3a/items.xml @@ -71,7 +71,7 @@ - + diff --git a/res/e3a/resources/iron.xml b/res/e3a/resources/iron.xml index 3856c045d..b245da358 100644 --- a/res/e3a/resources/iron.xml +++ b/res/e3a/resources/iron.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/resources/stone.xml b/res/e3a/resources/stone.xml index 854003c86..746b79c21 100644 --- a/res/e3a/resources/stone.xml +++ b/res/e3a/resources/stone.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/ships.xml b/res/e3a/ships.xml index b8c5f0197..291900a3b 100644 --- a/res/e3a/ships.xml +++ b/res/e3a/ships.xml @@ -10,7 +10,7 @@ - + @@ -20,7 +20,7 @@ - + @@ -35,7 +35,7 @@ - + @@ -50,7 +50,7 @@ - + @@ -66,7 +66,7 @@ - + @@ -75,7 +75,7 @@ - + @@ -85,7 +85,7 @@ - + @@ -93,7 +93,7 @@ - + @@ -103,7 +103,7 @@ - + @@ -113,7 +113,7 @@ - + @@ -125,7 +125,7 @@ - + @@ -136,7 +136,7 @@ - + diff --git a/res/e3a/weapons/crossbow.xml b/res/e3a/weapons/crossbow.xml index 57535a070..7b2ed743c 100644 --- a/res/e3a/weapons/crossbow.xml +++ b/res/e3a/weapons/crossbow.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/weapons/greatbow.xml b/res/e3a/weapons/greatbow.xml index ba91f54de..7f08427c8 100644 --- a/res/e3a/weapons/greatbow.xml +++ b/res/e3a/weapons/greatbow.xml @@ -6,7 +6,7 @@ - + diff --git a/res/e3a/weapons/greatsword.xml b/res/e3a/weapons/greatsword.xml index 5fc1c9042..5a199321d 100644 --- a/res/e3a/weapons/greatsword.xml +++ b/res/e3a/weapons/greatsword.xml @@ -4,7 +4,7 @@ --> - + diff --git a/res/e3a/weapons/halberd.xml b/res/e3a/weapons/halberd.xml index edb933701..2c11b62fc 100644 --- a/res/e3a/weapons/halberd.xml +++ b/res/e3a/weapons/halberd.xml @@ -5,7 +5,7 @@ - + diff --git a/res/e3a/weapons/laensword.xml b/res/e3a/weapons/laensword.xml index 13ebbf03e..50f824e8c 100644 --- a/res/e3a/weapons/laensword.xml +++ b/res/e3a/weapons/laensword.xml @@ -4,7 +4,7 @@ --> - + diff --git a/res/e3a/weapons/mallorncrossbow.xml b/res/e3a/weapons/mallorncrossbow.xml index 920ae553f..86991bc10 100644 --- a/res/e3a/weapons/mallorncrossbow.xml +++ b/res/e3a/weapons/mallorncrossbow.xml @@ -1,7 +1,7 @@ - + diff --git a/res/e3a/weapons/mallornlance.xml b/res/e3a/weapons/mallornlance.xml index 6355f5780..1fcad08c8 100644 --- a/res/e3a/weapons/mallornlance.xml +++ b/res/e3a/weapons/mallornlance.xml @@ -2,7 +2,7 @@ - + diff --git a/res/e3a/weapons/rustygreatsword.xml b/res/e3a/weapons/rustygreatsword.xml index 818fac553..607f16a6a 100644 --- a/res/e3a/weapons/rustygreatsword.xml +++ b/res/e3a/weapons/rustygreatsword.xml @@ -4,7 +4,7 @@ --> - + diff --git a/res/e3a/weapons/rustyhalberd.xml b/res/e3a/weapons/rustyhalberd.xml index bab849b49..ed25d5db7 100644 --- a/res/e3a/weapons/rustyhalberd.xml +++ b/res/e3a/weapons/rustyhalberd.xml @@ -5,7 +5,7 @@ - + diff --git a/res/ships/boat.xml b/res/ships/boat.xml index 91852de92..551fea702 100644 --- a/res/ships/boat.xml +++ b/res/ships/boat.xml @@ -10,7 +10,7 @@ - + diff --git a/scripts/eressea/e3/init.lua b/scripts/eressea/e3/init.lua index 9acda1093..e376eaadc 100644 --- a/scripts/eressea/e3/init.lua +++ b/scripts/eressea/e3/init.lua @@ -6,7 +6,7 @@ eressea.log.debug("rules for game E3") return { require('eressea'), require('eressea.xmasitems'), - require('eressea.markets'), + -- require('eressea.markets'), require('eressea.frost'), require('eressea.ents') } diff --git a/scripts/eressea/e4/init.lua b/scripts/eressea/e4/init.lua index e5e617c55..32c0b8498 100644 --- a/scripts/eressea/e4/init.lua +++ b/scripts/eressea/e4/init.lua @@ -5,7 +5,7 @@ eressea.log.debug("rules for game E4") return { require('eressea'), - require('eressea.markets'), + -- require('eressea.markets'), require('eressea.frost'), require('eressea.ents') } diff --git a/scripts/eressea/xmasitems.lua b/scripts/eressea/xmasitems.lua index 4f8a20767..b31691d72 100644 --- a/scripts/eressea/xmasitems.lua +++ b/scripts/eressea/xmasitems.lua @@ -15,6 +15,23 @@ local function error_message(msg, u, ord) return -1 end + +local function usepotion_message(u, type) + msg = message.create("usepotion") + msg:set_unit("unit", u) + msg:set_resource("potion", type) + return msg +end + +function use_stardust(u, amount) + local p = u.region:get_resource("peasant") + p = math.ceil(1.5 * p) + u.region:set_resource("peasant", p) + local msg = usepotion_message(u, "stardust") + msg:send_region(u.region) + return 1 +end + function use_snowglobe(u, amount, token, ord) local transform = { ocean = "glacier", @@ -59,9 +76,7 @@ function use_xmastree(u, amount) local trees = u.region:get_resource("tree") u.region:set_key("xm06", true) u.region:set_resource("tree", 10+trees) - local msg = message.create("usepotion") - msg:set_unit("unit", u) - msg:set_resource("potion", "xmastree") + local msg = usepotion_message(u, "xmastree") msg:send_region(u.region) return amount end diff --git a/scripts/tests/e3/rules.lua b/scripts/tests/e3/rules.lua index 323103e73..2cba83f21 100644 --- a/scripts/tests/e3/rules.lua +++ b/scripts/tests/e3/rules.lua @@ -4,6 +4,14 @@ module("tests.e3.e3features", package.seeall, lunit.testcase) local settings +-- use the C implementation in market.c, because the Lua +-- module is wrong (https://bugs.eressea.de/view.php?id=2225) +local function process_markets() + -- markets = require("eressea.markets") + -- markets.update() + eressea.process.markets() +end + local function set_rule(key, value) if value==nil then eressea.settings.set(key, settings[key]) @@ -403,8 +411,7 @@ function test_market_regions() -- if i am the only trader around, i should be getting all the herbs from all 7 regions local r, u, b, herbnames, luxurynames, herbtable, luxurytable = market_fixture() - - eressea.process.markets() + process_markets() test_items(u, herbtable, 10) test_items(u, luxurytable, 5) @@ -420,9 +427,8 @@ function test_multiple_markets() b2.working = true reset_items(u2) u2.building = b2 - - eressea.process.markets() + process_markets() for _, i in pairs(luxurytable) do assert_equal(5, u1:get_item(i)+u2:get_item(i), "not enough " .. i ) end @@ -432,12 +438,11 @@ function test_multiple_markets() assert_equal(5, u1:get_item('silk')) -- uncontested end - function test_market() local r = region.create(0, 0, "plain") local f1 = faction.create("market2@eressea.de", "human", "de") local u1 = unit.create(f1, r, 1) - + local b = building.create(r, "market") eressea.settings.set("rules.peasants.growth", "0") @@ -469,7 +474,7 @@ function test_market() end reset_items() b.size = 1 - eressea.process.markets() + process_markets() assert_equal(0, u1:get_item("h0")) b.size = 10 @@ -477,38 +482,38 @@ function test_market() reset_items() r:set_resource("peasant", 2100) - eressea.process.markets() + process_markets() assert_equal(5, u1:get_item("h0")) assert_equal(3, u1:get_item("balm")) reset_items() r:set_resource("peasant", 1049) - eressea.process.markets() + process_markets() assert_equal(2, u1:get_item("h0")) assert_equal(1, u1:get_item("balm")) reset_items() r:set_resource("peasant", 550) - eressea.process.markets() + process_markets() assert_equal(2, u1:get_item("h0")) assert_equal(1, u1:get_item("balm")) reset_items() r:set_resource("peasant", 549) - eressea.process.markets() + process_markets() assert_equal(1, u1:get_item("h0")) assert_equal(1, u1:get_item("balm")) reset_items() r:set_resource("peasant", 50) - eressea.process.markets() + process_markets() assert_equal(1, u1:get_item("h0")) assert_equal(1, u1:get_item("balm")) reset_items() r:set_resource("peasant", 49) - eressea.process.markets() + process_markets() assert_equal(0, u1:get_item("h0")) r:set_resource("peasant", 1050) diff --git a/scripts/tests/xmas.lua b/scripts/tests/xmas.lua index 7b4490d7a..e1cd4753b 100644 --- a/scripts/tests/xmas.lua +++ b/scripts/tests/xmas.lua @@ -82,3 +82,18 @@ function test_xmastree() r = use_tree("plain") assert_equal(10, r:get_resource("tree")) end + +function test_stardust() + -- fix random peasant changes: + eressea.settings.set("rules.economy.repopulate_maximum", 0) + local r = region.create(0, 0, "plain") + r:set_resource("peasant", 10) + local f = faction.create("noreply@eressea.de", "human", "de") + local u = unit.create(f, r, 5) + u:add_item("stardust", 1) + u:clear_orders() + u:add_order("BENUTZEN 1 Sternenstaub") + process_orders() + assert_equal(15, r:get_resource("peasant")) + assert_equal(0, u:get_item('stardust')) +end diff --git a/src/bind_region.c b/src/bind_region.c index 519502162..a28b94c07 100644 --- a/src/bind_region.c +++ b/src/bind_region.c @@ -458,6 +458,7 @@ static int tolua_region_create(lua_State * L) const terrain_type *terrain = get_terrain(tname); region *r, *result; if (!terrain) { + log_error("lua: region.create with invalid terrain %s", tname); return 0; } @@ -481,6 +482,7 @@ static int tolua_region_create(lua_State * L) tolua_pushusertype(L, result, TOLUA_CAST "region"); return 1; } + log_error("lua: region.create with invalid terrain %s", tname); return 0; } diff --git a/src/creport.c b/src/creport.c index ab5813e8a..6ba9f5e39 100644 --- a/src/creport.c +++ b/src/creport.c @@ -1160,7 +1160,8 @@ int seemode, FILE * F) } } if (cs) { - const char *bname = mkname("border", b->type->name(b, r, f, GF_PURE)); + const char *bname = border_name(b, r, f, GF_PURE); + bname = mkname("border", bname); fprintf(F, "GRENZE %d\n", ++g); fprintf(F, "\"%s\";typ\n", LOC(default_locale, bname)); fprintf(F, "%d;richtung\n", d); diff --git a/src/kernel/build.c b/src/kernel/build.c index f3c74bf95..97e5e84d0 100644 --- a/src/kernel/build.c +++ b/src/kernel/build.c @@ -849,7 +849,6 @@ build_building(unit * u, const building_type * btype, int id, int want, order * b->size += built; if (b->type->maxsize > 0 && b->size > b->type->maxsize) { - // this seems to be okay for a watch, but is not okay for an academy or harbour log_error("build: %s has size=%d, maxsize=%d", buildingname(b), b->size, b->type->maxsize); } fset(b, BLD_EXPANDED); diff --git a/src/kernel/building.c b/src/kernel/building.c index f0e46cc7e..e7c60ea9a 100644 --- a/src/kernel/building.c +++ b/src/kernel/building.c @@ -132,7 +132,7 @@ int buildingcapacity(const building * b) } return b->size * b->type->capacity; } - if (b->size >= b->type->maxsize) { + if (building_finished(b)) { if (b->type->maxcapacity >= 0) { return b->type->maxcapacity; } @@ -648,15 +648,20 @@ buildingtype_exists(const region * r, const building_type * bt, bool working) building *b; for (b = rbuildings(r); b; b = b->next) { - if (b->type == bt && b->size >= bt->maxsize && (!working || fval(b, BLD_WORKING))) + if (b->type == bt && (!working || fval(b, BLD_WORKING)) && building_finished(b)) { return true; + } } return false; } +bool building_finished(const struct building *b) { + return b->size >= b->type->maxsize; +} + bool building_is_active(const struct building *b) { - return b && fval(b, BLD_WORKING) && b->size >= b->type->maxsize; + return b && fval(b, BLD_WORKING) && building_finished(b); } building *active_building(const unit *u, const struct building_type *btype) { diff --git a/src/kernel/building.h b/src/kernel/building.h index 766242c4a..52b715c59 100644 --- a/src/kernel/building.h +++ b/src/kernel/building.h @@ -92,15 +92,7 @@ extern "C" { const struct building *b, int bsize); bool in_safe_building(struct unit *u1, struct unit *u2); - /* buildingt => building_type - * Name => locale_string(name) - * MaxGroesse => levels - * MinBauTalent => construction->minskill - * Kapazitaet => capacity, maxcapacity - * Materialien => construction->materials - * UnterSilber, UnterSpezialTyp, UnterSpezial => maintenance - * per_size => !maintenance->fixed - */ + #define BFL_NONE 0x00 #define BLD_MAINTAINED 0x01 /* vital maintenance paid for */ #define BLD_WORKING 0x02 /* full maintenance paid, it works */ @@ -138,6 +130,7 @@ extern "C" { struct region *r, const struct locale *lang); int build_building(struct unit *u, const struct building_type *typ, int id, int size, struct order *ord); + bool building_finished(const struct building *b); /* Alte Gebäudetypen: */ @@ -173,10 +166,6 @@ extern "C" { bool building_is_active(const struct building *b); struct building *active_building(const struct unit *u, const struct building_type *btype); -#ifdef WDW_PYRAMID - extern int wdw_pyramid_level(const struct building *b); -#endif - extern const char *buildingname(const struct building *b); extern const char *building_getname(const struct building *b); diff --git a/src/kernel/connection.c b/src/kernel/connection.c index d9f1871d0..f1e5c4b6d 100644 --- a/src/kernel/connection.c +++ b/src/kernel/connection.c @@ -677,3 +677,7 @@ int read_borders(gamedata *data) } return 0; } + +const char * border_name(const connection *co, const struct region * r, const struct faction * f, int flags) { + return (co->type->name) ? co->type->name(co, r, f, flags) : co->type->__name; +} diff --git a/src/kernel/connection.h b/src/kernel/connection.h index 2c0800849..7eef0f52a 100644 --- a/src/kernel/connection.h +++ b/src/kernel/connection.h @@ -148,6 +148,9 @@ extern "C" { /* game-specific callbacks */ void(*border_convert_cb) (struct connection * con, struct attrib * attr); + const char * border_name(const struct connection *co, + const struct region * r, const struct faction * f, int flags); + #ifdef __cplusplus } #endif diff --git a/src/kernel/item.c b/src/kernel/item.c index 1265a101d..182e71fbe 100644 --- a/src/kernel/item.c +++ b/src/kernel/item.c @@ -1188,6 +1188,7 @@ static item *default_spoil(const struct race *rc, int size) } static void free_itype(item_type *itype) { + assert(itype); free(itype->construction); free(itype->_appearance[0]); free(itype->_appearance[1]); @@ -1195,14 +1196,14 @@ static void free_itype(item_type *itype) { } static void free_wtype(weapon_type *wtype) { + assert(wtype); free(wtype->damage[0]); free(wtype->damage[1]); free(wtype); } -int free_rtype_cb(const void * match, const void * key, size_t keylen, void *cbdata) { - resource_type *rtype; - cb_get_kv(match, &rtype, sizeof(rtype)); +void free_rtype(resource_type *rtype) { + assert(rtype); if (rtype->wtype) { free_wtype(rtype->wtype); } @@ -1214,6 +1215,12 @@ int free_rtype_cb(const void * match, const void * key, size_t keylen, void *cbd } free(rtype->_name); free(rtype); +} + +int free_rtype_cb(const void * match, const void * key, size_t keylen, void *cbdata) { + resource_type *rtype; + cb_get_kv(match, &rtype, sizeof(rtype)); + free_rtype(rtype); return 0; } diff --git a/src/kernel/save.c b/src/kernel/save.c index fd82bed96..2379db877 100644 --- a/src/kernel/save.c +++ b/src/kernel/save.c @@ -1676,6 +1676,7 @@ int read_game(gamedata *data) { if (b->type == bt_lighthouse) { r->flags |= RF_LIGHTHOUSE; } + // repairs, bug 2221: if (b->type->maxsize>0 && b->size>b->type->maxsize) { log_error("building too big: %s (%s size %d of %d), fixing.", buildingname(b), b->type->_name, b->size, b->type->maxsize); diff --git a/src/kernel/spell.c b/src/kernel/spell.c index ebd5d44ef..ec651bd79 100644 --- a/src/kernel/spell.c +++ b/src/kernel/spell.c @@ -36,8 +36,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. static critbit_tree cb_spells; quicklist * spells; -static void free_spell_cb(void *cbdata) { - spell *sp = (spell *)cbdata; +static void free_spell(spell *sp) { free(sp->syntax); free(sp->parameter); free(sp->sname); @@ -45,6 +44,10 @@ static void free_spell_cb(void *cbdata) { free(sp); } +static void free_spell_cb(void *cbdata) { + free_spell((spell *)cbdata); +} + void free_spells(void) { cb_clear(&cb_spells); ql_foreach(spells, free_spell_cb); diff --git a/src/kernel/unit.c b/src/kernel/unit.c index e41e5b006..09b3d80a9 100644 --- a/src/kernel/unit.c +++ b/src/kernel/unit.c @@ -1044,7 +1044,7 @@ struct building *inside_building(const struct unit *u) if (!u->building) { return NULL; } - else if (u->building->size < u->building->type->maxsize) { + else if (!building_finished(u->building)) { /* Gebaeude noch nicht fertig */ return NULL; } diff --git a/src/kernel/version.h b/src/kernel/version.h index 7ef7d9c36..4aab16f5f 100644 --- a/src/kernel/version.h +++ b/src/kernel/version.h @@ -10,7 +10,7 @@ without prior permission by the authors of Eressea. */ -#define INTPAK_VERSION 329 /* in binary, ints can get packed */ +#define INTPAK_VERSION 329 /* in binary, ints can get packed. starting with E2/572 */ #define NOZEROIDS_VERSION 330 /* 2008-05-16 zero is not a valid ID for anything (including factions) */ #define NOBORDERATTRIBS_VERSION 331 /* 2008-05-17 connection::attribs has been moved to userdata */ #define UIDHASH_VERSION 332 /* 2008-05-22 borders use the region.uid to store */ diff --git a/src/kernel/xmlreader.c b/src/kernel/xmlreader.c index f4e5fd751..da8014d67 100644 --- a/src/kernel/xmlreader.c +++ b/src/kernel/xmlreader.c @@ -169,7 +169,7 @@ construction ** consPtr) con->skill = sk; con->maxsize = xml_ivalue(node, "maxsize", -1); con->minskill = xml_ivalue(node, "minskill", -1); - con->reqsize = xml_ivalue(node, "reqsize", -1); + con->reqsize = xml_ivalue(node, "reqsize", 1); con->defense_bonus = xml_ivalue(node, "defense_bonus", 0); con->close_combat_bonus = xml_ivalue(node, "close_combat_bonus", 0); con->ranged_bonus = xml_ivalue(node, "ranged_bonus", 0); diff --git a/src/move.c b/src/move.c index e7ca523b5..6c5950c1f 100644 --- a/src/move.c +++ b/src/move.c @@ -1758,7 +1758,7 @@ unit *owner_buildingtyp(const region * r, const building_type * bt) for (b = rbuildings(r); b; b = b->next) { owner = building_owner(b); if (b->type == bt && owner != NULL) { - if (b->size >= bt->maxsize) { + if (building_finished(b)) { return owner; } } diff --git a/src/report.c b/src/report.c index 15c5f1b2c..84b1291b2 100644 --- a/src/report.c +++ b/src/report.c @@ -915,7 +915,7 @@ static void describe(stream *out, const seen_region * sr, faction * f) for (b = get_borders(r, r2); b;) { struct edge *e = edges; bool transparent = b->type->transparent(b, f); - const char *name = b->type->name(b, r, f, GF_DETAILED | GF_ARTICLE); + const char *name = border_name(b, r, f, GF_DETAILED | GF_ARTICLE); if (!transparent) see[d] = false; @@ -1898,7 +1898,7 @@ const faction * f) } } - if (b->size < b->type->maxsize) { + if (!building_finished(b)) { bytes = (int)strlcpy(bufp, LOC(lang, "nr_building_inprogress"), size); if (wrptr(&bufp, &size, bytes) != 0) WARN_STATIC_BUFFER(); diff --git a/src/reports.c b/src/reports.c index 379b35429..48a01d9a8 100644 --- a/src/reports.c +++ b/src/reports.c @@ -1543,21 +1543,21 @@ int write_reports(faction * f, time_t ltime) log_debug("Reports for %s:", factionname(f)); for (rtype = report_types; rtype != NULL; rtype = rtype->next) { if (f->options & rtype->flag) { - int error; + int error = 0; do { char filename[32]; char path[MAX_PATH]; sprintf(filename, "%d-%s.%s", turn, factionid(f), rtype->extension); join_path(reportpath(), filename, path, sizeof(path)); - error = 0; + errno = 0; if (rtype->write(path, &ctx, encoding) == 0) { gotit = true; } if (errno) { char zText[64]; - log_warning("retrying, error %d during %s report for faction %s", error, rtype->extension, factionname(f)); - sprintf(zText, "waiting %u seconds before we retry", backup / 1000); + log_warning("retrying, error %d during %s report for faction %s", errno, rtype->extension, factionname(f)); + sprintf(zText, "waiting %u seconds before we retry", backup); perror(zText); _sleep(backup); if (backup < maxbackup) { diff --git a/src/reports.test.c b/src/reports.test.c index e00e50a8b..29adb0915 100644 --- a/src/reports.test.c +++ b/src/reports.test.c @@ -317,6 +317,12 @@ static void setup_spell_fixture(spell_fixture * spf) { spf->sbe = spellbook_get(spf->spb, spf->sp); } +static void cleanup_spell_fixture(spell_fixture *spf) { + spellbook_clear(spf->spb); + free(spf->spb); + test_cleanup(); +} + static void check_spell_syntax(CuTest *tc, char *msg, spell_fixture *spell, char *syntax) { stream strm; char buf[1024]; @@ -405,9 +411,8 @@ static void test_write_spell_syntax(CuTest *tc) { set_parameter(spell, "kc+"); check_spell_syntax(tc, "kc+", &spell, " ZAUBERE \"Testzauber\" ( REGION | EINHEIT [ ...] | SCHIFF \n [ ...] | BURG [ ...] )"); - spellbook_clear(spell.spb); - free(spell.spb); - test_cleanup(); + + cleanup_spell_fixture(&spell); } CuSuite *get_reports_suite(void) diff --git a/src/spells.c b/src/spells.c index b93c373ae..1da440df2 100644 --- a/src/spells.c +++ b/src/spells.c @@ -975,7 +975,7 @@ static int sp_blessstonecircle(castorder * co) return 0; } - if (b->size < b->type->maxsize) { + if (!building_finished(b)) { ADDMSG(&mage->faction->msgs, msg_feedback(mage, co->order, "error_notcomplete", "building", b)); return 0; @@ -4502,11 +4502,11 @@ int sp_icastle(castorder * co) if (type == bt_illusion) { b->size = (rng_int() % (int)((power * power) + 1) * 10); } - else if (type->maxsize == -1) { - b->size = ((rng_int() % (int)(power)) + 1) * 5; + else if (type->maxsize >0) { + b->size = type->maxsize; } else { - b->size = type->maxsize; + b->size = ((rng_int() % (int)(power)) + 1) * 5; } if (type->name == NULL) { diff --git a/src/wormhole.c b/src/wormhole.c index 36e04e9e0..916c0509d 100644 --- a/src/wormhole.c +++ b/src/wormhole.c @@ -149,8 +149,7 @@ make_wormhole(const building_type * bt_wormhole, region * r1, region * r2) attrib *a2 = a_add(&b2->attribs, a_new(&at_wormhole)); a1->data.v = b2->region; a2->data.v = b1->region; - b1->size = bt_wormhole->maxsize; - b2->size = bt_wormhole->maxsize; + b1->size = b2->size = bt_wormhole->maxcapacity * bt_wormhole->capacity; ADDMSG(&r1->msgs, msg_message("wormhole_appear", "region", r1)); ADDMSG(&r2->msgs, msg_message("wormhole_appear", "region", r2)); }