1
0
Fork 0

(svn r2742) Get rid of some void pointers plus a few minor changes, like 0 -> '\0'

release/0.4.5
tron 2005-07-29 06:20:28 +00:00
parent a2a5593fcc
commit 79292d193e
1 changed files with 43 additions and 41 deletions

View File

@ -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;