diff options
author | bjarni <bjarni@openttd.org> | 2005-01-08 10:38:07 +0000 |
---|---|---|
committer | bjarni <bjarni@openttd.org> | 2005-01-08 10:38:07 +0000 |
commit | 4972b3722e617e31143aa6dcc33bd1a63760f093 (patch) | |
tree | dad0e4354efe906c9351f426f87e89d1f2b55d90 | |
parent | dcca3cf80ba4214270f8e8577e9d73909108e4ee (diff) | |
download | openttd-4972b3722e617e31143aa6dcc33bd1a63760f093.tar.xz |
(svn r1427) fixed issue where the wrong sprite could be used if autoreplacing between single and multiheaded trains
-rw-r--r-- | vehicle.c | 8 |
1 files changed, 6 insertions, 2 deletions
@@ -1505,8 +1505,12 @@ int32 CmdReplaceVehicle(int x, int y, uint32 flags, uint32 p1, uint32 p2) /* rvi->image_index is the new sprite for the engine. Adding +1 makes the engine head the other way if it is a multiheaded engine (rear engine) - (sprite - rvi2->image_index) is 1 if the engine is heading the other way, otherwise 0*/ - v->spritenum = rvi->image_index + (sprite - rvi2->image_index); + (rvi->flags & RVI_MULTIHEAD && sprite - rvi2->image_index) is true if the engine is heading the other way, otherwise 0*/ + v->spritenum = rvi->image_index + (( rvi->flags & RVI_MULTIHEAD && sprite - rvi2->image_index) ? 1 : 0); + + // turn the last engine in a multiheaded train if needed + if ( v->next == NULL && rvi->flags & RVI_MULTIHEAD && v->spritenum == rvi->image_index ) + v->spritenum++; v->cargo_type = rvi->cargo_type; v->cargo_cap = rvi->capacity; |