summaryrefslogtreecommitdiff
path: root/src/cargotype.cpp
diff options
context:
space:
mode:
authorsmatz <smatz@openttd.org>2009-07-16 19:00:13 +0000
committersmatz <smatz@openttd.org>2009-07-16 19:00:13 +0000
commit1f29e38b8372484d51d852b89fc957eb53635ecb (patch)
treeda4a251ac74e87e72a2857233069790f991914f6 /src/cargotype.cpp
parentb6889daf8d11b083358a26eea3f633942e2e50e4 (diff)
downloadopenttd-1f29e38b8372484d51d852b89fc957eb53635ecb.tar.xz
(svn r16849) -Codechange: replace GetCargo() by CargoSpec::Get()
Diffstat (limited to 'src/cargotype.cpp')
-rw-r--r--src/cargotype.cpp24
1 files changed, 13 insertions, 11 deletions
diff --git a/src/cargotype.cpp b/src/cargotype.cpp
index 8216fbb65..cf1acb45e 100644
--- a/src/cargotype.cpp
+++ b/src/cargotype.cpp
@@ -11,7 +11,7 @@
#include "table/strings.h"
#include "table/cargo_const.h"
-CargoSpec _cargo[NUM_CARGO];
+CargoSpec CargoSpec::cargo[NUM_CARGO];
/* Bitmask of cargo types available */
uint32 _cargo_mask;
@@ -22,8 +22,8 @@ void SetupCargoForClimate(LandscapeID l)
assert(l < lengthof(_default_climate_cargo));
/* Reset and disable all cargo types */
- memset(_cargo, 0, sizeof(_cargo));
- for (CargoID i = 0; i < lengthof(_cargo); i++) _cargo[i].bitnum = INVALID_CARGO;
+ memset(CargoSpec::cargo, 0, sizeof(CargoSpec::cargo));
+ for (CargoID i = 0; i < lengthof(CargoSpec::cargo); i++) CargoSpec::Get(i)->bitnum = INVALID_CARGO;
_cargo_mask = 0;
@@ -33,8 +33,9 @@ void SetupCargoForClimate(LandscapeID l)
/* Bzzt: check if cl is just an index into the cargo table */
if (cl < lengthof(_default_cargo)) {
/* Copy the indexed cargo */
- _cargo[i] = _default_cargo[cl];
- if (_cargo[i].bitnum != INVALID_CARGO) SetBit(_cargo_mask, i);
+ CargoSpec *cargo = CargoSpec::Get(i);
+ *cargo = _default_cargo[cl];
+ if (cargo->bitnum != INVALID_CARGO) SetBit(_cargo_mask, i);
continue;
}
@@ -42,7 +43,7 @@ void SetupCargoForClimate(LandscapeID l)
* the label matches */
for (uint j = 0; j < lengthof(_default_cargo); j++) {
if (_default_cargo[j].label == cl) {
- _cargo[i] = _default_cargo[j];
+ *CargoSpec::Get(i) = _default_cargo[j];
/* Populate the available cargo mask */
SetBit(_cargo_mask, i);
@@ -55,9 +56,10 @@ void SetupCargoForClimate(LandscapeID l)
CargoID GetCargoIDByLabel(CargoLabel cl)
{
- for (CargoID c = 0; c < lengthof(_cargo); c++) {
- if (_cargo[c].bitnum == INVALID_CARGO) continue;
- if (_cargo[c].label == cl) return c;
+ for (CargoID c = 0; c < lengthof(CargoSpec::cargo); c++) {
+ CargoSpec *cargo = CargoSpec::Get(c);
+ if (cargo->bitnum == INVALID_CARGO) continue;
+ if (cargo->label == cl) return c;
}
/* No matching label was found, so it is invalid */
@@ -73,8 +75,8 @@ CargoID GetCargoIDByBitnum(uint8 bitnum)
{
if (bitnum == INVALID_CARGO) return CT_INVALID;
- for (CargoID c = 0; c < lengthof(_cargo); c++) {
- if (_cargo[c].bitnum == bitnum) return c;
+ for (CargoID c = 0; c < lengthof(CargoSpec::cargo); c++) {
+ if (CargoSpec::Get(c)->bitnum == bitnum) return c;
}
/* No matching label was found, so it is invalid */