From b5b7b489ce9f81dc97e52ef27b2b43cc36ad14a9 Mon Sep 17 00:00:00 2001 From: peter1138 Date: Thu, 12 Apr 2007 19:33:05 +0000 Subject: (svn r9617) -Codechange: Implement callback for cargo profit calculation --- src/economy.cpp | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'src') diff --git a/src/economy.cpp b/src/economy.cpp index 751a43c09..ac15a7ac5 100644 --- a/src/economy.cpp +++ b/src/economy.cpp @@ -1134,6 +1134,23 @@ int32 GetTransportedGoodsIncome(uint num_pieces, uint dist, byte transit_days, C const CargoSpec *cs = GetCargo(cargo_type); byte f; + /* Use callback to calculate cargo profit, if available */ + if (HASBIT(cs->callback_mask, CBM_CARGO_PROFIT_CALC)) { + uint32 var18 = min(dist, 0xFFFF) | (min(num_pieces, 0xFF) << 16) | (transit_days << 24); + uint16 callback = GetCargoCallback(CBID_CARGO_PROFIT_CALC, 0, var18, cs); + if (callback != CALLBACK_FAILED) { + int result = GB(callback, 0, 14); + + /* Simulate a 15 bit signed value */ + if (HASBIT(callback, 14)) result = 0x4000 - result; + + /* "The result should be a signed multiplier that gets multiplied + * by the amount of cargo moved and the price factor, then gets + * divided by 8192." */ + return result * num_pieces * _cargo_payment_rates[cargo_type] / 8192; + } + } + /* zero the distance if it's the bank and very short transport. */ if (_opt.landscape == LT_TEMPERATE && cs->label == 'VALU' && dist < 10) dist = 0; -- cgit v1.2.3-70-g09d2