summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSimon Howard2009-10-31 16:47:49 +0000
committerSimon Howard2009-10-31 16:47:49 +0000
commit299e1c5abf804e2e249c4f77b82fb7949a3f9d7b (patch)
treeee035310252568c943f242f46c6530af70b68ef0 /src
parent14bcdd1008db070bc4a12be73e3f692c1990966e (diff)
downloadchocolate-doom-299e1c5abf804e2e249c4f77b82fb7949a3f9d7b.tar.gz
chocolate-doom-299e1c5abf804e2e249c4f77b82fb7949a3f9d7b.tar.bz2
chocolate-doom-299e1c5abf804e2e249c4f77b82fb7949a3f9d7b.zip
When replacing an existing voice, discard voices that are the second
voice of a two voice instrument. Don't discard instruments from lower numbered MIDI channels for higher numbered MIDI channels. Subversion-branch: /branches/opl-branch Subversion-revision: 1727
Diffstat (limited to 'src')
-rw-r--r--src/i_oplmusic.c20
1 files changed, 18 insertions, 2 deletions
diff --git a/src/i_oplmusic.c b/src/i_oplmusic.c
index 89e73f1a..9501d51d 100644
--- a/src/i_oplmusic.c
+++ b/src/i_oplmusic.c
@@ -631,6 +631,16 @@ static void KeyOffEvent(opl_track_data_t *track, midi_event_t *event)
}
}
+// Compare the priorities of channels, returning either -1, 0 or 1.
+
+static int CompareChannelPriorities(opl_channel_data_t *chan1,
+ opl_channel_data_t *chan2)
+{
+ // TODO ...
+
+ return 1;
+}
+
// When all voices are in use, we must discard an existing voice to
// play a new note. Find and free an existing voice. The channel
// passed to the function is the channel for the new note to be
@@ -643,13 +653,19 @@ static opl_voice_t *ReplaceExistingVoice(opl_channel_data_t *channel)
// Check the allocated voices, if we find an instrument that is
// of a lower priority to the new instrument, discard it.
- // Priority is determined by MIDI instrument number; old
+ // If a voice is being used to play the second voice of an instrument,
+ // use that, as second voices are non-essential.
+ // Lower numbered MIDI channels implicitly have a higher priority
+ // than higher-numbered channels, eg. MIDI channel 1 is never
+ // discarded for MIDI channel 2.
result = NULL;
for (rover = voice_alloced_list; rover != NULL; rover = rover->next)
{
- if (rover->current_instr > channel->instrument)
+ if (rover->current_instr_voice != 0
+ || (rover->channel > channel
+ && CompareChannelPriorities(channel, rover->channel) > 0))
{
result = rover;
break;