File diff r14666:896110212413 → r14667:a7ee51a0cfe3
src/newgrf_config.cpp
Show inline comments
 
@@ -20,6 +20,21 @@
 
#include "fileio_func.h"
 
#include "fios.h"
 

	
 
GRFConfig::GRFConfig(const char *filename)
 
{
 
	if (filename != NULL) this->filename = strdup(filename);
 
}
 

	
 
GRFConfig::~GRFConfig()
 
{
 
	/* GCF_COPY as in NOT strdupped/alloced the filename, name and info */
 
	if (!HasBit(this->flags, GCF_COPY)) {
 
		free(this->filename);
 
		free(this->name);
 
		free(this->info);
 
		delete this->error;
 
	}
 
}
 

	
 
GRFConfig *_all_grfs;
 
GRFConfig *_grfconfig;
 
@@ -105,27 +120,13 @@ bool FillGRFDetails(GRFConfig *config, b
 
}
 

	
 

	
 
void ClearGRFConfig(GRFConfig **config)
 
{
 
	/* GCF_COPY as in NOT strdupped/alloced the filename, name and info */
 
	if (!HasBit((*config)->flags, GCF_COPY)) {
 
		free((*config)->filename);
 
		free((*config)->name);
 
		free((*config)->info);
 
		delete (*config)->error;
 
	}
 
	free(*config);
 
	*config = NULL;
 
}
 

	
 

	
 
/* Clear a GRF Config list */
 
void ClearGRFConfigList(GRFConfig **config)
 
{
 
	GRFConfig *c, *next;
 
	for (c = *config; c != NULL; c = next) {
 
		next = c->next;
 
		ClearGRFConfig(&c);
 
		delete c;
 
	}
 
	*config = NULL;
 
}
 
@@ -138,7 +139,7 @@ void ClearGRFConfigList(GRFConfig **conf
 
 */
 
GRFConfig *DuplicateGRFConfig(const GRFConfig *c)
 
{
 
	GRFConfig *config = MallocT<GRFConfig>(1);
 
	GRFConfig *config = new GRFConfig();
 
	*config = *c;
 

	
 
	if (c->filename != NULL) config->filename = strdup(c->filename);
 
@@ -203,7 +204,7 @@ static void RemoveDuplicatesFromGRFConfi
 
		if (cur->ident.grfid != list->ident.grfid) continue;
 

	
 
		prev->next = cur->next;
 
		ClearGRFConfig(&cur);
 
		delete cur;
 
		cur = prev; // Just go back one so it continues as normal later on
 
	}
 

	
 
@@ -320,8 +321,7 @@ public:
 

	
 
bool GRFFileScanner::AddFile(const char *filename, size_t basepath_length)
 
{
 
	GRFConfig *c = CallocT<GRFConfig>(1);
 
	c->filename = strdup(filename + basepath_length);
 
	GRFConfig *c = new GRFConfig(filename + basepath_length);
 

	
 
	bool added = true;
 
	if (FillGRFDetails(c, false)) {
 
@@ -355,7 +355,7 @@ bool GRFFileScanner::AddFile(const char 
 
	if (!added) {
 
		/* File couldn't be opened, or is either not a NewGRF or is a
 
		 * 'system' NewGRF or it's already known, so forget about it. */
 
		ClearGRFConfig(&c);
 
		delete c;
 
	}
 

	
 
	return added;