summaryrefslogtreecommitdiffstats
path: root/OpenAL32/alSource.c
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2011-08-20 23:59:24 -0700
committerChris Robinson <[email protected]>2011-08-20 23:59:24 -0700
commitf196a9fc67551aef43f75c3e36f3031170a03dac (patch)
treeb320e7754450bbd7eddc75875b3e9c21e9857377 /OpenAL32/alSource.c
parent7ea71d8bfaa7a05e329ab15ca8828cbc7fe7d00f (diff)
Defer source state changes from alSourcePlay/Pause/Stop/Rewind calls
Diffstat (limited to 'OpenAL32/alSource.c')
-rw-r--r--OpenAL32/alSource.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/OpenAL32/alSource.c b/OpenAL32/alSource.c
index f1007507..113970e6 100644
--- a/OpenAL32/alSource.c
+++ b/OpenAL32/alSource.c
@@ -1376,7 +1376,8 @@ AL_API ALvoid AL_APIENTRY alSourcePlayv(ALsizei n, const ALuint *sources)
for(i = 0;i < n;i++)
{
Source = (ALsource*)ALTHUNK_LOOKUPENTRY(sources[i]);
- SetSourceState(Source, Context, AL_PLAYING);
+ if(Context->DeferUpdates) Source->new_state = AL_PLAYING;
+ else SetSourceState(Source, Context, AL_PLAYING);
}
done:
@@ -1421,7 +1422,8 @@ AL_API ALvoid AL_APIENTRY alSourcePausev(ALsizei n, const ALuint *sources)
for(i = 0;i < n;i++)
{
Source = (ALsource*)ALTHUNK_LOOKUPENTRY(sources[i]);
- SetSourceState(Source, Context, AL_PAUSED);
+ if(Context->DeferUpdates) Source->new_state = AL_PAUSED;
+ else SetSourceState(Source, Context, AL_PAUSED);
}
done:
@@ -1466,7 +1468,8 @@ AL_API ALvoid AL_APIENTRY alSourceStopv(ALsizei n, const ALuint *sources)
for(i = 0;i < n;i++)
{
Source = (ALsource*)ALTHUNK_LOOKUPENTRY(sources[i]);
- SetSourceState(Source, Context, AL_STOPPED);
+ if(Context->DeferUpdates) Source->new_state = AL_STOPPED;
+ else SetSourceState(Source, Context, AL_STOPPED);
}
done:
@@ -1511,7 +1514,8 @@ AL_API ALvoid AL_APIENTRY alSourceRewindv(ALsizei n, const ALuint *sources)
for(i = 0;i < n;i++)
{
Source = (ALsource*)ALTHUNK_LOOKUPENTRY(sources[i]);
- SetSourceState(Source, Context, AL_INITIAL);
+ if(Context->DeferUpdates) Source->new_state = AL_INITIAL;
+ else SetSourceState(Source, Context, AL_INITIAL);
}
done:
@@ -1772,6 +1776,7 @@ static ALvoid InitSourceParams(ALsource *Source)
Source->Resampler = DefaultResampler;
Source->state = AL_INITIAL;
+ Source->new_state = AL_NONE;
Source->lSourceType = AL_UNDETERMINED;
Source->NeedsUpdate = AL_TRUE;