mirror of https://github.com/OpenTTD/OpenTTD
(svn r13126) -Fix (r13022) [FS#2009, FS#2010]: driver list should be dynamically allocated as static uninitialistion order is undetermined. The list is freed when the latest driver is removed.
parent
5469686001
commit
180272ed86
11
src/driver.h
11
src/driver.h
|
@ -43,7 +43,7 @@ private:
|
||||||
|
|
||||||
static Drivers &GetDrivers()
|
static Drivers &GetDrivers()
|
||||||
{
|
{
|
||||||
static Drivers s_drivers;
|
static Drivers &s_drivers = *new Drivers();
|
||||||
return s_drivers;
|
return s_drivers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,7 +71,14 @@ public:
|
||||||
*/
|
*/
|
||||||
virtual ~DriverFactoryBase() {
|
virtual ~DriverFactoryBase() {
|
||||||
if (this->name == NULL) return;
|
if (this->name == NULL) return;
|
||||||
GetDrivers().erase(this->name);
|
|
||||||
|
/* Prefix the name with driver type to make it unique */
|
||||||
|
char buf[32];
|
||||||
|
strecpy(buf, GetDriverTypeName(type), lastof(buf));
|
||||||
|
strecpy(buf + 5, this->name, lastof(buf));
|
||||||
|
|
||||||
|
GetDrivers().erase(buf);
|
||||||
|
if (GetDrivers().empty()) delete &GetDrivers();
|
||||||
free(this->name);
|
free(this->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue