summaryrefslogtreecommitdiff
path: root/src/newgrf.cpp
diff options
context:
space:
mode:
authorfrosch <frosch@openttd.org>2010-09-25 21:59:22 +0000
committerfrosch <frosch@openttd.org>2010-09-25 21:59:22 +0000
commita54b711dc10bf34929ec080d6507db0067455c64 (patch)
tree781f44d387defc0975828e1d7b7859e752c21fdd /src/newgrf.cpp
parent611e9862266e9982ef58cec7c3151744488e5883 (diff)
downloadopenttd-a54b711dc10bf34929ec080d6507db0067455c64.tar.xz
(svn r20848) -Add: _loaded_newgrf_features.used_liveries to keep track which liveries are used by some vehicle resp. which are not used at all.
Diffstat (limited to 'src/newgrf.cpp')
-rw-r--r--src/newgrf.cpp29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/newgrf.cpp b/src/newgrf.cpp
index b20b297a0..a63696ba1 100644
--- a/src/newgrf.cpp
+++ b/src/newgrf.cpp
@@ -46,6 +46,7 @@
#include "smallmap_gui.h"
#include "genworld.h"
#include "gui.h"
+#include "vehicle_func.h"
#include "table/strings.h"
#include "table/build_industry.h"
@@ -7062,6 +7063,7 @@ void ResetNewGRFData()
_misc_grf_features = 0;
_loaded_newgrf_features.has_2CC = false;
+ _loaded_newgrf_features.used_liveries = 1 << LS_DEFAULT;
_loaded_newgrf_features.has_newhouses = false;
_loaded_newgrf_features.has_newindustries = false;
_loaded_newgrf_features.shore = SHORE_REPLACE_NONE;
@@ -7261,6 +7263,33 @@ static void FinaliseEngineArray()
e->info.string_id = STR_NEWGRF_INVALID_ENGINE;
}
}
+
+ /* Skip wagons, there livery is defined via the engine */
+ if (e->type != VEH_TRAIN || e->u.rail.railveh_type != RAILVEH_WAGON) {
+ LiveryScheme ls = GetEngineLiveryScheme(e->index, INVALID_ENGINE, NULL);
+ SetBit(_loaded_newgrf_features.used_liveries, ls);
+ /* Note: For ships and roadvehicles we assume that they cannot be refitted between passenger and freight */
+
+ if (e->type == VEH_TRAIN) {
+ SetBit(_loaded_newgrf_features.used_liveries, LS_FREIGHT_WAGON);
+ switch (ls) {
+ case LS_STEAM:
+ case LS_DIESEL:
+ case LS_ELECTRIC:
+ case LS_MONORAIL:
+ case LS_MAGLEV:
+ SetBit(_loaded_newgrf_features.used_liveries, LS_PASSENGER_WAGON_STEAM + ls - LS_STEAM);
+ break;
+
+ case LS_DMU:
+ case LS_EMU:
+ SetBit(_loaded_newgrf_features.used_liveries, LS_PASSENGER_WAGON_DIESEL + ls - LS_DMU);
+ break;
+
+ default: NOT_REACHED();
+ }
+ }
+ }
}
}