File diff r12404:d58b2d050240 → r12405:ba094e765533
src/ai/api/ai_cargo.cpp
Show inline comments
 
@@ -8,19 +8,19 @@
 
#include "../../core/alloc_func.hpp"
 
#include "../../core/bitmath_func.hpp"
 
#include "../../newgrf_cargo.h"
 

	
 
/* static */ bool AICargo::IsValidCargo(CargoID cargo_type)
 
{
 
	return (cargo_type < NUM_CARGO && ::GetCargo(cargo_type)->IsValid());
 
	return (cargo_type < NUM_CARGO && ::CargoSpec::Get(cargo_type)->IsValid());
 
}
 

	
 
/* static */ char *AICargo::GetCargoLabel(CargoID cargo_type)
 
{
 
	if (!IsValidCargo(cargo_type)) return NULL;
 
	const CargoSpec *cargo = ::GetCargo(cargo_type);
 
	const CargoSpec *cargo = ::CargoSpec::Get(cargo_type);
 

	
 
	/* cargo->label is a uint32 packing a 4 character non-terminated string,
 
	 * like "PASS", "COAL", "OIL_". New ones can be defined by NewGRFs */
 
	char *cargo_label = MallocT<char>(sizeof(cargo->label) + 1);
 
	for (uint i = 0; i < sizeof(cargo->label); i++) {
 
		cargo_label[i] = GB(cargo->label, (uint8)(sizeof(cargo->label) - i - 1) * 8, 8);
 
@@ -29,13 +29,13 @@
 
	return cargo_label;
 
}
 

	
 
/* static */ bool AICargo::IsFreight(CargoID cargo_type)
 
{
 
	if (!IsValidCargo(cargo_type)) return false;
 
	const CargoSpec *cargo = ::GetCargo(cargo_type);
 
	const CargoSpec *cargo = ::CargoSpec::Get(cargo_type);
 
	return cargo->is_freight;
 
}
 

	
 
/* static */ bool AICargo::HasCargoClass(CargoID cargo_type, CargoClass cargo_class)
 
{
 
	if (!IsValidCargo(cargo_type)) return false;
 
@@ -43,13 +43,13 @@
 
}
 

	
 
/* static */ AICargo::TownEffect AICargo::GetTownEffect(CargoID cargo_type)
 
{
 
	if (!IsValidCargo(cargo_type)) return TE_NONE;
 

	
 
	return (AICargo::TownEffect)GetCargo(cargo_type)->town_effect;
 
	return (AICargo::TownEffect)CargoSpec::Get(cargo_type)->town_effect;
 
}
 

	
 
/* static */ Money AICargo::GetCargoIncome(CargoID cargo_type, uint32 distance, uint32 days_in_transit)
 
{
 
	if (!IsValidCargo(cargo_type)) return -1;
 
	return ::GetTransportedGoodsIncome(1, distance, Clamp(days_in_transit * 2 / 5, 0, 255), cargo_type);