mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 10:25:33 +00:00
validate: Add an action to wait for a given amout of time
During that time we will just not execute any new action + Lower WARNING to DEBUG when no playbcak_time is provided for an action, it should just be 0.
This commit is contained in:
parent
21a4888ae7
commit
cac53e9078
1 changed files with 67 additions and 6 deletions
|
@ -84,6 +84,7 @@ struct _GstValidateScenarioPrivate
|
||||||
guint num_actions;
|
guint num_actions;
|
||||||
|
|
||||||
guint get_pos_id;
|
guint get_pos_id;
|
||||||
|
guint wait_id;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct KeyFileGroupName
|
typedef struct KeyFileGroupName
|
||||||
|
@ -97,6 +98,7 @@ static GType gst_validate_action_get_type (void);
|
||||||
|
|
||||||
GST_DEFINE_MINI_OBJECT_TYPE (GstValidateAction, gst_validate_action);
|
GST_DEFINE_MINI_OBJECT_TYPE (GstValidateAction, gst_validate_action);
|
||||||
static GstValidateAction *gst_validate_action_new (void);
|
static GstValidateAction *gst_validate_action_new (void);
|
||||||
|
static gboolean get_position (GstValidateScenario * scenario);
|
||||||
|
|
||||||
static GstValidateAction *
|
static GstValidateAction *
|
||||||
_action_copy (GstValidateAction * act)
|
_action_copy (GstValidateAction * act)
|
||||||
|
@ -577,6 +579,22 @@ _set_rank (GstValidateScenario * scenario, GstValidateAction * action)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
_add_get_position_source (GstValidateScenario * scenario)
|
||||||
|
{
|
||||||
|
GstValidateScenarioPrivate *priv = scenario->priv;
|
||||||
|
|
||||||
|
if (priv->get_pos_id == 0 && priv->wait_id == 0) {
|
||||||
|
priv->get_pos_id = g_timeout_add (50, (GSourceFunc) get_position, scenario);
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (scenario, "Start checking position again");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (scenario, "No need to start a new gsource");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
get_position (GstValidateScenario * scenario)
|
get_position (GstValidateScenario * scenario)
|
||||||
{
|
{
|
||||||
|
@ -673,6 +691,45 @@ get_position (GstValidateScenario * scenario)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
stop_waiting (GstValidateScenario * scenario)
|
||||||
|
{
|
||||||
|
GstValidateScenarioPrivate *priv = scenario->priv;
|
||||||
|
|
||||||
|
priv->wait_id = 0;
|
||||||
|
_add_get_position_source (scenario);
|
||||||
|
|
||||||
|
g_print ("\n==== Stop waiting ===\n");
|
||||||
|
|
||||||
|
return G_SOURCE_REMOVE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
_execute_wait (GstValidateScenario * scenario, GstValidateAction * action)
|
||||||
|
{
|
||||||
|
GstValidateScenarioPrivate *priv = scenario->priv;
|
||||||
|
GstClockTime duration;
|
||||||
|
|
||||||
|
if (!gst_validate_action_get_clocktime (scenario, action,
|
||||||
|
"duration", &duration)) {
|
||||||
|
GST_DEBUG_OBJECT (scenario, "Duration could not be parsed");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
gst_validate_action_print (action, "Waiting for %" GST_TIME_FORMAT "\n",
|
||||||
|
GST_TIME_ARGS (duration));
|
||||||
|
if (priv->get_pos_id) {
|
||||||
|
g_source_remove (priv->get_pos_id);
|
||||||
|
priv->get_pos_id = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
priv->wait_id = g_timeout_add (duration / G_USEC_PER_SEC,
|
||||||
|
(GSourceFunc) stop_waiting, scenario);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_validate_scenario_update_segment_from_seek (GstValidateScenario * scenario,
|
gst_validate_scenario_update_segment_from_seek (GstValidateScenario * scenario,
|
||||||
GstEvent * seek)
|
GstEvent * seek)
|
||||||
|
@ -745,11 +802,7 @@ message_cb (GstBus * bus, GstMessage * message, GstValidateScenario * scenario)
|
||||||
priv->needs_parsing = NULL;
|
priv->needs_parsing = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (priv->get_pos_id == 0) {
|
_add_get_position_source (scenario);
|
||||||
get_position (scenario);
|
|
||||||
priv->get_pos_id =
|
|
||||||
g_timeout_add (50, (GSourceFunc) get_position, scenario);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case GST_MESSAGE_ERROR:
|
case GST_MESSAGE_ERROR:
|
||||||
case GST_MESSAGE_EOS:
|
case GST_MESSAGE_EOS:
|
||||||
|
@ -796,6 +849,11 @@ _pipeline_freed_cb (GstValidateScenario * scenario,
|
||||||
g_source_remove (priv->get_pos_id);
|
g_source_remove (priv->get_pos_id);
|
||||||
priv->get_pos_id = 0;
|
priv->get_pos_id = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (priv->wait_id) {
|
||||||
|
g_source_remove (priv->wait_id);
|
||||||
|
priv->wait_id = 0;
|
||||||
|
}
|
||||||
scenario->pipeline = NULL;
|
scenario->pipeline = NULL;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (scenario, "pipeline was freed");
|
GST_DEBUG_OBJECT (scenario, "pipeline was freed");
|
||||||
|
@ -969,7 +1027,7 @@ _load_scenario_file (GstValidateScenario * scenario,
|
||||||
gst_structure_get_string (structure, "playback_time"))) {
|
gst_structure_get_string (structure, "playback_time"))) {
|
||||||
priv->needs_parsing = g_list_append (priv->needs_parsing, action);
|
priv->needs_parsing = g_list_append (priv->needs_parsing, action);
|
||||||
} else
|
} else
|
||||||
GST_WARNING_OBJECT (scenario,
|
GST_INFO_OBJECT (scenario,
|
||||||
"No playback time for action %" GST_PTR_FORMAT, structure);
|
"No playback time for action %" GST_PTR_FORMAT, structure);
|
||||||
|
|
||||||
if (!(action->name = gst_structure_get_string (structure, "name")))
|
if (!(action->name = gst_structure_get_string (structure, "name")))
|
||||||
|
@ -1399,6 +1457,7 @@ void
|
||||||
init_scenarios (void)
|
init_scenarios (void)
|
||||||
{
|
{
|
||||||
const gchar *seek_mandatory_fields[] = { "start", NULL };
|
const gchar *seek_mandatory_fields[] = { "start", NULL };
|
||||||
|
const gchar *wait_mandatory_fields[] = { "wait", NULL };
|
||||||
|
|
||||||
_gst_validate_action_type = gst_validate_action_get_type ();
|
_gst_validate_action_type = gst_validate_action_get_type ();
|
||||||
|
|
||||||
|
@ -1422,6 +1481,8 @@ init_scenarios (void)
|
||||||
" a relative change (eg, '+1' means 'next track', '-1' means 'previous"
|
" a relative change (eg, '+1' means 'next track', '-1' means 'previous"
|
||||||
" track'), note that you need to state that it is a string in the scenario file"
|
" track'), note that you need to state that it is a string in the scenario file"
|
||||||
" prefixing it with (string).", FALSE);
|
" prefixing it with (string).", FALSE);
|
||||||
|
gst_validate_add_action_type ("wait", _execute_wait, wait_mandatory_fields,
|
||||||
|
"Action to wait during 'duration' seconds", FALSE);
|
||||||
gst_validate_add_action_type ("set-feature-rank", _set_rank, NULL,
|
gst_validate_add_action_type ("set-feature-rank", _set_rank, NULL,
|
||||||
"Allows you to change the ranking of a particular plugin feature", TRUE);
|
"Allows you to change the ranking of a particular plugin feature", TRUE);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue