diff options
author | peter1138 <peter1138@openttd.org> | 2008-08-29 20:03:51 +0000 |
---|---|---|
committer | peter1138 <peter1138@openttd.org> | 2008-08-29 20:03:51 +0000 |
commit | 4c56b827e5b6a89b043dee2b7148d1f25e1e20c5 (patch) | |
tree | 1b1160fb4b1b59096fe19802c7ea1a6102af0f4a /src | |
parent | 06777f7efc882171093fde824c5b189bf5727b25 (diff) | |
download | openttd-4c56b827e5b6a89b043dee2b7148d1f25e1e20c5.tar.xz |
(svn r14184) -Codechange: [NewGRF] Since our NewGRF handling is better than it used to be, disable a NewGRF if unexpected sprites are reached.
Diffstat (limited to 'src')
-rw-r--r-- | src/lang/english.txt | 1 | ||||
-rw-r--r-- | src/newgrf.cpp | 9 |
2 files changed, 9 insertions, 1 deletions
diff --git a/src/lang/english.txt b/src/lang/english.txt index d3ce0072e..461eef9f3 100644 --- a/src/lang/english.txt +++ b/src/lang/english.txt @@ -3216,6 +3216,7 @@ STR_NEWGRF_ERROR_OTTD_VERSION_NUMBER :{SKIP}{STRING1} STR_NEWGRF_ERROR_AFTER_TRANSLATED_FILE :the GRF file it was designed to translate STR_NEWGRF_ERROR_TOO_MANY_NEWGRFS_LOADED :Too many NewGRFs are loaded. STR_NEWGRF_ERROR_STATIC_GRF_CAUSES_DESYNC :Loading {RAW_STRING} as static NewGRF with {RAW_STRING} could cause desyncs. +STR_NEWGRF_ERROR_UNEXPECTED_SPRITE :Unexpected sprite. STR_NEWGRF_PRESET_LIST_TIP :{BLACK}Load the selected preset STR_NEWGRF_PRESET_SAVE :{BLACK}Save preset diff --git a/src/newgrf.cpp b/src/newgrf.cpp index 2fc15c06a..35c604bb6 100644 --- a/src/newgrf.cpp +++ b/src/newgrf.cpp @@ -5918,7 +5918,14 @@ void LoadNewGRFFile(GRFConfig *config, uint file_index, GrfLoadingStage stage) FioSkipBytes(num); } } else { - if (_skip_sprites == 0) grfmsg(7, "LoadNewGRFFile: Skipping unexpected sprite"); + if (_skip_sprites == 0) { + grfmsg(0, "LoadNewGRFFile: Unexpected sprite, disabling"); + config->status = GCS_DISABLED; + config->error = CallocT<GRFError>(1); + config->error->severity = STR_NEWGRF_ERROR_MSG_FATAL; + config->error->message = STR_NEWGRF_ERROR_UNEXPECTED_SPRITE; + break; + } FioSkipBytes(7); num -= 8; |