From 575c4865a0818f6e55e1f5cd8255435d78783bd7 Mon Sep 17 00:00:00 2001 From: Edward Hervey Date: Mon, 21 Jun 2010 11:53:30 +0200 Subject: [PATCH] GESTimelinePipeline: Make a copy of the provided GstEncodingProfile --- ges/ges-timeline-pipeline.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/ges/ges-timeline-pipeline.c b/ges/ges-timeline-pipeline.c index 611480097e..aeec8da3e9 100644 --- a/ges/ges-timeline-pipeline.c +++ b/ges/ges-timeline-pipeline.c @@ -74,6 +74,11 @@ ges_timeline_pipeline_dispose (GObject * object) self->encodebin = NULL; } + if (self->profile) { + gst_encoding_profile_free (self->profile); + self->profile = NULL; + } + G_OBJECT_CLASS (ges_timeline_pipeline_parent_class)->dispose (object); } @@ -534,10 +539,13 @@ ges_timeline_pipeline_add_timeline (GESTimelinePipeline * pipeline, * ges_timeline_pipeline_set_render_settings: * @pipeline: a #GESTimelinePipeline * @output_uri: the %URI to which the timeline will be rendered - * @profile: the #GstEncodingProfile to use to render the timeline + * @profile: the #GstEncodingProfile to use to render the timeline. * * Specify where the pipeline shall be rendered and with what settings. * + * A copy of @profile and @output_uri will be done internally, the caller can + * safely free those values afterwards. + * * This method must be called before setting the pipeline mode to * #TIMELINE_MODE_RENDER * @@ -563,8 +571,10 @@ ges_timeline_pipeline_set_render_settings (GESTimelinePipeline * pipeline, return FALSE; } + if (pipeline->profile) + gst_encoding_profile_free (pipeline->profile); g_object_set (pipeline->encodebin, "profile", profile, NULL); - pipeline->profile = profile; + pipeline->profile = gst_encoding_profile_copy (profile); return TRUE; }