extmidi.c
author darkvater
Sun, 14 Nov 2004 13:59:11 +0000
changeset 398 160e40c179fd
parent 342 c16e965ab592
child 1301 bf64ba5b6774
permissions -rw-r--r--
(svn r590) -newgrf: Instead of a bunch of statinfo arrays, use station-array of struct StationSpec-s (pasky).
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     1
#ifndef __BEOS__
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     2
#ifndef __MORPHOS__
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     3
#include "stdafx.h"
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     4
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     5
#include "ttd.h"
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     6
#include "hal.h"
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     7
#include <sys/types.h>
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     8
#include <sys/wait.h>
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
     9
#include <unistd.h>
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    10
#include <signal.h>
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    11
#include <sys/stat.h>
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    12
#include <errno.h>
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    13
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    14
#ifndef EXTERNAL_PLAYER
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    15
#define EXTERNAL_PLAYER "timidity"
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    16
#endif
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    17
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    18
static pid_t _pid;
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    19
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    20
static void extmidi_kill(void)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    21
{
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    22
	if (_pid > 0) {
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    23
		kill(_pid, SIGKILL);
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    24
		while (waitpid(_pid, NULL, WNOHANG) != _pid);
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    25
	}
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    26
	_pid = 0;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    27
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    28
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    29
static char *extmidi_start(char **parm)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    30
{
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    31
	_pid = 0;
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    32
	return NULL;
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    33
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    34
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    35
static void extmidi_stop(void)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    36
{
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    37
	extmidi_kill();
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    38
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    39
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    40
static void extmidi_play_song(const char *filename)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    41
{
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    42
	extmidi_kill();
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    43
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    44
	_pid = fork();
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    45
	if (_pid < 0) {
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    46
		fprintf(stderr, "extmidi: couldn't fork: %s\n", strerror(errno));
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    47
		_pid = 0;
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    48
		return;
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    49
	}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    50
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    51
	if (_pid == 0) {
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    52
		#if defined(MIDI_ARG)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    53
			execlp(EXTERNAL_PLAYER, "extmidi", MIDI_ARG, filename, NULL);
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    54
		#else
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    55
			execlp(EXTERNAL_PLAYER, "extmidi", filename, NULL);
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    56
		#endif
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    57
		fprintf(stderr, "extmidi: couldn't execl: %s\n", strerror(errno));
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    58
		exit(0);
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    59
	}
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    60
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    61
	usleep(500);
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    62
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    63
	if (_pid == waitpid(_pid, NULL, WNOHANG)) {
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    64
		fprintf(stderr, "extmidi: play song failed\n");
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    65
		_pid = 0;
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    66
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    67
		usleep(5000);
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    68
	}
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    69
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    70
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    71
static void extmidi_stop_song(void)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    72
{
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    73
	extmidi_kill();
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    74
}
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    75
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    76
static bool extmidi_is_playing(void)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    77
{
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    78
	if (_pid == 0)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    79
		return 0;
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    80
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    81
	if (waitpid(_pid, NULL, WNOHANG) == _pid) {
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    82
		_pid = 0;
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    83
		return 0;
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    84
	}
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    85
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    86
	return 1;
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    87
}
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    88
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    89
static void extmidi_set_volume(byte vol)
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    90
{
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
    91
	fprintf(stderr, "extmidi: set volume not implemented\n");
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    92
}
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    93
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    94
const HalMusicDriver _extmidi_music_driver = {
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    95
	extmidi_start,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    96
	extmidi_stop,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    97
	extmidi_play_song,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    98
	extmidi_stop_song,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
    99
	extmidi_is_playing,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   100
	extmidi_set_volume,
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   101
};
342
c16e965ab592 (svn r518) Merge extmidi.c r441 to trunk:
tron
parents: 0
diff changeset
   102
0
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   103
#endif /* __MORPHOS__ */
29654efe3188 (svn r1) Import of revision 975 of old (crashed) SVN
truelight
parents:
diff changeset
   104
#endif /* __BEOS__ */