ges: Fix a bunch of leaks

There are definitely more left, but don't have time for more debugging
This commit is contained in:
Edward Hervey 2017-11-27 11:49:04 +01:00 committed by Edward Hervey
parent baa83510fc
commit 9a45d0ef85
7 changed files with 18 additions and 4 deletions

View file

@ -983,6 +983,8 @@ ges_asset_request (GType extractable_type, const gchar * id, GError ** error)
_unsure_material_for_wrong_id (id, extractable_type, lerr); _unsure_material_for_wrong_id (id, extractable_type, lerr);
real_id = g_strdup (id); real_id = g_strdup (id);
} }
if (lerr)
g_error_free (lerr);
asset = ges_asset_cache_lookup (extractable_type, real_id); asset = ges_asset_cache_lookup (extractable_type, real_id);
if (asset) { if (asset) {

View file

@ -486,6 +486,7 @@ _loading_done (GESFormatter * self)
for (tmp = assets; tmp; tmp = tmp->next) { for (tmp = assets; tmp; tmp = tmp->next) {
ges_asset_set_proxy (NULL, tmp->data); ges_asset_set_proxy (NULL, tmp->data);
} }
g_list_free (assets);
g_hash_table_foreach (priv->layers, (GHFunc) _set_auto_transition, NULL); g_hash_table_foreach (priv->layers, (GHFunc) _set_auto_transition, NULL);
ges_project_set_loaded (self->project, self); ges_project_set_loaded (self->project, self);

View file

@ -50,6 +50,7 @@ _fill_track_type (GESAsset * asset)
if (bin_desc) { if (bin_desc) {
ges_track_element_asset_set_track_type (GES_TRACK_ELEMENT_ASSET (asset), ges_track_element_asset_set_track_type (GES_TRACK_ELEMENT_ASSET (asset),
ttype); ttype);
g_free (bin_desc);
} else { } else {
GST_WARNING_OBJECT (asset, "No track type set, you should" GST_WARNING_OBJECT (asset, "No track type set, you should"
" specify one in [audio, video] as first component" " in the asset id"); " specify one in [audio, video] as first component" " in the asset id");

View file

@ -71,6 +71,8 @@ extractable_check_id (GType type, const gchar * id, GError ** error)
else else
g_assert_not_reached (); g_assert_not_reached ();
g_free (bin_desc);
return real_id; return real_id;
} }

View file

@ -1316,18 +1316,18 @@ gboolean
ges_timeline_element_add_child_property (GESTimelineElement * self, ges_timeline_element_add_child_property (GESTimelineElement * self,
GParamSpec * pspec, GObject * child) GParamSpec * pspec, GObject * child)
{ {
gchar *signame = g_strconcat ("notify::", pspec->name, NULL); gchar *signame;
ChildPropHandler *handler; ChildPropHandler *handler;
if (g_hash_table_contains (self->priv->children_props, pspec)) { if (g_hash_table_contains (self->priv->children_props, pspec)) {
GST_INFO_OBJECT (self, "Child property already exists: %s", pspec->name); GST_INFO_OBJECT (self, "Child property already exists: %s", pspec->name);
return FALSE; return FALSE;
} }
GST_DEBUG_OBJECT (self, "Adding child property: %" GST_PTR_FORMAT "::%s", GST_DEBUG_OBJECT (self, "Adding child property: %" GST_PTR_FORMAT "::%s",
child, pspec->name); child, pspec->name);
signame = g_strconcat ("notify::", pspec->name, NULL);
handler = (ChildPropHandler *) g_slice_new0 (ChildPropHandler); handler = (ChildPropHandler *) g_slice_new0 (ChildPropHandler);
handler->child = gst_object_ref (child); handler->child = gst_object_ref (child);
handler->handler_id = handler->handler_id =

View file

@ -369,12 +369,14 @@ static void
_set_meta_file_size (const gchar * uri, GESUriClipAsset * asset) _set_meta_file_size (const gchar * uri, GESUriClipAsset * asset)
{ {
GError *error = NULL; GError *error = NULL;
GFileInfo *file_info; GFileInfo *file_info = NULL;
guint64 file_size; guint64 file_size;
GFile *gfile = NULL;
GESMetaContainer *container = GES_META_CONTAINER (asset); GESMetaContainer *container = GES_META_CONTAINER (asset);
file_info = g_file_query_info (g_file_new_for_uri (uri), "standard::size", gfile = g_file_new_for_uri (uri);
file_info = g_file_query_info (gfile, "standard::size",
G_FILE_QUERY_INFO_NONE, NULL, &error); G_FILE_QUERY_INFO_NONE, NULL, &error);
if (!error) { if (!error) {
file_size = g_file_info_get_attribute_uint64 (file_info, "standard::size"); file_size = g_file_info_get_attribute_uint64 (file_info, "standard::size");
@ -383,6 +385,10 @@ _set_meta_file_size (const gchar * uri, GESUriClipAsset * asset)
} else { } else {
g_error_free (error); g_error_free (error);
} }
if (gfile)
g_object_unref (gfile);
if (file_info)
g_object_unref (file_info);
} }
static void static void

View file

@ -1256,6 +1256,7 @@ _save_layers (GESXmlFormatter * self, GString * str, GESTimeline * timeline)
priv->nbelements++; priv->nbelements++;
} }
g_list_free_full (clips, (GDestroyNotify) gst_object_unref);
g_string_append (str, " </layer>\n"); g_string_append (str, " </layer>\n");
} }
} }
@ -1318,6 +1319,7 @@ _save_groups (GESXmlFormatter * self, GString * str, GESTimeline * timeline)
for (tmp = ges_timeline_get_groups (timeline); tmp; tmp = tmp->next) { for (tmp = ges_timeline_get_groups (timeline); tmp; tmp = tmp->next) {
_save_group (self, str, &seen_groups, tmp->data); _save_group (self, str, &seen_groups, tmp->data);
} }
g_list_free (seen_groups);
g_string_append (str, " </groups>\n"); g_string_append (str, " </groups>\n");
} }