Changeset - r9582:cb7711765a81
[Not reviewed]
master
0 3 0
smatz - 16 years ago 2008-06-24 09:15:45
smatz@openttd.org
(svn r13619) -Codechange: use 'const char *' instead of std::string for blitter and driver names
Removes indirect dependency on <string> for 20 files, reduces binary size by 16kB
3 files changed with 33 insertions and 10 deletions:
0 comments (0 inline, 0 general)
src/blitter/factory.hpp
Show inline comments
 
@@ -8,7 +8,6 @@
 
#include "base.hpp"
 
#include "../debug.h"
 
#include "../string_func.h"
 
#include <string>
 
#include <map>
 

	
 
/**
 
@@ -16,8 +15,16 @@
 
 */
 
class BlitterFactoryBase {
 
private:
 
	char *name;
 
	typedef std::map<std::string, BlitterFactoryBase *> Blitters;
 
	const char *name;
 

	
 
	struct StringCompare {
 
		bool operator () (const char *a, const char *b) const
 
		{
 
			return strcmp(a, b) < 0;
 
		}
 
	};
 

	
 
	typedef std::map<const char *, BlitterFactoryBase *, StringCompare> Blitters;
 

	
 
	static Blitters &GetBlitters()
 
	{
 
@@ -58,7 +65,7 @@ public:
 
		if (this->name == NULL) return;
 
		GetBlitters().erase(this->name);
 
		if (GetBlitters().empty()) delete &GetBlitters();
 
		free(this->name);
 
		free((void *)this->name);
 
	}
 

	
 
	/**
src/driver.cpp
Show inline comments
 
@@ -156,7 +156,9 @@ void DriverFactoryBase::RegisterDriver(c
 
	strecpy(buf, GetDriverTypeName(type), lastof(buf));
 
	strecpy(buf + 5, name, lastof(buf));
 

	
 
	std::pair<Drivers::iterator, bool> P = GetDrivers().insert(Drivers::value_type(buf, this));
 
	const char *longname = strdup(buf);
 

	
 
	std::pair<Drivers::iterator, bool> P = GetDrivers().insert(Drivers::value_type(longname, this));
 
	assert(P.second);
 
}
 

	
 
@@ -194,7 +196,14 @@ DriverFactoryBase::~DriverFactoryBase() 
 
	strecpy(buf, GetDriverTypeName(type), lastof(buf));
 
	strecpy(buf + 5, this->name, lastof(buf));
 

	
 
	GetDrivers().erase(buf);
 
	Drivers::iterator it = GetDrivers().find(buf);
 
	assert(it != GetDrivers().end());
 

	
 
	const char *longname = (*it).first;
 

	
 
	GetDrivers().erase(it);
 
	free((void *)longname);
 

	
 
	if (GetDrivers().empty()) delete &GetDrivers();
 
	free(this->name);
 
	free((void *)this->name);
 
}
src/driver.h
Show inline comments
 
@@ -8,7 +8,6 @@
 
#include "debug.h"
 
#include "core/enum_type.hpp"
 
#include "string_func.h"
 
#include <string>
 
#include <map>
 

	
 
bool GetDriverParamBool(const char * const *parm, const char *name);
 
@@ -37,9 +36,17 @@ DECLARE_POSTFIX_INCREMENT(Driver::Type);
 
class DriverFactoryBase {
 
private:
 
	Driver::Type type;
 
	char *name;
 
	const char *name;
 
	int priority;
 
	typedef std::map<std::string, DriverFactoryBase *> Drivers;
 

	
 
	struct StringCompare {
 
		bool operator () (const char *a, const char *b) const
 
		{
 
			return strcmp(a, b) < 0;
 
		}
 
	};
 

	
 
	typedef std::map<const char *, DriverFactoryBase *, StringCompare> Drivers;
 

	
 
	static Drivers &GetDrivers()
 
	{
0 comments (0 inline, 0 general)