project: Add a signal to notify when a new timeline is starting to load
authorThibault Saunier <tsaunier@igalia.com>
Wed, 1 May 2019 22:20:42 +0000 (18:20 -0400)
committerThibault Saunier <tsaunier@igalia.com>
Thu, 23 May 2019 22:54:42 +0000 (18:54 -0400)
ges/ges-project.c
ges/ges-project.h

index 5f5baab70c0a9c0f4840d32fafc6631b3af8875c..b65a1a0993800985bf1a7c39e36e0aa13b367e55 100644 (file)
@@ -80,6 +80,7 @@ typedef struct EmitLoadedInIdle
 
 enum
 {
+  LOADING_SIGNAL,
   LOADED_SIGNAL,
   ERROR_LOADING_ASSET,
   ASSET_ADDED_SIGNAL,
@@ -179,6 +180,7 @@ _load_project (GESProject * project, GESTimeline * timeline, GError ** error)
 
   priv = GES_PROJECT (project)->priv;
 
+  g_signal_emit (project, _signals[LOADING_SIGNAL], 0, timeline);
   if (priv->uri == NULL) {
     EmitLoadedInIdle *data = g_slice_new (EmitLoadedInIdle);
 
@@ -481,10 +483,23 @@ ges_project_class_init (GESProjectClass * klass)
       G_SIGNAL_RUN_LAST, G_STRUCT_OFFSET (GESProjectClass, asset_removed),
       NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 1, GES_TYPE_ASSET);
 
+  /**
+   * GESProject::loading:
+   * @project: the #GESProject that is starting to load a timeline
+   * @timeline: The #GESTimeline that started loading
+   *
+   * Since: 1.18
+   */
+  _signals[LOADING_SIGNAL] =
+      g_signal_new ("loading", G_TYPE_FROM_CLASS (klass),
+      G_SIGNAL_RUN_FIRST, G_STRUCT_OFFSET (GESProjectClass, loading),
+      NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE,
+      1, GES_TYPE_TIMELINE);
+
   /**
    * GESProject::loaded:
-   * @project: the #GESProject that is done loading a project.
-   * @timeline: The #GESTimeline that complete loading
+   * @project: the #GESProject that is done loading a timeline.
+   * @timeline: The #GESTimeline that completed loading
    */
   _signals[LOADED_SIGNAL] =
       g_signal_new ("loaded", G_TYPE_FROM_CLASS (klass),
index 18239844d2018e81f3c3bb3f694c48c2eb184678..a9648350cdfe7087c165725ca3b155402c9c0dd0 100644 (file)
@@ -71,8 +71,10 @@ struct _GESProjectClass
                               GType extractable_type);
   gboolean (*loaded)         (GESProject  * self,
                               GESTimeline * timeline);
+  gboolean (*loading)        (GESProject  * self,
+                              GESTimeline * timeline);
 
-  gpointer _ges_reserved[GES_PADDING];
+  gpointer _ges_reserved[GES_PADDING - 1];
 };
 
 GES_API