(svn r2833) Remove saving of sprite cache data:
the benefits are questionable, it's error prone, undocumented and hasn't been widely used for ages, if ever
This commit is contained in:
		| @@ -7,7 +7,6 @@ | |||||||
| #include "macros.h" | #include "macros.h" | ||||||
| #include "screenshot.h" | #include "screenshot.h" | ||||||
| #include "sound.h" | #include "sound.h" | ||||||
| #include "spritecache.h" |  | ||||||
| #include "string.h" | #include "string.h" | ||||||
| #include "variables.h" | #include "variables.h" | ||||||
| #include "network.h" | #include "network.h" | ||||||
| @@ -767,7 +766,6 @@ static const SettingDesc misc_settings[] = { | |||||||
| 	{"sounddriver",				SDT_STRINGBUF | (lengthof(_ini_sounddriver)<<16) | SDT_NOSAVE,NULL,			_ini_sounddriver,				NULL}, | 	{"sounddriver",				SDT_STRINGBUF | (lengthof(_ini_sounddriver)<<16) | SDT_NOSAVE,NULL,			_ini_sounddriver,				NULL}, | ||||||
| 	{"language",					SDT_STRINGBUF | lengthof(_dynlang.curr_file)<<16,							NULL,			_dynlang.curr_file,			NULL}, | 	{"language",					SDT_STRINGBUF | lengthof(_dynlang.curr_file)<<16,							NULL,			_dynlang.curr_file,			NULL}, | ||||||
| 	{"resolution",				SDT_UINT16 | SDT_INTLIST | lengthof(_cur_resolution) << 16,		"640,480",_cur_resolution,				NULL}, | 	{"resolution",				SDT_UINT16 | SDT_INTLIST | lengthof(_cur_resolution) << 16,		"640,480",_cur_resolution,				NULL}, | ||||||
| 	{"cache_sprites",			SDT_BOOL,			(void*)false, &_cache_sprites,			NULL}, |  | ||||||
| 	{"screenshot_format", SDT_STRINGBUF | (lengthof(_screenshot_format_name)<<16),			NULL,			_screenshot_format_name,NULL}, | 	{"screenshot_format", SDT_STRINGBUF | (lengthof(_screenshot_format_name)<<16),			NULL,			_screenshot_format_name,NULL}, | ||||||
| 	{"savegame_format",		SDT_STRINGBUF | (lengthof(_savegame_format)<<16),							NULL,			_savegame_format,				NULL}, | 	{"savegame_format",		SDT_STRINGBUF | (lengthof(_savegame_format)<<16),							NULL,			_savegame_format,				NULL}, | ||||||
| 	{"rightclick_emulate",SDT_BOOL,			(void*)false, &_rightclick_emulate, NULL}, | 	{"rightclick_emulate",SDT_BOOL,			(void*)false, &_rightclick_emulate, NULL}, | ||||||
|   | |||||||
							
								
								
									
										108
									
								
								spritecache.c
									
									
									
									
									
								
							
							
						
						
									
										108
									
								
								spritecache.c
									
									
									
									
									
								
							| @@ -13,7 +13,6 @@ | |||||||
| #include "variables.h" | #include "variables.h" | ||||||
| #include <ctype.h> | #include <ctype.h> | ||||||
|  |  | ||||||
| #define SPRITECACHE_ID 0xF00F0006 |  | ||||||
| #define SPRITE_CACHE_SIZE 1024*1024 | #define SPRITE_CACHE_SIZE 1024*1024 | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -383,58 +382,6 @@ static void LoadGrfIndexed(const char *filename, const SpriteID *index_tbl, int | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| typedef size_t CDECL fread_t(void*, size_t, size_t, FILE*); |  | ||||||
|  |  | ||||||
| static bool HandleCachedSpriteHeaders(const char *filename, bool read) |  | ||||||
| { |  | ||||||
| 	FILE *f; |  | ||||||
| 	fread_t *proc; |  | ||||||
| 	uint32 hdr; |  | ||||||
|  |  | ||||||
| 	if (!_cache_sprites) |  | ||||||
| 		return false; |  | ||||||
|  |  | ||||||
| 	if (read) { |  | ||||||
| 		f = fopen(filename, "rb"); |  | ||||||
| 		proc = fread; |  | ||||||
|  |  | ||||||
| 		if (f == NULL) |  | ||||||
| 			return false; |  | ||||||
|  |  | ||||||
| 		proc(&hdr, sizeof(hdr), 1, f); |  | ||||||
| 		if (hdr != SPRITECACHE_ID) { |  | ||||||
| 			fclose(f); |  | ||||||
| 			return false; |  | ||||||
| 		} |  | ||||||
| 	} else { |  | ||||||
| 		f = fopen(filename, "wb"); |  | ||||||
| 		proc = (fread_t*) fwrite; |  | ||||||
|  |  | ||||||
| 		if (f == NULL) |  | ||||||
| 			return false; |  | ||||||
|  |  | ||||||
| 		hdr = SPRITECACHE_ID; |  | ||||||
| 		proc(&hdr, sizeof(hdr), 1, f); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	proc(_sprite_size, 1, sizeof(_sprite_size), f); |  | ||||||
| 	proc(_sprite_file_pos, 1, sizeof(_sprite_file_pos), f); |  | ||||||
|  |  | ||||||
| #if 0 |  | ||||||
| 	proc(_sprite_xsize, 1, sizeof(_sprite_xsize), f); |  | ||||||
| 	proc(_sprite_ysize, 1, sizeof(_sprite_ysize), f); |  | ||||||
| 	proc(_sprite_xoffs, 1, sizeof(_sprite_xoffs), f); |  | ||||||
| 	proc(_sprite_yoffs, 1, sizeof(_sprite_yoffs), f); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if !defined(WANT_NEW_LRU) |  | ||||||
| 	if (read) |  | ||||||
| 		memset(_sprite_lru, 0xFF, sizeof(_sprite_lru)); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| 	fclose(f); |  | ||||||
| 	return true; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #define S_FREE_MASK 1 | #define S_FREE_MASK 1 | ||||||
|  |  | ||||||
| @@ -822,6 +769,7 @@ void CheckExternalFiles(void) | |||||||
|  |  | ||||||
| static void LoadSpriteTables(void) | static void LoadSpriteTables(void) | ||||||
| { | { | ||||||
|  | 	int load_index = 0; | ||||||
| 	uint i; | 	uint i; | ||||||
| 	uint j; | 	uint j; | ||||||
| 	const FileList *files; // list of grf files to be loaded. Either Windows files or DOS files | 	const FileList *files; // list of grf files to be loaded. Either Windows files or DOS files | ||||||
| @@ -829,11 +777,6 @@ static void LoadSpriteTables(void) | |||||||
| 	_loading_stage = 1; | 	_loading_stage = 1; | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * Note for developers: |  | ||||||
| 	 *   Keep in mind that when you add a LoadGrfIndexed in the 'if'-section below |  | ||||||
| 	 *   that you should also add the corresponding FioOpenFile to the 'else'-section |  | ||||||
| 	 *   below. |  | ||||||
| 	 * |  | ||||||
| 	 * TODO: | 	 * TODO: | ||||||
| 	 *   I think we can live entirely without Indexed GRFs, but I have to | 	 *   I think we can live entirely without Indexed GRFs, but I have to | ||||||
| 	 *   invest that further. --octo | 	 *   invest that further. --octo | ||||||
| @@ -841,25 +784,19 @@ static void LoadSpriteTables(void) | |||||||
|  |  | ||||||
| 	files = _use_dos_palette? &files_dos : &files_win; | 	files = _use_dos_palette? &files_dos : &files_win; | ||||||
|  |  | ||||||
| 	// Try to load the sprites from cache |  | ||||||
| 	if (!HandleCachedSpriteHeaders(_cached_filenames[_opt.landscape], true)) { |  | ||||||
| 		// We do not have the sprites in cache yet, or cache is disabled |  | ||||||
| 		// So just load all files from disk.. |  | ||||||
|  |  | ||||||
| 		int load_index = 0; |  | ||||||
|  |  | ||||||
| 	for (i = 0; files->basic[i].filename != NULL; i++) { | 	for (i = 0; files->basic[i].filename != NULL; i++) { | ||||||
| 			load_index += LoadGrfFile(files->basic[i].filename, load_index, (byte)i); | 		load_index += LoadGrfFile(files->basic[i].filename, load_index, i); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	LoadGrfIndexed("openttd.grf", _openttd_grf_indexes, i++); | 	LoadGrfIndexed("openttd.grf", _openttd_grf_indexes, i++); | ||||||
|  |  | ||||||
| 		if (_sprite_page_to_load != 0) | 	if (_sprite_page_to_load != 0) { | ||||||
| 		LoadGrfIndexed( | 		LoadGrfIndexed( | ||||||
| 			files->landscape[_sprite_page_to_load - 1].filename, | 			files->landscape[_sprite_page_to_load - 1].filename, | ||||||
| 			_landscape_spriteindexes[_sprite_page_to_load - 1], | 			_landscape_spriteindexes[_sprite_page_to_load - 1], | ||||||
| 			i++ | 			i++ | ||||||
| 		); | 		); | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	LoadGrfIndexed("trkfoundw.grf", _slopes_spriteindexes[_opt.landscape], i++); | 	LoadGrfIndexed("trkfoundw.grf", _slopes_spriteindexes[_opt.landscape], i++); | ||||||
|  |  | ||||||
| @@ -879,47 +816,16 @@ static void LoadSpriteTables(void) | |||||||
| 	for (_loading_stage = 0; _loading_stage < 2; _loading_stage++) { | 	for (_loading_stage = 0; _loading_stage < 2; _loading_stage++) { | ||||||
| 		load_index = _custom_sprites_base; | 		load_index = _custom_sprites_base; | ||||||
| 		for (j = 0; j != lengthof(_newgrf_files) && _newgrf_files[j]; j++) { | 		for (j = 0; j != lengthof(_newgrf_files) && _newgrf_files[j]; j++) { | ||||||
| 				if (!FiosCheckFileExists(_newgrf_files[j])) | 			if (!FiosCheckFileExists(_newgrf_files[j])) { | ||||||
| 				// TODO: usrerror() | 				// TODO: usrerror() | ||||||
| 				error("NewGRF file missing: %s", _newgrf_files[j]); | 				error("NewGRF file missing: %s", _newgrf_files[j]); | ||||||
| 				if (_loading_stage == 0) | 			} | ||||||
| 					InitNewGRFFile(_newgrf_files[j], load_index); | 			if (_loading_stage == 0) InitNewGRFFile(_newgrf_files[j], load_index); | ||||||
| 			load_index += LoadNewGrfFile(_newgrf_files[j], load_index, i++); | 			load_index += LoadNewGrfFile(_newgrf_files[j], load_index, i++); | ||||||
| 			DEBUG(spritecache, 2) ("Currently %i sprites are loaded", load_index); | 			DEBUG(spritecache, 2) ("Currently %i sprites are loaded", load_index); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 		// If needed, save the cache to file |  | ||||||
| 		HandleCachedSpriteHeaders(_cached_filenames[_opt.landscape], false); |  | ||||||
| 	} else { |  | ||||||
| 		// We have sprites cached. We just loaded the cached files |  | ||||||
| 		//  now we only have to open a file-pointer to all the original grf-files |  | ||||||
| 		// This is very important. Not all sprites are in the cache. So sometimes |  | ||||||
| 		//  the game needs to load the sprite from disk. When the file is not |  | ||||||
| 		//  open it can not read. So all files that are in the 'if'-section |  | ||||||
| 		//  above should also be in this 'else'-section. |  | ||||||
| 		// |  | ||||||
| 		// NOTE: the order of the files must be identical as in the section above!! |  | ||||||
|  |  | ||||||
| 		for (i = 0; files->basic[i].filename != NULL; i++) |  | ||||||
| 			FioOpenFile(i,files->basic[i].filename); |  | ||||||
|  |  | ||||||
| 		FioOpenFile(i++, "openttd.grf"); |  | ||||||
|  |  | ||||||
| 		if (_sprite_page_to_load != 0) |  | ||||||
| 			FioOpenFile(i++, files->landscape[_sprite_page_to_load - 1].filename); |  | ||||||
|  |  | ||||||
| 		FioOpenFile(i++, "trkfoundw.grf"); |  | ||||||
| 		FioOpenFile(i++, "canalsw.grf"); |  | ||||||
|  |  | ||||||
| 		// FIXME: if a user changes his newgrf's, the cached-sprites gets |  | ||||||
| 		//  invalid. We should have some kind of check for this. |  | ||||||
| 		// The best solution for this is to delete the cached-sprites.. but how |  | ||||||
| 		//  do we detect it? |  | ||||||
| 		for (j = 0; j != lengthof(_newgrf_files) && _newgrf_files[j] != NULL; j++) |  | ||||||
| 			FioOpenFile(i++, _newgrf_files[j]); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	_compact_cache_counter = 0; | 	_compact_cache_counter = 0; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -33,6 +33,4 @@ static inline const byte *GetNonSprite(SpriteID sprite) | |||||||
| void GfxLoadSprites(void); | void GfxLoadSprites(void); | ||||||
| void IncreaseSpriteLRU(void); | void IncreaseSpriteLRU(void); | ||||||
|  |  | ||||||
| extern bool _cache_sprites; |  | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 tron
					tron