summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortron <tron@openttd.org>2005-03-30 19:52:26 +0000
committertron <tron@openttd.org>2005-03-30 19:52:26 +0000
commit3c38db7c2ba6e67a9759b75abca766c43c1a0274 (patch)
treecae4aa874d2b93a6b7a6cf13a0a7950828bd93a3
parent3e4553e55f45a1dc3b6ffab3d0d27830a54ce3e8 (diff)
downloadopenttd-3c38db7c2ba6e67a9759b75abca766c43c1a0274.tar.xz
(svn r2112) -Fix: ExtMidi no longer halts the game while starting a song
-Fix: Redirect stdin/stdout/stderr of the ExtMidi process to /dev/null, to prevent it from writing to the terminal While here give the ExtMidi functions canonical names
-rw-r--r--extmidi.c126
-rw-r--r--music_gui.c2
-rw-r--r--ttd.c4
3 files changed, 70 insertions, 62 deletions
diff --git a/extmidi.c b/extmidi.c
index 7f48969c1..975e618e6 100644
--- a/extmidi.c
+++ b/extmidi.c
@@ -5,6 +5,8 @@
#include "ttd.h"
#include "hal.h"
#include "sound.h"
+#include "string.h"
+#include <fcntl.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
@@ -12,89 +14,97 @@
#include <sys/stat.h>
#include <errno.h>
-static pid_t _pid;
+static struct {
+ char song[MAX_PATH];
+ int pid;
+} _midi;
-static void extmidi_kill(void)
-{
- if (_pid > 0) {
- kill(_pid, SIGKILL);
- while (waitpid(_pid, NULL, WNOHANG) != _pid);
- }
- _pid = 0;
-}
+static void DoPlay(void);
+static void DoStop(void);
-static const char *extmidi_start(const char * const *parm)
+static const char* ExtMidiStart(const char* const * parm)
{
- _pid = 0;
+ _midi.song[0] = '\0';
+ _midi.pid = -1;
return NULL;
}
-static void extmidi_stop(void)
+static void ExtMidiStop(void)
{
- extmidi_kill();
+ _midi.song[0] = '\0';
+ DoStop();
}
-static void extmidi_play_song(const char *filename)
+static void ExtMidiPlaySong(const char* filename)
{
- extmidi_kill();
-
- _pid = fork();
- if (_pid < 0) {
- fprintf(stderr, "extmidi: couldn't fork: %s\n", strerror(errno));
- _pid = 0;
- return;
- }
-
- if (_pid == 0) {
- #if defined(MIDI_ARG)
- execlp(msf.extmidi, "extmidi", MIDI_ARG, filename, NULL);
- #else
- execlp(msf.extmidi, "extmidi", filename, NULL);
- #endif
- fprintf(stderr, "extmidi: couldn't execl: %s\n", strerror(errno));
- exit(0);
- }
-
- usleep(500);
-
- if (_pid == waitpid(_pid, NULL, WNOHANG)) {
- fprintf(stderr, "extmidi: play song failed\n");
- _pid = 0;
+ ttd_strlcpy(_midi.song, filename, lengthof(_midi.song));
+ DoStop();
+}
- usleep(5000);
- }
+static void ExtMidiStopSong(void)
+{
+ _midi.song[0] = '\0';
+ DoStop();
}
-static void extmidi_stop_song(void)
+static bool ExtMidiIsPlaying(void)
{
- extmidi_kill();
+ if (_midi.pid != -1 && waitpid(_midi.pid, NULL, WNOHANG) == _midi.pid)
+ _midi.pid = -1;
+ if (_midi.pid == -1 && _midi.song[0] != '\0') DoPlay();
+ return _midi.pid != -1;
}
-static bool extmidi_is_playing(void)
+static void ExtMidiSetVolume(byte vol)
{
- if (_pid == 0)
- return 0;
+ fprintf(stderr, "extmidi: set volume not implemented\n");
+}
- if (waitpid(_pid, NULL, WNOHANG) == _pid) {
- _pid = 0;
- return 0;
+static void DoPlay(void)
+{
+ _midi.pid = fork();
+ switch (_midi.pid) {
+ case 0: {
+ int d;
+
+ close(0);
+ close(1);
+ close(2);
+ d = open("/dev/null", O_RDONLY);
+ if (d != -1) {
+ if (dup2(d, 1) != -1 && dup2(d, 2) != -1) {
+ #if defined(MIDI_ARG)
+ execlp(msf.extmidi, "extmidi", MIDI_ARG, _midi.song, NULL);
+ #else
+ execlp(msf.extmidi, "extmidi", _midi.song, NULL);
+ #endif
+ }
+ }
+ exit(1);
+ }
+
+ case -1:
+ fprintf(stderr, "extmidi: couldn't fork: %s\n", strerror(errno));
+ /* FALLTHROUGH */
+
+ default:
+ _midi.song[0] = '\0';
+ break;
}
-
- return 1;
}
-static void extmidi_set_volume(byte vol)
+static void DoStop(void)
{
- fprintf(stderr, "extmidi: set volume not implemented\n");
+ if (_midi.pid != -1) kill(_midi.pid, SIGTERM);
}
const HalMusicDriver _extmidi_music_driver = {
- extmidi_start,
- extmidi_stop,
- extmidi_play_song,
- extmidi_stop_song,
- extmidi_is_playing,
- extmidi_set_volume,
+ ExtMidiStart,
+ ExtMidiStop,
+ ExtMidiPlaySong,
+ ExtMidiStopSong,
+ ExtMidiIsPlaying,
+ ExtMidiSetVolume,
};
#endif /* __MORPHOS__ */
diff --git a/music_gui.c b/music_gui.c
index 92105668a..a5e9b3957 100644
--- a/music_gui.c
+++ b/music_gui.c
@@ -181,7 +181,7 @@ void MusicLoop(void)
if (_song_is_active == false)
return;
- if (!_music_driver->is_song_playing()) {
+ if (!_music_driver->is_song_playing() && _game_mode != GM_MENU) {
StopMusic();
SkipToNextSong();
PlayPlaylistSong();
diff --git a/ttd.c b/ttd.c
index 89853699a..430b20e6f 100644
--- a/ttd.c
+++ b/ttd.c
@@ -641,7 +641,6 @@ int ttd_main(int argc, char* argv[])
LoadDriver(SOUND_DRIVER, _ini_sounddriver);
LoadDriver(MUSIC_DRIVER, _ini_musicdriver);
LoadDriver(VIDEO_DRIVER, _ini_videodriver); // load video last, to prevent an empty window while sound and music loads
- MusicLoop();
_savegame_sort_order = 1; // default sorting of savegames is by date, newest first
#ifdef ENABLE_NETWORK
@@ -1165,8 +1164,7 @@ void GameLoop(void)
InputLoop();
- if (_game_mode != GM_MENU)
- MusicLoop();
+ MusicLoop();
}
void BeforeSaveGame(void)