(svn r10446) -Codechange: Move extmidi's global data into its class.

pull/155/head
peter1138 17 years ago
parent 767412f410
commit 666241e925

@ -16,47 +16,39 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <errno.h> #include <errno.h>
static struct {
char song[MAX_PATH];
pid_t pid;
} _midi;
static void DoPlay();
static void DoStop();
static FMusicDriver_ExtMidi iFMusicDriver_ExtMidi; static FMusicDriver_ExtMidi iFMusicDriver_ExtMidi;
const char* MusicDriver_ExtMidi::Start(const char* const * parm) const char* MusicDriver_ExtMidi::Start(const char* const * parm)
{ {
_midi.song[0] = '\0'; this->song[0] = '\0';
_midi.pid = -1; this->pid = -1;
return NULL; return NULL;
} }
void MusicDriver_ExtMidi::Stop() void MusicDriver_ExtMidi::Stop()
{ {
_midi.song[0] = '\0'; this->song[0] = '\0';
DoStop(); this->DoStop();
} }
void MusicDriver_ExtMidi::PlaySong(const char* filename) void MusicDriver_ExtMidi::PlaySong(const char* filename)
{ {
ttd_strlcpy(_midi.song, filename, lengthof(_midi.song)); ttd_strlcpy(this->song, filename, lengthof(this->song));
DoStop(); this->DoStop();
} }
void MusicDriver_ExtMidi::StopSong() void MusicDriver_ExtMidi::StopSong()
{ {
_midi.song[0] = '\0'; this->song[0] = '\0';
DoStop(); this->DoStop();
} }
bool MusicDriver_ExtMidi::IsSongPlaying() bool MusicDriver_ExtMidi::IsSongPlaying()
{ {
if (_midi.pid != -1 && waitpid(_midi.pid, NULL, WNOHANG) == _midi.pid) if (this->pid != -1 && waitpid(this->pid, NULL, WNOHANG) == this->pid)
_midi.pid = -1; this->pid = -1;
if (_midi.pid == -1 && _midi.song[0] != '\0') DoPlay(); if (this->pid == -1 && this->song[0] != '\0') this->DoPlay();
return _midi.pid != -1; return this->pid != -1;
} }
void MusicDriver_ExtMidi::SetVolume(byte vol) void MusicDriver_ExtMidi::SetVolume(byte vol)
@ -64,10 +56,10 @@ void MusicDriver_ExtMidi::SetVolume(byte vol)
DEBUG(driver, 1, "extmidi: set volume not implemented"); DEBUG(driver, 1, "extmidi: set volume not implemented");
} }
static void DoPlay() void MusicDriver_ExtMidi::DoPlay()
{ {
_midi.pid = fork(); this->pid = fork();
switch (_midi.pid) { switch (this->pid) {
case 0: { case 0: {
int d; int d;
@ -75,9 +67,9 @@ static void DoPlay()
d = open("/dev/null", O_RDONLY); d = open("/dev/null", O_RDONLY);
if (d != -1 && dup2(d, 1) != -1 && dup2(d, 2) != -1) { if (d != -1 && dup2(d, 1) != -1 && dup2(d, 2) != -1) {
#if defined(MIDI_ARG) #if defined(MIDI_ARG)
execlp(msf.extmidi, "extmidi", MIDI_ARG, _midi.song, (char*)0); execlp(msf.extmidi, "extmidi", MIDI_ARG, this->song, (char*)0);
#else #else
execlp(msf.extmidi, "extmidi", _midi.song, (char*)0); execlp(msf.extmidi, "extmidi", this->song, (char*)0);
#endif #endif
} }
_exit(1); _exit(1);
@ -88,14 +80,14 @@ static void DoPlay()
/* FALLTHROUGH */ /* FALLTHROUGH */
default: default:
_midi.song[0] = '\0'; this->song[0] = '\0';
break; break;
} }
} }
static void DoStop() void MusicDriver_ExtMidi::DoStop()
{ {
if (_midi.pid != -1) kill(_midi.pid, SIGTERM); if (this->pid != -1) kill(this->pid, SIGTERM);
} }
#endif /* __MORPHOS__ */ #endif /* __MORPHOS__ */

@ -6,6 +6,13 @@
#include "music_driver.hpp" #include "music_driver.hpp"
class MusicDriver_ExtMidi: public MusicDriver { class MusicDriver_ExtMidi: public MusicDriver {
private:
char song[MAX_PATH];
pid_t pid;
void DoPlay();
void DoStop();
public: public:
/* virtual */ bool CanProbe() { return true; } /* virtual */ bool CanProbe() { return true; }

Loading…
Cancel
Save