validate:scenario: Properly check that remaining actions are not 'ending' ones

When checking that all action were executed, we need to make sure that
actions such as EOS or stop are not taken into account as we might have
shorter medias than the duration of the scenario, and that should not be
fatal.

+ Plug a leak on the way
This commit is contained in:
Thibault Saunier 2014-07-23 14:51:43 +02:00
parent 386b572066
commit 35b6bfb7c8

View file

@ -1073,15 +1073,20 @@ message_cb (GstBus * bus, GstMessage * message, GstValidateScenario * scenario)
for (tmp = scenario->priv->actions; tmp; tmp = tmp->next) { for (tmp = scenario->priv->actions; tmp; tmp = tmp->next) {
GstValidateAction *action = ((GstValidateAction *) tmp->data); GstValidateAction *action = ((GstValidateAction *) tmp->data);
gchar *action_string;
tmpconcat = actions; tmpconcat = actions;
if (g_strcmp0 (action->name, "eos")) action_string = gst_structure_to_string (action->structure);
if (g_regex_match_simple ("eos|stop", action_string, 0, 0)) {
g_free (action_string);
continue; continue;
}
nb_actions++; nb_actions++;
actions = g_strdup_printf ("%s\n%*s%s", actions =
actions, 20, "", gst_structure_to_string (action->structure)); g_strdup_printf ("%s\n%*s%s", actions, 20, "", action_string);
g_free (tmpconcat); g_free (tmpconcat);
g_free (action_string);
} }