2008-10-23 18:06:26 -04:00
|
|
|
$OpenBSD: patch-playercode_mplayer_c,v 1.5 2008/10/23 22:06:28 miod Exp $
|
|
|
|
--- playercode/mplayer.c.orig Mon Jan 21 21:23:56 2002
|
|
|
|
+++ playercode/mplayer.c Wed Oct 22 19:56:49 2008
|
|
|
|
@@ -254,7 +254,7 @@ static int MP_FindEmptyChannel(MODULE *mod)
|
2002-03-03 19:02:46 -05:00
|
|
|
Voice_Stopped_internal(t))
|
|
|
|
return t;
|
|
|
|
|
|
|
|
- tvol=0xffffffUL;t=0;a=mod->voice;
|
|
|
|
+ tvol=0xffffffUL;t=-1;a=mod->voice;
|
|
|
|
for (k=0;k<md_sngchn;k++,a++) {
|
|
|
|
/* allow us to take over a nonexisting sample */
|
|
|
|
if (!a->main.s)
|
2008-10-23 18:06:26 -04:00
|
|
|
@@ -367,9 +367,9 @@ static SWORD StartEnvelope(ENVPR *t,UBYTE flg,UBYTE pt
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Fit in the envelope, still */
|
|
|
|
- if (t->a >= t->pts)
|
|
|
|
+ if (t->a >= t->pts && t->pts != 0)
|
|
|
|
t->a = t->pts - 1;
|
|
|
|
- if (t->b >= t->pts)
|
|
|
|
+ if (t->b >= t->pts && t->pts != 0)
|
|
|
|
t->b = t->pts-1;
|
|
|
|
|
|
|
|
return t->env[t->a].val;
|
|
|
|
@@ -442,24 +442,22 @@ static SWORD ProcessEnvelope(MP_VOICE *aout, ENVPR *t,
|
2002-03-15 04:30:33 -05:00
|
|
|
} else
|
|
|
|
/*
|
2002-03-03 19:02:46 -05:00
|
|
|
* Non looping situations.
|
2002-03-15 04:30:33 -05:00
|
|
|
- * Start to fade if the volume envelope is finished.
|
2002-03-03 19:02:46 -05:00
|
|
|
*/
|
|
|
|
- if (p > t->env[t->pts - 1].pos) {
|
2002-03-15 04:30:33 -05:00
|
|
|
+ if (a != b)
|
|
|
|
+ v = InterpolateEnv(p, &t->env[a], &t->env[b]);
|
|
|
|
+ else
|
2002-03-03 19:02:46 -05:00
|
|
|
v = t->env[a].val;
|
2002-03-15 04:30:33 -05:00
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * Start to fade if the volume envelope is finished.
|
|
|
|
+ */
|
|
|
|
+ if (p >= t->env[t->pts - 1].pos) {
|
2002-03-03 19:02:46 -05:00
|
|
|
if (t->flg & EF_VOLENV) {
|
|
|
|
aout->main.keyoff |= KEY_FADE;
|
2002-03-15 04:30:33 -05:00
|
|
|
if (!v)
|
|
|
|
aout->main.fadevol = 0;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
- /*
|
|
|
|
- * Regular processing : compute value, progress one step.
|
|
|
|
- */
|
|
|
|
- if (a != b)
|
|
|
|
- v = InterpolateEnv(p, &t->env[a], &t->env[b]);
|
|
|
|
- else
|
|
|
|
- v = t->env[a].val;
|
|
|
|
-
|
|
|
|
p++;
|
|
|
|
/* did pointer reach point b? */
|
|
|
|
if (p >= t->env[b].pos)
|