From 37748a3152bb184e0547af5d67bfcb22a7c97dcb Mon Sep 17 00:00:00 2001 From: rubidium Date: Sun, 8 Jul 2007 19:54:51 +0000 Subject: (svn r10483) -Codechange: add support for callbacks to manipulate the building chance of farm fields and chopping chance for lumber mills. --- src/industry_cmd.cpp | 26 +++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) (limited to 'src/industry_cmd.cpp') diff --git a/src/industry_cmd.cpp b/src/industry_cmd.cpp index eab7aee83..0ba2c0750 100644 --- a/src/industry_cmd.cpp +++ b/src/industry_cmd.cpp @@ -929,11 +929,6 @@ void PlantRandomFarmField(const Industry *i) if (tile != INVALID_TILE) PlantFarmField(tile, i->index); } -static void MaybePlantFarmField(const Industry *i) -{ - if (CHANCE16(1, 8)) PlantRandomFarmField(i); -} - /** * Search callback function for ChopLumberMillTrees * @param tile to test @@ -998,10 +993,23 @@ static void ProduceIndustryGoods(Industry *i) i->produced_cargo_waiting[0] = min(0xffff, i->produced_cargo_waiting[0] + i->production_rate[0]); i->produced_cargo_waiting[1] = min(0xffff, i->produced_cargo_waiting[1] + i->production_rate[1]); - if (indbehav & INDUSTRYBEH_PLANT_FIELDS) { - MaybePlantFarmField(i); - } else if ((indbehav & INDUSTRYBEH_CUT_TREES) && (i->counter & 0x1FF) == 0) { - ChopLumberMillTrees(i); + if ((indbehav & INDUSTRYBEH_PLANT_FIELDS) != 0) { + bool plant; + if (HASBIT(indsp->callback_flags, CBM_IND_SPECIAL_EFFECT)) { + plant = (GetIndustryCallback(CBID_INDUSTRY_SPECIAL_EFFECT, Random(), 0, i, i->type, i->xy) != 0); + } else { + plant = CHANCE16(1, 8); + } + + if (plant) PlantRandomFarmField(i); + } + if ((indbehav & INDUSTRYBEH_CUT_TREES) != 0) { + bool cut = ((i->counter & 0x1FF) == 0); + if (HASBIT(indsp->callback_flags, CBM_IND_SPECIAL_EFFECT)) { + cut = (GetIndustryCallback(CBID_INDUSTRY_SPECIAL_EFFECT, 0, 1, i, i->type, i->xy) != 0); + } + + if (cut) ChopLumberMillTrees(i); } } } -- cgit v1.2.3-54-g00ecf