diff options
author | maedhros <maedhros@openttd.org> | 2007-01-12 11:20:34 +0000 |
---|---|---|
committer | maedhros <maedhros@openttd.org> | 2007-01-12 11:20:34 +0000 |
commit | 4ae861880bda8a0882db1a6bd1e82cff003248a6 (patch) | |
tree | b908ffc45eacd441ee01360329e463991af50290 | |
parent | 5afd50017de25527e0d3334e9515e82a0299fe31 (diff) | |
download | openttd-4ae861880bda8a0882db1a6bd1e82cff003248a6.tar.xz |
(svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
-rw-r--r-- | src/newgrf.cpp | 7 | ||||
-rw-r--r-- | src/newgrf_spritegroup.cpp | 12 | ||||
-rw-r--r-- | src/newgrf_spritegroup.h | 1 |
3 files changed, 18 insertions, 2 deletions
diff --git a/src/newgrf.cpp b/src/newgrf.cpp index 6d4f1a333..4d0982d93 100644 --- a/src/newgrf.cpp +++ b/src/newgrf.cpp @@ -1648,7 +1648,12 @@ static void NewSpriteGroup(byte *buf, int len) /* The first var adjust doesn't have an operation specified, so we set it to add. */ adjust->operation = group->g.determ.num_adjusts == 1 ? DSGA_OP_ADD : (DeterministicSpriteGroupAdjustOperation)grf_load_byte(&buf); adjust->variable = grf_load_byte(&buf); - adjust->parameter = IS_BYTE_INSIDE(adjust->variable, 0x60, 0x80) ? grf_load_byte(&buf) : 0; + if (adjust->variable == 0x7E) { + /* Link subroutine group */ + adjust->subroutine = GetGroupFromGroupID(setid, type, grf_load_byte(&buf)); + } else { + adjust->parameter = IS_BYTE_INSIDE(adjust->variable, 0x60, 0x80) ? grf_load_byte(&buf) : 0; + } varadjust = grf_load_byte(&buf); adjust->shift_num = GB(varadjust, 0, 5); diff --git a/src/newgrf_spritegroup.cpp b/src/newgrf_spritegroup.cpp index e187ddd9f..97e0114e2 100644 --- a/src/newgrf_spritegroup.cpp +++ b/src/newgrf_spritegroup.cpp @@ -5,6 +5,7 @@ #include "variables.h" #include "macros.h" #include "oldpool.h" +#include "newgrf_callbacks.h" #include "newgrf_spritegroup.h" #include "date.h" @@ -142,7 +143,16 @@ static inline const SpriteGroup *ResolveVariable(const SpriteGroup *group, Resol /* Try to get the variable. We shall assume it is available, unless told otherwise. */ bool available = true; - value = GetVariable(object, adjust->variable, adjust->parameter, &available); + if (adjust->variable == 0x7E) { + const SpriteGroup *subgroup = Resolve(adjust->subroutine, object); + if (subgroup == NULL || subgroup->type != SGT_CALLBACK) { + value = CALLBACK_FAILED; + } else { + value = subgroup->g.callback.result; + } + } else { + value = GetVariable(object, adjust->variable, adjust->parameter, &available); + } if (!available) { /* Unsupported property: skip further processing and return either diff --git a/src/newgrf_spritegroup.h b/src/newgrf_spritegroup.h index f77b6009d..836032882 100644 --- a/src/newgrf_spritegroup.h +++ b/src/newgrf_spritegroup.h @@ -69,6 +69,7 @@ typedef struct DeterministicSpriteGroupAdjust { uint32 and_mask; uint32 add_val; uint32 divmod_val; + const SpriteGroup *subroutine; } DeterministicSpriteGroupAdjust; |