Plug two minor Leaks (#5603)

* Resource leak: CHECK_FILE_ERR returns, without freeing chunk_name.

Found with static analysis.

* Resource leak: leaks `page` on error path.

Found with static analysis.
This commit is contained in:
Auke Kok 2017-04-17 00:04:58 -07:00 committed by Loïc Blot
parent 73de17afa8
commit 97988a1044
2 changed files with 11 additions and 2 deletions

@ -512,9 +512,11 @@ CGUITTGlyphPage* CGUITTFont::createGlyphPage(const u8& pixel_mode)
if (page_texture_size.Width > max_texture_size.Width || page_texture_size.Height > max_texture_size.Height) if (page_texture_size.Width > max_texture_size.Width || page_texture_size.Height > max_texture_size.Height)
page_texture_size = max_texture_size; page_texture_size = max_texture_size;
if (!page->createPageTexture(pixel_mode, page_texture_size)) if (!page->createPageTexture(pixel_mode, page_texture_size)) {
// TODO: add error message? // TODO: add error message?
delete page;
return 0; return 0;
}
if (page) if (page)
{ {

@ -406,7 +406,14 @@ bool ScriptApiSecurity::safeLoadFile(lua_State *L, const char *path)
// Read the file // Read the file
int ret = std::fseek(fp, 0, SEEK_END); int ret = std::fseek(fp, 0, SEEK_END);
CHECK_FILE_ERR(ret, fp); if (ret) {
lua_pushfstring(L, "%s: %s", path, strerror(errno));
std::fclose(fp);
if (path) {
delete [] chunk_name;
}
return false;
}
size_t size = std::ftell(fp) - start; size_t size = std::ftell(fp) - start;
char *code = new char[size]; char *code = new char[size];