src/newgrf_spritegroup.cpp
author celestar
Mon, 19 Mar 2007 09:33:17 +0000
branchgamebalance
changeset 9894 70d78ac95d6c
parent 5873 ef74899fd5d7
child 6298 c30fe89622df
permissions -rw-r--r--
(svn r9310) [gamebalance] -Feature: Player performance now influences the wealth level of a town (albeit only on a small scale). This is the first feedback effect that the player has on the local and global economy. Please refrain from using the AI too much for the time being because it'll trash the ratings most likely.
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
     1
/* $Id$ */
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
     2
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
     3
#include "stdafx.h"
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
     4
#include "openttd.h"
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
     5
#include "variables.h"
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
     6
#include "macros.h"
5216
d581e4db95b6 (svn r7331) - Codechange: Rename all memory pool macro's and types to "old pool", so the new pool implementation can be committed alongside it.
matthijs
parents: 5081
diff changeset
     7
#include "oldpool.h"
5868
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
     8
#include "newgrf_callbacks.h"
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
     9
#include "newgrf_spritegroup.h"
4261
2ec8f5a9747b (svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
rubidium
parents: 3971
diff changeset
    10
#include "date.h"
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    11
4971
0a3653c45b5a (svn r6974) use the pool macros for the SpriteGroup pool
tron
parents: 4894
diff changeset
    12
static void SpriteGroupPoolCleanBlock(uint start_item, uint end_item);
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    13
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    14
static uint _spritegroup_count = 0;
5725
8ad0e96437e0 (svn r7758) -Codechange: Change SpriteGroup pool allocation from 16 items to 512 items at a time, as with a few sets loaded there can easily be 10,000+ items in the pool.
peter1138
parents: 5216
diff changeset
    15
STATIC_OLD_POOL(SpriteGroup, SpriteGroup, 9, 250, NULL, SpriteGroupPoolCleanBlock)
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    16
5022
323517a5df08 (svn r7063) static
tron
parents: 4971
diff changeset
    17
static void DestroySpriteGroup(SpriteGroup *group)
4402
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    18
{
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    19
	/* Free dynamically allocated memory */
4894
079148a9eadc (svn r6838) - Fix (r6836): MS VC complains beecause it doesn't understand consts... (or I don't...)
peter1138
parents: 4402
diff changeset
    20
	/* XXX Cast away the consts due to MSVC being buggy... */
4402
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    21
	switch (group->type) {
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    22
		case SGT_REAL:
4894
079148a9eadc (svn r6838) - Fix (r6836): MS VC complains beecause it doesn't understand consts... (or I don't...)
peter1138
parents: 4402
diff changeset
    23
			free((SpriteGroup**)group->g.real.loaded);
079148a9eadc (svn r6838) - Fix (r6836): MS VC complains beecause it doesn't understand consts... (or I don't...)
peter1138
parents: 4402
diff changeset
    24
			free((SpriteGroup**)group->g.real.loading);
4402
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    25
			break;
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    26
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    27
		case SGT_DETERMINISTIC:
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    28
			free(group->g.determ.adjusts);
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    29
			free(group->g.determ.ranges);
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    30
			break;
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    31
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    32
		case SGT_RANDOMIZED:
4894
079148a9eadc (svn r6838) - Fix (r6836): MS VC complains beecause it doesn't understand consts... (or I don't...)
peter1138
parents: 4402
diff changeset
    33
			free((SpriteGroup**)group->g.random.groups);
4402
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    34
			break;
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    35
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    36
		default:
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    37
			break;
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    38
	}
05a9ad2ec919 (svn r6155) -Codechange: split Destroy routine from SpriteGroupPoolCleanBlock
truelight
parents: 4331
diff changeset
    39
}
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    40
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    41
static void SpriteGroupPoolCleanBlock(uint start_item, uint end_item)
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    42
{
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    43
	uint i;
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    44
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    45
	for (i = start_item; i <= end_item; i++) {
4971
0a3653c45b5a (svn r6974) use the pool macros for the SpriteGroup pool
tron
parents: 4894
diff changeset
    46
		DestroySpriteGroup(GetSpriteGroup(i));
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    47
	}
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    48
}
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    49
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    50
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    51
/* Allocate a new SpriteGroup */
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    52
SpriteGroup *AllocateSpriteGroup(void)
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    53
{
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    54
	/* This is totally different to the other pool allocators, as we never remove an item from the pool. */
4971
0a3653c45b5a (svn r6974) use the pool macros for the SpriteGroup pool
tron
parents: 4894
diff changeset
    55
	if (_spritegroup_count == GetSpriteGroupPoolSize()) {
0a3653c45b5a (svn r6974) use the pool macros for the SpriteGroup pool
tron
parents: 4894
diff changeset
    56
		if (!AddBlockToPool(&_SpriteGroup_pool)) return NULL;
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    57
	}
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    58
4971
0a3653c45b5a (svn r6974) use the pool macros for the SpriteGroup pool
tron
parents: 4894
diff changeset
    59
	return GetSpriteGroup(_spritegroup_count++);
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    60
}
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    61
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    62
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    63
void InitializeSpriteGroupPool(void)
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    64
{
4971
0a3653c45b5a (svn r6974) use the pool macros for the SpriteGroup pool
tron
parents: 4894
diff changeset
    65
	CleanPool(&_SpriteGroup_pool);
3595
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    66
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    67
	_spritegroup_count = 0;
20621831cd46 (svn r4486) - NewGRF: Create and use a memory pool to manage sprite groups. This
peter1138
parents:
diff changeset
    68
}
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    69
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    70
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
    71
static inline uint32 GetVariable(const ResolverObject *object, byte variable, byte parameter, bool *available)
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    72
{
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    73
	/* Return common variables */
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    74
	switch (variable) {
4331
11de01553605 (svn r6013) -Fix: some newgrf properties returned the date in the new format where the newgrf's expect the original format. Thanks to michi_cc for finding these and providing the initial patch.
rubidium
parents: 4322
diff changeset
    75
		case 0x00: return max(_date - DAYS_TILL_ORIGINAL_BASE_YEAR, 0);
4322
0bee6d9bc452 (svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
rubidium
parents: 4293
diff changeset
    76
		case 0x01: return clamp(_cur_year, ORIGINAL_BASE_YEAR, ORIGINAL_MAX_YEAR) - ORIGINAL_BASE_YEAR;
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    77
		case 0x02: return _cur_month;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    78
		case 0x03: return _opt.landscape;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    79
		case 0x09: return _date_fract;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    80
		case 0x0A: return _tick_counter;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    81
		case 0x0C: return object->callback;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    82
		case 0x10: return object->callback_param1;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    83
		case 0x11: return 0;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    84
		case 0x18: return object->callback_param2;
5855
691082ee15fb (svn r8058) -Codechange: Replaced an occurence of (uint32)-1 by UINT_MAX
celestar
parents: 5852
diff changeset
    85
		case 0x1A: return UINT_MAX;
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    86
		case 0x1B: return GB(_display_opt, 0, 6);
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    87
		case 0x1C: return object->last_value;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    88
		case 0x20: return _opt.landscape == LT_HILLY ? _opt.snow_line : 0xFF;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    89
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    90
		/* Not a common variable, so evalute the feature specific variables */
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
    91
		default: return object->GetVariable(object, variable, parameter, available);
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    92
	}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    93
}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    94
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
    95
5851
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
    96
/* Evaluate an adjustment for a variable of the given size.
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
    97
* U is the unsigned type and S is the signed type to use. */
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
    98
template <typename U, typename S>
5857
5ef1679ad1e4 (svn r8062) -Codechange: change newgrf varaction2 value from signed to unsigned
peter1138
parents: 5855
diff changeset
    99
static U EvalAdjustT(const DeterministicSpriteGroupAdjust *adjust, U last_value, uint32 value)
5851
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   100
{
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   101
	value >>= adjust->shift_num;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   102
	value  &= adjust->and_mask;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   103
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   104
	if (adjust->type != DSGA_TYPE_NONE) value += (S)adjust->add_val;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   105
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   106
	switch (adjust->type) {
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   107
		case DSGA_TYPE_DIV:  value /= (S)adjust->divmod_val; break;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   108
		case DSGA_TYPE_MOD:  value %= (U)adjust->divmod_val; break;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   109
		case DSGA_TYPE_NONE: break;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   110
	}
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   111
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   112
	switch (adjust->operation) {
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   113
		case DSGA_OP_ADD:  return last_value + value;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   114
		case DSGA_OP_SUB:  return last_value - value;
5852
cb3f71b16e1a (svn r8055) -Codechange: Replace the different max, dmax, maxu whatever macros by a simple template function max(), that requires two arguments of the same type. While I'm at it change a variable called "max" to "maxval" in a function that calls max().
celestar
parents: 5851
diff changeset
   115
		case DSGA_OP_SMIN: return min((S)last_value, (S)value);
cb3f71b16e1a (svn r8055) -Codechange: Replace the different max, dmax, maxu whatever macros by a simple template function max(), that requires two arguments of the same type. While I'm at it change a variable called "max" to "maxval" in a function that calls max().
celestar
parents: 5851
diff changeset
   116
		case DSGA_OP_SMAX: return max((S)last_value, (S)value);
5851
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   117
		case DSGA_OP_UMIN: return min((U)last_value, (U)value);
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   118
		case DSGA_OP_UMAX: return max((U)last_value, (U)value);
5857
5ef1679ad1e4 (svn r8062) -Codechange: change newgrf varaction2 value from signed to unsigned
peter1138
parents: 5855
diff changeset
   119
		case DSGA_OP_SDIV: return (S)last_value / (S)value;
5ef1679ad1e4 (svn r8062) -Codechange: change newgrf varaction2 value from signed to unsigned
peter1138
parents: 5855
diff changeset
   120
		case DSGA_OP_SMOD: return (S)last_value % (S)value;
5851
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   121
		case DSGA_OP_UDIV: return (U)last_value / (U)value;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   122
		case DSGA_OP_UMOD: return (U)last_value % (U)value;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   123
		case DSGA_OP_MUL:  return last_value * value;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   124
		case DSGA_OP_AND:  return last_value & value;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   125
		case DSGA_OP_OR:   return last_value | value;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   126
		case DSGA_OP_XOR:  return last_value ^ value;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   127
		default:           return value;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   128
	}
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   129
}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   130
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   131
3686
55efe6da4dfb (svn r4611) - NewGRF: introduce new vehicle sprite group resolver code. This also fixes some known bugs (e.g. the 'Standard Five' in UKRS is now the correct colour)
peter1138
parents: 3681
diff changeset
   132
static inline const SpriteGroup *ResolveVariable(const SpriteGroup *group, ResolverObject *object)
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   133
{
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   134
	static SpriteGroup nvarzero;
5858
dfe44c585495 (svn r8063) -Codechange: When evaluating newgrf varaction2s the 'last value' should start off at 0, and the result of the operation is remembered.
peter1138
parents: 5857
diff changeset
   135
	uint32 last_value = 0;
5857
5ef1679ad1e4 (svn r8062) -Codechange: change newgrf varaction2 value from signed to unsigned
peter1138
parents: 5855
diff changeset
   136
	uint32 value = 0;
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   137
	uint i;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   138
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   139
	object->scope = group->g.determ.var_scope;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   140
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   141
	for (i = 0; i < group->g.determ.num_adjusts; i++) {
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   142
		DeterministicSpriteGroupAdjust *adjust = &group->g.determ.adjusts[i];
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   143
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   144
		/* Try to get the variable. We shall assume it is available, unless told otherwise. */
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   145
		bool available = true;
5868
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   146
		if (adjust->variable == 0x7E) {
5873
ef74899fd5d7 (svn r8081) -Fix (r8075): Use a copy of the resolver object instead of the using the existing one. This fixes problems with the object scope setting.
peter1138
parents: 5868
diff changeset
   147
			ResolverObject subobject = *object;
ef74899fd5d7 (svn r8081) -Fix (r8075): Use a copy of the resolver object instead of the using the existing one. This fixes problems with the object scope setting.
peter1138
parents: 5868
diff changeset
   148
			const SpriteGroup *subgroup = Resolve(adjust->subroutine, &subobject);
5868
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   149
			if (subgroup == NULL || subgroup->type != SGT_CALLBACK) {
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   150
				value = CALLBACK_FAILED;
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   151
			} else {
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   152
				value = subgroup->g.callback.result;
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   153
			}
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   154
		} else {
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   155
			value = GetVariable(object, adjust->variable, adjust->parameter, &available);
baa704b6dc4f (svn r8075) -Feature: Add support for variable 7E - subroutines. (peter1138)
maedhros
parents: 5858
diff changeset
   156
		}
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   157
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   158
		if (!available) {
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   159
			/* Unsupported property: skip further processing and return either
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   160
			 * the group from the first range or the default group. */
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   161
			return Resolve(group->g.determ.num_ranges > 0 ? group->g.determ.ranges[0].group : group->g.determ.default_group, object);
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   162
		}
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   163
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   164
		switch (group->g.determ.size) {
5851
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   165
			case DSG_SIZE_BYTE:  value = EvalAdjustT<uint8, int8>(adjust, last_value, value); break;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   166
			case DSG_SIZE_WORD:  value = EvalAdjustT<uint16, int16>(adjust, last_value, value); break;
ea65a6afdc43 (svn r8054) -Codechange: Use a template function instead of a macro for evaluating NewGRF var adjusts
peter1138
parents: 5838
diff changeset
   167
			case DSG_SIZE_DWORD: value = EvalAdjustT<uint32, int32>(adjust, last_value, value); break;
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   168
			default: NOT_REACHED(); break;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   169
		}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   170
		last_value = value;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   171
	}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   172
5858
dfe44c585495 (svn r8063) -Codechange: When evaluating newgrf varaction2s the 'last value' should start off at 0, and the result of the operation is remembered.
peter1138
parents: 5857
diff changeset
   173
	object->last_value = last_value;
dfe44c585495 (svn r8063) -Codechange: When evaluating newgrf varaction2s the 'last value' should start off at 0, and the result of the operation is remembered.
peter1138
parents: 5857
diff changeset
   174
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   175
	if (group->g.determ.num_ranges == 0) {
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   176
		/* nvar == 0 is a special case -- we turn our value into a callback result */
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   177
		nvarzero.type = SGT_CALLBACK;
3942
18f75e002a09 (svn r5087) - NewGRF: Fix thinko in returning a calculated callback result
peter1138
parents: 3893
diff changeset
   178
		nvarzero.g.callback.result = GB(value, 0, 15);
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   179
		return &nvarzero;
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   180
	}
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   181
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   182
	for (i = 0; i < group->g.determ.num_ranges; i++) {
5857
5ef1679ad1e4 (svn r8062) -Codechange: change newgrf varaction2 value from signed to unsigned
peter1138
parents: 5855
diff changeset
   183
		if (group->g.determ.ranges[i].low <= value && value <= group->g.determ.ranges[i].high) {
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   184
			return Resolve(group->g.determ.ranges[i].group, object);
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   185
		}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   186
	}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   187
3893
46169364701b (svn r4960) - NewGRF: explicitly handle unsupported variables, instead of returning -1.
peter1138
parents: 3861
diff changeset
   188
	return Resolve(group->g.determ.default_group, object);
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   189
}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   190
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   191
3686
55efe6da4dfb (svn r4611) - NewGRF: introduce new vehicle sprite group resolver code. This also fixes some known bugs (e.g. the 'Standard Five' in UKRS is now the correct colour)
peter1138
parents: 3681
diff changeset
   192
static inline const SpriteGroup *ResolveRandom(const SpriteGroup *group, ResolverObject *object)
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   193
{
3753
aa15896bc569 (svn r4741) - NewGRF: use the correct variable type for the random bit mask
peter1138
parents: 3734
diff changeset
   194
	uint32 mask;
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   195
	byte index;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   196
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   197
	object->scope = group->g.random.var_scope;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   198
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   199
	if (object->trigger != 0) {
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   200
		/* Handle triggers */
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   201
		/* Magic code that may or may not do the right things... */
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   202
		byte waiting_triggers = object->GetTriggers(object);
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   203
		byte match = group->g.random.triggers & (waiting_triggers | object->trigger);
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   204
		bool res;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   205
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   206
		res = (group->g.random.cmp_mode == RSG_CMP_ANY) ?
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   207
			(match != 0) : (match == group->g.random.triggers);
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   208
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   209
		if (res) {
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   210
			waiting_triggers &= ~match;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   211
			object->reseed |= (group->g.random.num_groups - 1) << group->g.random.lowest_randbit;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   212
		} else {
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   213
			waiting_triggers |= object->trigger;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   214
		}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   215
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   216
		object->SetTriggers(object, waiting_triggers);
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   217
	}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   218
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   219
	mask  = (group->g.random.num_groups - 1) << group->g.random.lowest_randbit;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   220
	index = (object->GetRandomBits(object) & mask) >> group->g.random.lowest_randbit;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   221
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   222
	return Resolve(group->g.random.groups[index], object);
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   223
}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   224
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   225
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   226
/* ResolverObject (re)entry point */
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   227
const SpriteGroup *Resolve(const SpriteGroup *group, ResolverObject *object)
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   228
{
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   229
	/* We're called even if there is no group, so quietly return nothing */
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   230
	if (group == NULL) return NULL;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   231
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   232
	switch (group->type) {
3734
f929883c5ae0 (svn r4714) - NewGRF: simplify evaluation of 'real' sprite groups.
peter1138
parents: 3690
diff changeset
   233
		case SGT_REAL:          return object->ResolveReal(object, group);
3677
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   234
		case SGT_DETERMINISTIC: return ResolveVariable(group, object);
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   235
		case SGT_RANDOMIZED:    return ResolveRandom(group, object);
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   236
		default:                return group;
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   237
	}
cb6659a684b5 (svn r4594) - NewGRF: introduce the basic sprite group resolver. This code isn't used yet.
peter1138
parents: 3668
diff changeset
   238
}