(svn r4537) - NewGRF: replace if cascade with a switch block in the sprite group loader
This commit is contained in:
		
							
								
								
									
										105
									
								
								newgrf.c
									
									
									
									
									
								
							
							
						
						
									
										105
									
								
								newgrf.c
									
									
									
									
									
								
							| @@ -1302,8 +1302,6 @@ static void NewSpriteSet(byte *buf, int len) | |||||||
| /* Action 0x02 */ | /* Action 0x02 */ | ||||||
| static void NewSpriteGroup(byte *buf, int len) | static void NewSpriteGroup(byte *buf, int len) | ||||||
| { | { | ||||||
| 	byte *bufend = buf + len; |  | ||||||
|  |  | ||||||
| 	/* <02> <feature> <set-id> <type/num-entries> <feature-specific-data...> | 	/* <02> <feature> <set-id> <type/num-entries> <feature-specific-data...> | ||||||
| 	 * | 	 * | ||||||
| 	 * B feature       see action 1 | 	 * B feature       see action 1 | ||||||
| @@ -1314,26 +1312,18 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 	 *                 otherwise it specifies a number of entries, the exact | 	 *                 otherwise it specifies a number of entries, the exact | ||||||
| 	 *                 meaning depends on the feature | 	 *                 meaning depends on the feature | ||||||
| 	 * V feature-specific-data (huge mess, don't even look it up --pasky) */ | 	 * V feature-specific-data (huge mess, don't even look it up --pasky) */ | ||||||
| 	/* TODO: No 0x80-types (ugh). */ |  | ||||||
| 	/* TODO: Also, empty sprites aren't handled for now. Need to investigate |  | ||||||
| 	 * the "opacity" rules for these, that is which sprite to fall back to |  | ||||||
| 	 * when. --pasky */ |  | ||||||
| 	uint8 feature; | 	uint8 feature; | ||||||
| 	uint8 setid; | 	uint8 setid; | ||||||
| 	/* XXX: For stations, these two are "little cargo" and "lotsa cargo" sets. */ | 	uint8 type; | ||||||
| 	uint8 numloaded; | 	SpriteGroup *group = NULL; | ||||||
| 	uint8 numloading; | 	byte *bufend = buf + len; | ||||||
| 	SpriteGroup *group; |  | ||||||
| 	RealSpriteGroup *rg; |  | ||||||
| 	byte *loaded_ptr; |  | ||||||
| 	byte *loading_ptr; |  | ||||||
| 	int i; |  | ||||||
|  |  | ||||||
| 	check_length(len, 5, "NewSpriteGroup"); | 	check_length(len, 5, "NewSpriteGroup"); | ||||||
| 	feature = buf[1]; | 	buf++; | ||||||
| 	setid = buf[2]; |  | ||||||
| 	numloaded = buf[3]; | 	feature = grf_load_byte(&buf); | ||||||
| 	numloading = buf[4]; | 	setid   = grf_load_byte(&buf); | ||||||
|  | 	type    = grf_load_byte(&buf); | ||||||
|  |  | ||||||
| 	if (setid >= _cur_grffile->spritegroups_count) { | 	if (setid >= _cur_grffile->spritegroups_count) { | ||||||
| 		// Allocate memory for new sprite group references. | 		// Allocate memory for new sprite group references. | ||||||
| @@ -1343,28 +1333,22 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 			_cur_grffile->spritegroups[_cur_grffile->spritegroups_count] = NULL; | 			_cur_grffile->spritegroups[_cur_grffile->spritegroups_count] = NULL; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if (numloaded == 0x81 || numloaded == 0x82) { | 	switch (type) { | ||||||
|  | 		/* Deterministic Sprite Group */ | ||||||
|  | 		case 0x81: // Self scope, byte | ||||||
|  | 		case 0x82: // Parent scope, byte | ||||||
|  | 		{ | ||||||
| 			DeterministicSpriteGroup *dg; | 			DeterministicSpriteGroup *dg; | ||||||
| 			uint16 groupid; | 			uint16 groupid; | ||||||
| 			int i; | 			int i; | ||||||
|  |  | ||||||
| 		// Ok, this is gonna get a little wild, so hold your breath... | 			check_length(bufend - buf, 6, "NewSpriteGroup 0x81/0x82"); | ||||||
|  |  | ||||||
| 		/* This stuff is getting actually evaluated in |  | ||||||
| 		 * EvalDeterministicSpriteGroup(). */ |  | ||||||
|  |  | ||||||
| 		buf += 4; len -= 4; |  | ||||||
| 		check_length(len, 6, "NewSpriteGroup 0x81/0x82"); |  | ||||||
|  |  | ||||||
| 			group = AllocateSpriteGroup(); | 			group = AllocateSpriteGroup(); | ||||||
| 			group->type = SGT_DETERMINISTIC; | 			group->type = SGT_DETERMINISTIC; | ||||||
| 			dg = &group->g.determ; | 			dg = &group->g.determ; | ||||||
|  |  | ||||||
| 		/* XXX: We don't free() anything, assuming that if there was | 			dg->var_scope = type == 0x82 ? VSG_SCOPE_PARENT : VSG_SCOPE_SELF; | ||||||
| 		 * some action here before, it got associated by action 3. |  | ||||||
| 		 * We should perhaps keep some refcount? --pasky */ |  | ||||||
|  |  | ||||||
| 		dg->var_scope = numloaded == 0x82 ? VSG_SCOPE_PARENT : VSG_SCOPE_SELF; |  | ||||||
| 			dg->variable = grf_load_byte(&buf); | 			dg->variable = grf_load_byte(&buf); | ||||||
| 			/* Variables 0x60 - 0x7F include an extra parameter */ | 			/* Variables 0x60 - 0x7F include an extra parameter */ | ||||||
| 			if (IS_BYTE_INSIDE(dg->variable, 0x60, 0x80)) | 			if (IS_BYTE_INSIDE(dg->variable, 0x60, 0x80)) | ||||||
| @@ -1388,7 +1372,7 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 				if (HASBIT(groupid, 15)) { | 				if (HASBIT(groupid, 15)) { | ||||||
| 					dg->ranges[i].group = NewCallBackResultSpriteGroup(groupid); | 					dg->ranges[i].group = NewCallBackResultSpriteGroup(groupid); | ||||||
| 				} else if (groupid >= _cur_grffile->spritegroups_count || _cur_grffile->spritegroups[groupid] == NULL) { | 				} else if (groupid >= _cur_grffile->spritegroups_count || _cur_grffile->spritegroups[groupid] == NULL) { | ||||||
| 				grfmsg(GMS_WARN, "NewSpriteGroup(0x%02X:0x%02X): Groupid 0x%04X does not exist, leaving empty.", setid, numloaded, groupid); | 					grfmsg(GMS_WARN, "NewSpriteGroup(0x%02X:0x%02X): Groupid 0x%04X does not exist, leaving empty.", setid, type, groupid); | ||||||
| 					dg->ranges[i].group = NULL; | 					dg->ranges[i].group = NULL; | ||||||
| 				} else { | 				} else { | ||||||
| 					dg->ranges[i].group = _cur_grffile->spritegroups[groupid]; | 					dg->ranges[i].group = _cur_grffile->spritegroups[groupid]; | ||||||
| @@ -1402,35 +1386,32 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 			if (HASBIT(groupid, 15)) { | 			if (HASBIT(groupid, 15)) { | ||||||
| 				dg->default_group = NewCallBackResultSpriteGroup(groupid); | 				dg->default_group = NewCallBackResultSpriteGroup(groupid); | ||||||
| 			} else if (groupid >= _cur_grffile->spritegroups_count || _cur_grffile->spritegroups[groupid] == NULL) { | 			} else if (groupid >= _cur_grffile->spritegroups_count || _cur_grffile->spritegroups[groupid] == NULL) { | ||||||
| 			grfmsg(GMS_WARN, "NewSpriteGroup(0x%02X:0x%02X): Groupid 0x%04X does not exist, leaving empty.", setid, numloaded, groupid); | 				grfmsg(GMS_WARN, "NewSpriteGroup(0x%02X:0x%02X): Groupid 0x%04X does not exist, leaving empty.", setid, type, groupid); | ||||||
| 				dg->default_group = NULL; | 				dg->default_group = NULL; | ||||||
| 			} else { | 			} else { | ||||||
| 				dg->default_group = _cur_grffile->spritegroups[groupid]; | 				dg->default_group = _cur_grffile->spritegroups[groupid]; | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 		_cur_grffile->spritegroups[setid] = group; | 			break; | ||||||
| 		return; | 		} | ||||||
|  |  | ||||||
| 	} else if (numloaded == 0x80 || numloaded == 0x83) { | 		/* Randomized Sprite Group */ | ||||||
|  | 		case 0x80: // Self scope | ||||||
|  | 		case 0x83: // Parent scope | ||||||
|  | 		{ | ||||||
| 			RandomizedSpriteGroup *rg; | 			RandomizedSpriteGroup *rg; | ||||||
| 			int i; | 			int i; | ||||||
|  |  | ||||||
| 			/* This stuff is getting actually evaluated in | 			/* This stuff is getting actually evaluated in | ||||||
| 			 * EvalRandomizedSpriteGroup(). */ | 			 * EvalRandomizedSpriteGroup(). */ | ||||||
|  |  | ||||||
| 		buf += 4; | 			check_length(bufend - buf, 6, "NewSpriteGroup 0x80/0x83"); | ||||||
| 		len -= 4; |  | ||||||
| 		check_length(len, 6, "NewSpriteGroup 0x80/0x83"); |  | ||||||
|  |  | ||||||
| 			group = AllocateSpriteGroup(); | 			group = AllocateSpriteGroup(); | ||||||
| 			group->type = SGT_RANDOMIZED; | 			group->type = SGT_RANDOMIZED; | ||||||
| 			rg = &group->g.random; | 			rg = &group->g.random; | ||||||
|  |  | ||||||
| 		/* XXX: We don't free() anything, assuming that if there was | 			rg->var_scope = type == 0x83 ? VSG_SCOPE_PARENT : VSG_SCOPE_SELF; | ||||||
| 		 * some action here before, it got associated by action 3. |  | ||||||
| 		 * We should perhaps keep some refcount? --pasky */ |  | ||||||
|  |  | ||||||
| 		rg->var_scope = numloaded == 0x83 ? VSG_SCOPE_PARENT : VSG_SCOPE_SELF; |  | ||||||
|  |  | ||||||
| 			rg->triggers = grf_load_byte(&buf); | 			rg->triggers = grf_load_byte(&buf); | ||||||
| 			rg->cmp_mode = rg->triggers & 0x80; | 			rg->cmp_mode = rg->triggers & 0x80; | ||||||
| @@ -1446,17 +1427,23 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 				if (HASBIT(groupid, 15)) { | 				if (HASBIT(groupid, 15)) { | ||||||
| 					rg->groups[i] = NewCallBackResultSpriteGroup(groupid); | 					rg->groups[i] = NewCallBackResultSpriteGroup(groupid); | ||||||
| 				} else if (groupid >= _cur_grffile->spritegroups_count || _cur_grffile->spritegroups[groupid] == NULL) { | 				} else if (groupid >= _cur_grffile->spritegroups_count || _cur_grffile->spritegroups[groupid] == NULL) { | ||||||
| 				grfmsg(GMS_WARN, "NewSpriteGroup(0x%02X:0x%02X): Groupid 0x%04X does not exist, leaving empty.", setid, numloaded, groupid); | 					grfmsg(GMS_WARN, "NewSpriteGroup(0x%02X:0x%02X): Groupid 0x%04X does not exist, leaving empty.", setid, type, groupid); | ||||||
| 					rg->groups[i] = NULL; | 					rg->groups[i] = NULL; | ||||||
| 				} else { | 				} else { | ||||||
| 					rg->groups[i] = _cur_grffile->spritegroups[groupid]; | 					rg->groups[i] = _cur_grffile->spritegroups[groupid]; | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 		_cur_grffile->spritegroups[setid] = group; | 			break; | ||||||
| 		return; |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		default: | ||||||
|  | 		{ | ||||||
|  | 			RealSpriteGroup *rg; | ||||||
|  | 			byte num_loaded  = type; | ||||||
|  | 			byte num_loading = grf_load_byte(&buf); | ||||||
|  | 			uint i; | ||||||
|  |  | ||||||
| 			if (!_cur_grffile->spriteset_start) { | 			if (!_cur_grffile->spriteset_start) { | ||||||
| 				grfmsg(GMS_ERROR, "NewSpriteGroup: No sprite set to work on! Skipping."); | 				grfmsg(GMS_ERROR, "NewSpriteGroup: No sprite set to work on! Skipping."); | ||||||
| 				return; | 				return; | ||||||
| @@ -1467,12 +1454,6 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 				// return; // XXX: we can't because of MB's newstats.grf --pasky | 				// return; // XXX: we can't because of MB's newstats.grf --pasky | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 	check_length(bufend - buf, 5, "NewSpriteGroup"); |  | ||||||
| 	buf += 5; |  | ||||||
| 	check_length(bufend - buf, 2 * numloaded, "NewSpriteGroup"); |  | ||||||
| 	loaded_ptr = buf; |  | ||||||
| 	loading_ptr = buf + 2 * numloaded; |  | ||||||
|  |  | ||||||
| 			if (_cur_grffile->first_spriteset == 0) | 			if (_cur_grffile->first_spriteset == 0) | ||||||
| 				_cur_grffile->first_spriteset = _cur_grffile->spriteset_start; | 				_cur_grffile->first_spriteset = _cur_grffile->spriteset_start; | ||||||
|  |  | ||||||
| @@ -1481,8 +1462,8 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 			rg = &group->g.real; | 			rg = &group->g.real; | ||||||
|  |  | ||||||
| 			rg->sprites_per_set = _cur_grffile->spriteset_numents; | 			rg->sprites_per_set = _cur_grffile->spriteset_numents; | ||||||
| 	rg->loaded_count  = numloaded; | 			rg->loaded_count  = num_loaded; | ||||||
| 	rg->loading_count = numloading; | 			rg->loading_count = num_loading; | ||||||
|  |  | ||||||
| 			rg->loaded  = calloc(rg->loaded_count,  sizeof(*rg->loaded)); | 			rg->loaded  = calloc(rg->loaded_count,  sizeof(*rg->loaded)); | ||||||
| 			rg->loading = calloc(rg->loading_count, sizeof(*rg->loading)); | 			rg->loading = calloc(rg->loading_count, sizeof(*rg->loading)); | ||||||
| @@ -1490,10 +1471,10 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 			DEBUG(grf, 6) ("NewSpriteGroup: New SpriteGroup 0x%02hhx, %u views, %u loaded, %u loading, sprites %u - %u", | 			DEBUG(grf, 6) ("NewSpriteGroup: New SpriteGroup 0x%02hhx, %u views, %u loaded, %u loading, sprites %u - %u", | ||||||
| 					setid, rg->sprites_per_set, rg->loaded_count, rg->loading_count, | 					setid, rg->sprites_per_set, rg->loaded_count, rg->loading_count, | ||||||
| 					_cur_grffile->spriteset_start - _cur_grffile->sprite_offset, | 					_cur_grffile->spriteset_start - _cur_grffile->sprite_offset, | ||||||
| 			_cur_grffile->spriteset_start + (_cur_grffile->spriteset_numents * (numloaded + numloading)) - _cur_grffile->sprite_offset); | 					_cur_grffile->spriteset_start + (_cur_grffile->spriteset_numents * (num_loaded + num_loading)) - _cur_grffile->sprite_offset); | ||||||
|  |  | ||||||
| 	for (i = 0; i < numloaded; i++) { | 			for (i = 0; i < num_loaded; i++) { | ||||||
| 		uint16 spriteset_id = grf_load_word(&loaded_ptr); | 				uint16 spriteset_id = grf_load_word(&buf); | ||||||
| 				if (HASBIT(spriteset_id, 15)) { | 				if (HASBIT(spriteset_id, 15)) { | ||||||
| 					rg->loaded[i] = NewCallBackResultSpriteGroup(spriteset_id); | 					rg->loaded[i] = NewCallBackResultSpriteGroup(spriteset_id); | ||||||
| 				} else { | 				} else { | ||||||
| @@ -1502,8 +1483,8 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 				DEBUG(grf, 8) ("NewSpriteGroup: + rg->loaded[%i]  = %u (subset %u)", i, rg->loaded[i]->g.result.result, spriteset_id); | 				DEBUG(grf, 8) ("NewSpriteGroup: + rg->loaded[%i]  = %u (subset %u)", i, rg->loaded[i]->g.result.result, spriteset_id); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 	for (i = 0; i < numloading; i++) { | 			for (i = 0; i < num_loading; i++) { | ||||||
| 		uint16 spriteset_id = grf_load_word(&loading_ptr); | 				uint16 spriteset_id = grf_load_word(&buf); | ||||||
| 				if (HASBIT(spriteset_id, 15)) { | 				if (HASBIT(spriteset_id, 15)) { | ||||||
| 					rg->loading[i] = NewCallBackResultSpriteGroup(spriteset_id); | 					rg->loading[i] = NewCallBackResultSpriteGroup(spriteset_id); | ||||||
| 				} else { | 				} else { | ||||||
| @@ -1512,6 +1493,10 @@ static void NewSpriteGroup(byte *buf, int len) | |||||||
| 				DEBUG(grf, 8) ("NewSpriteGroup: + rg->loading[%i] = %u (subset %u)", i, rg->loading[i]->g.result.result, spriteset_id); | 				DEBUG(grf, 8) ("NewSpriteGroup: + rg->loading[%i] = %u (subset %u)", i, rg->loading[i]->g.result.result, spriteset_id); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|  | 			break; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	_cur_grffile->spritegroups[setid] = group; | 	_cur_grffile->spritegroups[setid] = group; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 peter1138
					peter1138