mirror of https://github.com/OpenTTD/OpenTTD
(svn r2742) Get rid of some void pointers plus a few minor changes, like 0 -> '\0'
parent
a2a5593fcc
commit
79292d193e
84
driver.c
84
driver.c
|
@ -27,69 +27,73 @@
|
||||||
typedef struct DriverDesc {
|
typedef struct DriverDesc {
|
||||||
const char* name;
|
const char* name;
|
||||||
const char* longname;
|
const char* longname;
|
||||||
const void* drv;
|
const HalCommonDriver* drv;
|
||||||
} DriverDesc;
|
} DriverDesc;
|
||||||
|
|
||||||
typedef struct DriverClass {
|
typedef struct DriverClass {
|
||||||
const DriverDesc *descs;
|
const DriverDesc *descs;
|
||||||
const char *name;
|
const char *name;
|
||||||
void *var;
|
const HalCommonDriver** drv;
|
||||||
} DriverClass;
|
} DriverClass;
|
||||||
|
|
||||||
|
|
||||||
|
#define M(x, y, z) { x, y, (const HalCommonDriver*)z }
|
||||||
static const DriverDesc _music_driver_descs[] = {
|
static const DriverDesc _music_driver_descs[] = {
|
||||||
#ifdef __BEOS__
|
#ifdef __BEOS__
|
||||||
{ "bemidi", "BeOS MIDI Driver", &_bemidi_music_driver },
|
M("bemidi", "BeOS MIDI Driver", &_bemidi_music_driver),
|
||||||
#endif
|
#endif
|
||||||
#ifdef __OS2__
|
#ifdef __OS2__
|
||||||
{ "os2", "OS/2 Music Driver", &_os2_music_driver},
|
M("os2", "OS/2 Music Driver", &_os2_music_driver),
|
||||||
#endif
|
#endif
|
||||||
#ifdef WIN32_ENABLE_DIRECTMUSIC_SUPPORT
|
#ifdef WIN32_ENABLE_DIRECTMUSIC_SUPPORT
|
||||||
{ "dmusic", "DirectMusic MIDI Driver", &_dmusic_midi_driver },
|
M("dmusic", "DirectMusic MIDI Driver", &_dmusic_midi_driver),
|
||||||
#endif
|
#endif
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
{ "win32", "Win32 MIDI Driver", &_win32_music_driver },
|
M("win32", "Win32 MIDI Driver", &_win32_music_driver),
|
||||||
#endif
|
#endif
|
||||||
#ifdef UNIX
|
#ifdef UNIX
|
||||||
#if !defined(__BEOS__) && !defined(__MORPHOS__) && !defined(__AMIGA__)
|
#if !defined(__BEOS__) && !defined(__MORPHOS__) && !defined(__AMIGA__)
|
||||||
{ "extmidi", "External MIDI Driver", &_extmidi_music_driver },
|
M("extmidi", "External MIDI Driver", &_extmidi_music_driver),
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
{ "null", "Null Music Driver", &_null_music_driver },
|
M("null", "Null Music Driver", &_null_music_driver),
|
||||||
{ NULL, NULL, NULL}
|
M(NULL, NULL, NULL)
|
||||||
};
|
};
|
||||||
|
|
||||||
static const DriverDesc _sound_driver_descs[] = {
|
static const DriverDesc _sound_driver_descs[] = {
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
{ "win32", "Win32 WaveOut Driver", &_win32_sound_driver },
|
M("win32", "Win32 WaveOut Driver", &_win32_sound_driver),
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_SDL
|
#ifdef WITH_SDL
|
||||||
{ "sdl", "SDL Sound Driver", &_sdl_sound_driver },
|
M("sdl", "SDL Sound Driver", &_sdl_sound_driver),
|
||||||
#endif
|
#endif
|
||||||
{ "null", "Null Sound Driver", &_null_sound_driver },
|
M("null", "Null Sound Driver", &_null_sound_driver),
|
||||||
{ NULL, NULL, NULL}
|
M(NULL, NULL, NULL)
|
||||||
};
|
};
|
||||||
|
|
||||||
static const DriverDesc _video_driver_descs[] = {
|
static const DriverDesc _video_driver_descs[] = {
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
{ "win32", "Win32 GDI Video Driver", &_win32_video_driver },
|
M("win32", "Win32 GDI Video Driver", &_win32_video_driver),
|
||||||
#endif
|
#endif
|
||||||
#ifdef WITH_SDL
|
#ifdef WITH_SDL
|
||||||
{ "sdl", "SDL Video Driver", &_sdl_video_driver },
|
M("sdl", "SDL Video Driver", &_sdl_video_driver),
|
||||||
#endif
|
#endif
|
||||||
{ "null", "Null Video Driver", &_null_video_driver},
|
M("null", "Null Video Driver", &_null_video_driver),
|
||||||
#ifdef ENABLE_NETWORK
|
#ifdef ENABLE_NETWORK
|
||||||
{ "dedicated", "Dedicated Video Driver", &_dedicated_video_driver},
|
M("dedicated", "Dedicated Video Driver", &_dedicated_video_driver),
|
||||||
#endif
|
#endif
|
||||||
{ NULL, NULL, NULL}
|
M(NULL, NULL, NULL)
|
||||||
};
|
};
|
||||||
|
#undef M
|
||||||
|
|
||||||
|
|
||||||
|
#define M(x, y, z) { x, y, (const HalCommonDriver**)z }
|
||||||
static const DriverClass _driver_classes[] = {
|
static const DriverClass _driver_classes[] = {
|
||||||
{_video_driver_descs, "video", &_video_driver},
|
M(_video_driver_descs, "video", &_video_driver),
|
||||||
{_sound_driver_descs, "sound", &_sound_driver},
|
M(_sound_driver_descs, "sound", &_sound_driver),
|
||||||
{_music_driver_descs, "music", &_music_driver},
|
M(_music_driver_descs, "music", &_music_driver)
|
||||||
};
|
};
|
||||||
|
#undef M
|
||||||
|
|
||||||
static const DriverDesc* GetDriverByName(const DriverDesc* dd, const char* name)
|
static const DriverDesc* GetDriverByName(const DriverDesc* dd, const char* name)
|
||||||
{
|
{
|
||||||
|
@ -103,18 +107,11 @@ void LoadDriver(int driver, const char *name)
|
||||||
{
|
{
|
||||||
const DriverClass *dc = &_driver_classes[driver];
|
const DriverClass *dc = &_driver_classes[driver];
|
||||||
const DriverDesc *dd;
|
const DriverDesc *dd;
|
||||||
const void **var;
|
|
||||||
const void *drv;
|
|
||||||
const char *err;
|
const char *err;
|
||||||
char *parm;
|
|
||||||
char buffer[256];
|
|
||||||
const char *parms[32];
|
|
||||||
|
|
||||||
parms[0] = NULL;
|
|
||||||
|
|
||||||
if (*name == '\0') {
|
if (*name == '\0') {
|
||||||
for (dd = dc->descs; dd->name != NULL; dd++) {
|
for (dd = dc->descs; dd->name != NULL; dd++) {
|
||||||
err = ((const HalCommonDriver*)dd->drv)->start(parms);
|
err = dd->drv->start(NULL);
|
||||||
if (err == NULL) break;
|
if (err == NULL) break;
|
||||||
DEBUG(driver, 1) ("Probing %s driver \"%s\" failed with error: %s",
|
DEBUG(driver, 1) ("Probing %s driver \"%s\" failed with error: %s",
|
||||||
dc->name, dd->name, err
|
dc->name, dd->name, err
|
||||||
|
@ -127,20 +124,24 @@ void LoadDriver(int driver, const char *name)
|
||||||
DEBUG(driver, 1)
|
DEBUG(driver, 1)
|
||||||
("Successfully probed %s driver \"%s\"", dc->name, dd->name);
|
("Successfully probed %s driver \"%s\"", dc->name, dd->name);
|
||||||
|
|
||||||
var = dc->var;
|
*dc->drv = dd->drv;
|
||||||
*var = dd->drv;
|
|
||||||
} else {
|
} else {
|
||||||
|
char* parm;
|
||||||
|
char buffer[256];
|
||||||
|
const char* parms[32];
|
||||||
|
|
||||||
// Extract the driver name and put parameter list in parm
|
// Extract the driver name and put parameter list in parm
|
||||||
ttd_strlcpy(buffer, name, sizeof(buffer));
|
ttd_strlcpy(buffer, name, sizeof(buffer));
|
||||||
parm = strchr(buffer, ':');
|
parm = strchr(buffer, ':');
|
||||||
if (parm) {
|
parms[0] = NULL;
|
||||||
|
if (parm != NULL) {
|
||||||
uint np = 0;
|
uint np = 0;
|
||||||
// Tokenize the parm.
|
// Tokenize the parm.
|
||||||
do {
|
do {
|
||||||
*parm++ = 0;
|
*parm++ = '\0';
|
||||||
if (np < lengthof(parms) - 1)
|
if (np < lengthof(parms) - 1)
|
||||||
parms[np++] = parm;
|
parms[np++] = parm;
|
||||||
while (*parm != 0 && *parm != ',')
|
while (*parm != '\0' && *parm != ',')
|
||||||
parm++;
|
parm++;
|
||||||
} while (*parm == ',');
|
} while (*parm == ',');
|
||||||
parms[np] = NULL;
|
parms[np] = NULL;
|
||||||
|
@ -149,26 +150,27 @@ void LoadDriver(int driver, const char *name)
|
||||||
if (dd == NULL)
|
if (dd == NULL)
|
||||||
error("No such %s driver: %s\n", dc->name, buffer);
|
error("No such %s driver: %s\n", dc->name, buffer);
|
||||||
|
|
||||||
var = dc->var;
|
if (*dc->drv != NULL) (*dc->drv)->stop();
|
||||||
if (*var != NULL) ((const HalCommonDriver*)*var)->stop();
|
*dc->drv = NULL;
|
||||||
*var = NULL;
|
|
||||||
drv = dd->drv;
|
|
||||||
|
|
||||||
err = ((const HalCommonDriver*)drv)->start(parms);
|
err = dd->drv->start(parms);
|
||||||
if (err != NULL) {
|
if (err != NULL) {
|
||||||
error("Unable to load driver %s(%s). The error was: %s\n",
|
error("Unable to load driver %s(%s). The error was: %s\n",
|
||||||
dd->name, dd->longname, err
|
dd->name, dd->longname, err
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
*var = drv;
|
*dc->drv = dd->drv;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static const char* GetDriverParam(const char* const* parm, const char* name)
|
static const char* GetDriverParam(const char* const* parm, const char* name)
|
||||||
{
|
{
|
||||||
uint len = strlen(name);
|
uint len;
|
||||||
|
|
||||||
|
if (parm == NULL) return NULL;
|
||||||
|
|
||||||
|
len = strlen(name);
|
||||||
for (; *parm != NULL; parm++) {
|
for (; *parm != NULL; parm++) {
|
||||||
const char* p = *parm;
|
const char* p = *parm;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue