File diff r6955:42f59093f6f9 → r6956:6398843f1341
src/newgrf_config.cpp
Show inline comments
 
@@ -124,8 +124,9 @@ void ClearGRFConfigList(GRFConfig **conf
 
/** Copy a GRF Config list
 
 * @param dst pointer to destination list
 
 * @param src pointer to source list values
 
 * @param init_only the copied GRF will be processed up to GLS_INIT
 
 * @return pointer to the last value added to the destination list */
 
GRFConfig **CopyGRFConfigList(GRFConfig **dst, const GRFConfig *src)
 
GRFConfig **CopyGRFConfigList(GRFConfig **dst, const GRFConfig *src, bool init_only)
 
{
 
	/* Clear destination as it will be overwritten */
 
	ClearGRFConfigList(dst);
 
@@ -143,6 +144,8 @@ GRFConfig **CopyGRFConfigList(GRFConfig 
 
			if (src->error->custom_message != NULL) c->error->custom_message = strdup(src->error->custom_message);
 
		}
 

	
 
		if (init_only) SETBIT(c->flags, GCF_INIT_ONLY);
 

	
 
		*dst = c;
 
		dst = &c->next;
 
	}
 
@@ -190,7 +193,7 @@ void AppendStaticGRFConfigs(GRFConfig **
 
	GRFConfig **tail = dst;
 
	while (*tail != NULL) tail = &(*tail)->next;
 

	
 
	CopyGRFConfigList(tail, _grfconfig_static);
 
	CopyGRFConfigList(tail, _grfconfig_static, false);
 
	RemoveDuplicatesFromGRFConfigList(*dst);
 
}
 

	
 
@@ -210,14 +213,7 @@ void AppendToGRFConfigList(GRFConfig **d
 
/* Reset the current GRF Config to either blank or newgame settings */
 
void ResetGRFConfig(bool defaults)
 
{
 
	GRFConfig **c = &_grfconfig;
 

	
 
	if (defaults) {
 
		c = CopyGRFConfigList(c, _grfconfig_newgame);
 
	} else {
 
		ClearGRFConfigList(c);
 
	}
 

	
 
	CopyGRFConfigList(&_grfconfig, _grfconfig_newgame, !defaults);
 
	AppendStaticGRFConfigs(&_grfconfig);
 
}