Feature: framework to make savegames self-descriptive
We won't be able to make it fully self-descriptive (looking at you MAP-chunks), but anything else can. With this framework, we can add headers for each chunk explaining how each chunk looks like in detail. They also will all be tables, making it a lot easier to read in external tooling, and opening the way to consider a database (like SQLite) to use as savegame format. Lastly, with the headers in the savegame, you can freely add fields without needing a savegame version bump; older versions of OpenTTD will simply ignore the new field. This also means we can remove all the SLE_CONDNULL, as they are irrelevant. The next few commits will start using this framework.
This commit is contained in:
		 Patric Stout
					Patric Stout
				
			
				
					committed by
					
						 Patric Stout
						Patric Stout
					
				
			
			
				
	
			
			
			 Patric Stout
						Patric Stout
					
				
			
						parent
						
							513641f9ba
						
					
				
				
					commit
					7dd5fd6ed4
				
			| @@ -204,7 +204,7 @@ class SlGamelogEmergency : public DefaultSaveLoadHandler<SlGamelogEmergency, Log | ||||
| public: | ||||
| 	/* We need to store something, so store a "true" value. */ | ||||
| 	inline static const SaveLoad description[] = { | ||||
| 		SLEG_CONDVAR(_is_emergency_save, SLE_BOOL, SLV_RIFF_TO_ARRAY, SL_MAX_VERSION), | ||||
| 		SLEG_CONDVAR("is_emergency_save", _is_emergency_save, SLE_BOOL, SLV_RIFF_TO_ARRAY, SL_MAX_VERSION), | ||||
| 	}; | ||||
|  | ||||
| 	void GenericSaveLoad(LoggedChange *lc) const | ||||
| @@ -224,17 +224,17 @@ class SlGamelogAction : public DefaultSaveLoadHandler<SlGamelogAction, LoggedAct | ||||
| public: | ||||
| 	inline static const SaveLoad description[] = { | ||||
| 		SLE_SAVEBYTE(LoggedChange, ct), | ||||
| 		SLEG_STRUCT(SlGamelogMode), | ||||
| 		SLEG_STRUCT(SlGamelogRevision), | ||||
| 		SLEG_STRUCT(SlGamelogOldver), | ||||
| 		SLEG_STRUCT(SlGamelogSetting), | ||||
| 		SLEG_STRUCT(SlGamelogGrfadd), | ||||
| 		SLEG_STRUCT(SlGamelogGrfrem), | ||||
| 		SLEG_STRUCT(SlGamelogGrfcompat), | ||||
| 		SLEG_STRUCT(SlGamelogGrfparam), | ||||
| 		SLEG_STRUCT(SlGamelogGrfmove), | ||||
| 		SLEG_STRUCT(SlGamelogGrfbug), | ||||
| 		SLEG_STRUCT(SlGamelogEmergency), | ||||
| 		SLEG_STRUCT("mode", SlGamelogMode), | ||||
| 		SLEG_STRUCT("revision", SlGamelogRevision), | ||||
| 		SLEG_STRUCT("oldver", SlGamelogOldver), | ||||
| 		SLEG_STRUCT("setting", SlGamelogSetting), | ||||
| 		SLEG_STRUCT("grfadd", SlGamelogGrfadd), | ||||
| 		SLEG_STRUCT("grfrem", SlGamelogGrfrem), | ||||
| 		SLEG_STRUCT("grfcompat", SlGamelogGrfcompat), | ||||
| 		SLEG_STRUCT("grfparam", SlGamelogGrfparam), | ||||
| 		SLEG_STRUCT("grfmove", SlGamelogGrfmove), | ||||
| 		SLEG_STRUCT("grfbug", SlGamelogGrfbug), | ||||
| 		SLEG_STRUCT("emergency", SlGamelogEmergency), | ||||
| 	}; | ||||
|  | ||||
| 	void Save(LoggedAction *la) const override | ||||
| @@ -285,7 +285,7 @@ public: | ||||
| static const SaveLoad _gamelog_desc[] = { | ||||
| 	SLE_CONDVAR(LoggedAction, at,            SLE_UINT8,   SLV_RIFF_TO_ARRAY, SL_MAX_VERSION), | ||||
| 	SLE_VAR(LoggedAction, tick,              SLE_UINT16), | ||||
| 	SLEG_STRUCTLIST(SlGamelogAction), | ||||
| 	SLEG_STRUCTLIST("action", SlGamelogAction), | ||||
| }; | ||||
|  | ||||
| static void Load_GLOG_common(LoggedAction *&gamelog_action, uint &gamelog_actions) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user