Check variable before g_array_free() call.

Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
Andrew Borodin 2010-11-09 14:05:11 +03:00
parent 79133154b0
commit 9ec4d4c08b
3 changed files with 33 additions and 20 deletions

View File

@ -1619,6 +1619,7 @@ save_file_position (const char *filename, long line, long column, off_t offset,
open_target_error:
g_free (fn);
early_error:
if (bookmarks != NULL)
g_array_free (bookmarks, TRUE);
}

View File

@ -1667,6 +1667,8 @@ extfs_done (struct vfs_class *me)
g_free (info->path);
g_free (info->prefix);
}
if (extfs_plugins != NULL)
g_array_free (extfs_plugins, TRUE);
}

View File

@ -1196,7 +1196,7 @@ hdiff_multi (const char *s, const char *t, const BRACKET bracket, int min, GArra
len = lcsubstr (s + bracket[0].off, bracket[0].len,
t + bracket[1].off, bracket[1].len, ret, min);
if (ret->len)
if (ret->len != 0)
{
size_t k = 0;
const PAIR *data = (const PAIR *) &g_array_index (ret, PAIR, 0);
@ -1830,6 +1830,7 @@ redo_diff (WDiff * dview)
ndiff = dff_execute (dview->args, extra, dview->file[0], dview->file[1], ops);
if (ndiff < 0)
{
if (ops != NULL)
g_array_free (ops, TRUE);
return -1;
}
@ -1845,6 +1846,7 @@ redo_diff (WDiff * dview)
ctx.f = f[1];
rv |= dff_reparse (1, dview->file[1], ops, printer, &ctx);
if (ops != NULL)
g_array_free (ops, TRUE);
if (rv != 0 || dview->a[0]->len != dview->a[1]->len)
@ -1904,10 +1906,8 @@ destroy_hdiff (WDiff * dview)
{
GArray *h = (GArray *) g_ptr_array_index (dview->hdiff, i);
if (h != NULL)
{
g_array_free (h, TRUE);
}
}
g_ptr_array_free (dview->hdiff, TRUE);
dview->hdiff = NULL;
}
@ -2370,22 +2370,26 @@ static void
dview_reread (WDiff * dview)
{
int ndiff = dview->ndiff;
destroy_hdiff (dview);
destroy_hdiff (dview);
if (dview->a[0] != NULL)
{
g_array_foreach (dview->a[0], DIFFLN, cc_free_elt);
g_array_free (dview->a[0], TRUE);
}
if (dview->a[1] != NULL)
{
g_array_foreach (dview->a[1], DIFFLN, cc_free_elt);
g_array_free (dview->a[1], TRUE);
}
dview->a[0] = g_array_new (FALSE, FALSE, sizeof (DIFFLN));
dview->a[1] = g_array_new (FALSE, FALSE, sizeof (DIFFLN));
ndiff = redo_diff (dview);
if (ndiff >= 0)
{
dview->ndiff = ndiff;
}
}
/* --------------------------------------------------------------------------------------------- */
static void
@ -2446,16 +2450,22 @@ dview_fini (WDiff * dview)
str_close_conv (dview->converter);
destroy_hdiff (dview);
if (dview->a[0] != NULL)
{
g_array_foreach (dview->a[0], DIFFLN, cc_free_elt);
g_array_free (dview->a[0], TRUE);
dview->a[0] = NULL;
}
if (dview->a[1] != NULL)
{
g_array_foreach (dview->a[1], DIFFLN, cc_free_elt);
g_array_free (dview->a[1], TRUE);
dview->a[1] = NULL;
}
g_free (dview->label[0]);
g_free (dview->label[1]);
dview->a[1] = NULL;
dview->a[0] = NULL;
}
/* --------------------------------------------------------------------------------------------- */