From 6e3ae628fc495d3f6ad496948bada1594872206b Mon Sep 17 00:00:00 2001 From: frosch Date: Tue, 4 Mar 2008 10:41:16 +0000 Subject: [PATCH] (svn r12333) -Fix: Switch grfstatus from 'activated' back to 'will-be-active' between reservation- and activation-stage. This fixes action7/9 conditions 0x06 to 0x0A to return the same in those two stages. --- src/newgrf.cpp | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/newgrf.cpp b/src/newgrf.cpp index 46a8669e77..0b1d0122a0 100644 --- a/src/newgrf.cpp +++ b/src/newgrf.cpp @@ -5853,6 +5853,12 @@ void LoadNewGRF(uint load_index, uint file_index) * in each loading stage, (try to) open each file specified in the config * and load information from it. */ for (GrfLoadingStage stage = GLS_LABELSCAN; stage <= GLS_ACTIVATION; stage++) { + /* Set activated grfs back to will-be-activated between reservation- and activation-stage. + * This ensures that action7/9 conditions 0x06 - 0x0A work correctly. */ + for (GRFConfig *c = _grfconfig; c != NULL; c = c->next) { + if (c->status == GCS_ACTIVATED) c->status = GCS_INITIALISED; + } + uint slot = file_index; _cur_stage = stage;