(svn r17730) -Codechange: do not cache the source of a packet in the cargo list. It's only used for (some) GUI/NewGRF purposes so precalculating it costs more than calculating when it's actually used.

This commit is contained in:
rubidium 2009-10-06 21:06:26 +00:00
parent 1cab0dbc1d
commit 31acc42b21
2 changed files with 1 additions and 4 deletions

View File

@ -217,7 +217,6 @@ void CargoList::InvalidateCache()
this->empty = this->packets.empty();
this->count = 0;
this->feeder_share = 0;
this->source = INVALID_STATION;
this->days_in_transit = 0;
if (this->empty) return;
@ -229,5 +228,4 @@ void CargoList::InvalidateCache()
this->feeder_share += (*it)->feeder_share;
}
this->days_in_transit = dit / count;
this->source = (*packets.begin())->source;
}

View File

@ -166,7 +166,6 @@ private:
bool empty; ///< Cache for whether this list is empty or not
uint count; ///< Cache for the number of cargo entities
Money feeder_share; ///< Cache for the feeder share
StationID source; ///< Cache for the source of the packet
uint days_in_transit; ///< Cache for the number of days in transit
public:
@ -225,7 +224,7 @@ public:
*/
FORCEINLINE StationID Source() const
{
return this->source;
return this->Empty() ? INVALID_STATION : this->packets.front()->source;;
}
/**