1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-24 21:26:40 +00:00

Merge remote branch 'corristo/openal'

This commit is contained in:
Marc Zinnschlag 2012-03-30 10:45:31 +02:00
commit cc9a874f2b

View file

@ -441,12 +441,34 @@ void OpenAL_Output::init(const std::string &devname)
try try
{ {
ALCuint maxtotal = std::min<ALCuint>(maxmono+maxstereo, 256); ALCuint maxtotal = std::min<ALCuint>(maxmono+maxstereo, 256);
for(size_t i = 0;i < maxtotal;i++) if (maxtotal == 0) // workaround for broken implementations
{ {
ALuint src = 0; maxtotal = 256;
alGenSources(1, &src); bool stop = false;
throwALerror(); for(size_t i = 0;i < maxtotal && !stop;i++) // generate source until error returned
mFreeSources.push_back(src); {
ALuint src = 0;
alGenSources(1, &src);
ALenum err = alGetError();
if(err != AL_NO_ERROR)
{
stop = true;
}
else
{
mFreeSources.push_back(src);
}
}
}
else // normal case
{
for(size_t i = 0;i < maxtotal;i++)
{
ALuint src = 0;
alGenSources(1, &src);
throwALerror();
mFreeSources.push_back(src);
}
} }
} }
catch(std::exception &e) catch(std::exception &e)