summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--newgrf.c24
1 files changed, 14 insertions, 10 deletions
diff --git a/newgrf.c b/newgrf.c
index 640f4c013..ff23eded3 100644
--- a/newgrf.c
+++ b/newgrf.c
@@ -1027,13 +1027,19 @@ static bool BridgeChangeInfo(uint brid, int numinfo, int prop, byte **bufp, int
}
for (table = tableid; table < tableid + numtables; table++) {
- assert(table < 7);
- if (bridge->sprite_table[table] == NULL) {
- bridge->sprite_table[table] = malloc(32 * sizeof(**bridge->sprite_table));
- }
+ if (table < 7) {
+ if (bridge->sprite_table[table] == NULL) {
+ bridge->sprite_table[table] = malloc(32 * sizeof(**bridge->sprite_table));
+ }
- for (sprite = 0; sprite < 32; sprite++)
- bridge->sprite_table[table][sprite] = grf_load_dword(&buf);
+ for (sprite = 0; sprite < 32; sprite++)
+ bridge->sprite_table[table][sprite] = grf_load_dword(&buf);
+ } else {
+ grfmsg(GMS_WARN, "BridgeChangeInfo: Table %d >= 7, skipping.", table);
+ // Skip past invalid data.
+ for (sprite = 0; sprite < 32; sprite++)
+ grf_load_dword(&buf);
+ }
}
}
break;
@@ -2272,10 +2278,8 @@ static void ResetNewGRFData(void)
for (i = 0; i < MAX_BRIDGES; i++) {
if (_bridge[i].sprite_table != NULL) {
byte j;
- for (j = 0; j < 7; j++) {
- if (_bridge[i].sprite_table[j] != NULL)
- free(_bridge[i].sprite_table[j]);
- }
+ for (j = 0; j < 7; j++)
+ free(_bridge[i].sprite_table[j]);
free(_bridge[i].sprite_table);
}
}