Fix source and buffer out-of-memory conditions
This commit is contained in:
parent
a6213ebfc7
commit
a11f25e47b
@ -95,20 +95,20 @@ ALAPI ALvoid ALAPIENTRY alGenBuffers(ALsizei n,ALuint *puiBuffers)
|
||||
while(i < n)
|
||||
{
|
||||
*list = calloc(1, sizeof(ALbuffer));
|
||||
if(*list)
|
||||
if(!(*list))
|
||||
{
|
||||
puiBuffers[i] = (ALuint)ALTHUNK_ADDENTRY(*list);
|
||||
(*list)->state = UNUSED;
|
||||
g_uiBufferCount++;
|
||||
i++;
|
||||
|
||||
list = &(*list)->next;
|
||||
alDeleteBuffers(i, puiBuffers);
|
||||
alSetError(AL_OUT_OF_MEMORY);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// If we didn't create all the Buffers, we must have run out of memory
|
||||
if (i != n)
|
||||
alSetError(AL_OUT_OF_MEMORY);
|
||||
puiBuffers[i] = (ALuint)ALTHUNK_ADDENTRY(*list);
|
||||
(*list)->state = UNUSED;
|
||||
g_uiBufferCount++;
|
||||
i++;
|
||||
|
||||
list = &(*list)->next;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -65,22 +65,22 @@ ALAPI ALvoid ALAPIENTRY alGenSources(ALsizei n,ALuint *sources)
|
||||
while(i < n)
|
||||
{
|
||||
*list = calloc(1, sizeof(ALsource));
|
||||
if(*list)
|
||||
if(!(*list))
|
||||
{
|
||||
sources[i]=(ALuint)ALTHUNK_ADDENTRY(*list);
|
||||
(*list)->source = sources[i];
|
||||
|
||||
InitSourceParams(*list);
|
||||
Context->SourceCount++;
|
||||
i++;
|
||||
|
||||
list = &(*list)->next;
|
||||
alDeleteSources(i, sources);
|
||||
alSetError(AL_OUT_OF_MEMORY);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// If we didn't create all the Sources, we must have run out or memory
|
||||
if(i != n)
|
||||
alSetError(AL_OUT_OF_MEMORY);
|
||||
sources[i] = (ALuint)ALTHUNK_ADDENTRY(*list);
|
||||
(*list)->source = sources[i];
|
||||
|
||||
InitSourceParams(*list);
|
||||
Context->SourceCount++;
|
||||
i++;
|
||||
|
||||
list = &(*list)->next;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
|
Loading…
x
Reference in New Issue
Block a user