mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-05 06:58:49 +00:00
testclock: add clock-type property
To allow the GstTestClock to be used as a GstSystemClock, it is useful to implement the clock-type property that GstSystemClock provides. This allows GstTestClock to be used as the system clock with code that expects a GstSystemClock. https://bugzilla.gnome.org/show_bug.cgi?id=762147
This commit is contained in:
parent
2076be19ed
commit
57a9919eb1
1 changed files with 21 additions and 1 deletions
|
@ -183,7 +183,8 @@
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
PROP_0,
|
PROP_0,
|
||||||
PROP_START_TIME
|
PROP_START_TIME,
|
||||||
|
PROP_CLOCK_TYPE
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct _GstClockEntryContext GstClockEntryContext;
|
typedef struct _GstClockEntryContext GstClockEntryContext;
|
||||||
|
@ -196,6 +197,7 @@ struct _GstClockEntryContext
|
||||||
|
|
||||||
struct _GstTestClockPrivate
|
struct _GstTestClockPrivate
|
||||||
{
|
{
|
||||||
|
GstClockType clock_type;
|
||||||
GstClockTime start_time;
|
GstClockTime start_time;
|
||||||
GstClockTime internal_time;
|
GstClockTime internal_time;
|
||||||
GList *entry_contexts;
|
GList *entry_contexts;
|
||||||
|
@ -203,6 +205,8 @@ struct _GstTestClockPrivate
|
||||||
GCond entry_processed_cond;
|
GCond entry_processed_cond;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define DEFAULT_CLOCK_TYPE GST_CLOCK_TYPE_MONOTONIC
|
||||||
|
|
||||||
#define GST_TEST_CLOCK_GET_PRIVATE(obj) ((GST_TEST_CLOCK_CAST (obj))->priv)
|
#define GST_TEST_CLOCK_GET_PRIVATE(obj) ((GST_TEST_CLOCK_CAST (obj))->priv)
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_STATIC (test_clock_debug);
|
GST_DEBUG_CATEGORY_STATIC (test_clock_debug);
|
||||||
|
@ -287,6 +291,13 @@ gst_test_clock_class_init (GstTestClockClass * klass)
|
||||||
"Start Time of the Clock", 0, G_MAXUINT64, 0,
|
"Start Time of the Clock", 0, G_MAXUINT64, 0,
|
||||||
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS | G_PARAM_CONSTRUCT_ONLY);
|
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS | G_PARAM_CONSTRUCT_ONLY);
|
||||||
g_object_class_install_property (gobject_class, PROP_START_TIME, pspec);
|
g_object_class_install_property (gobject_class, PROP_START_TIME, pspec);
|
||||||
|
|
||||||
|
g_object_class_install_property (gobject_class, PROP_CLOCK_TYPE,
|
||||||
|
g_param_spec_enum ("clock-type", "Clock type",
|
||||||
|
"The kind of clock implementation to be reported by this clock",
|
||||||
|
GST_TYPE_CLOCK_TYPE, DEFAULT_CLOCK_TYPE,
|
||||||
|
G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -301,6 +312,7 @@ gst_test_clock_init (GstTestClock * test_clock)
|
||||||
|
|
||||||
g_cond_init (&priv->entry_added_cond);
|
g_cond_init (&priv->entry_added_cond);
|
||||||
g_cond_init (&priv->entry_processed_cond);
|
g_cond_init (&priv->entry_processed_cond);
|
||||||
|
priv->clock_type = DEFAULT_CLOCK_TYPE;
|
||||||
|
|
||||||
GST_OBJECT_FLAG_SET (test_clock,
|
GST_OBJECT_FLAG_SET (test_clock,
|
||||||
GST_CLOCK_FLAG_CAN_DO_SINGLE_SYNC |
|
GST_CLOCK_FLAG_CAN_DO_SINGLE_SYNC |
|
||||||
|
@ -361,6 +373,9 @@ gst_test_clock_get_property (GObject * object, guint property_id,
|
||||||
case PROP_START_TIME:
|
case PROP_START_TIME:
|
||||||
g_value_set_uint64 (value, priv->start_time);
|
g_value_set_uint64 (value, priv->start_time);
|
||||||
break;
|
break;
|
||||||
|
case PROP_CLOCK_TYPE:
|
||||||
|
g_value_set_enum (value, priv->clock_type);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -381,6 +396,11 @@ gst_test_clock_set_property (GObject * object, guint property_id,
|
||||||
"test clock start time initialized at %" GST_TIME_FORMAT,
|
"test clock start time initialized at %" GST_TIME_FORMAT,
|
||||||
GST_TIME_ARGS (priv->start_time));
|
GST_TIME_ARGS (priv->start_time));
|
||||||
break;
|
break;
|
||||||
|
case PROP_CLOCK_TYPE:
|
||||||
|
priv->clock_type = (GstClockType) g_value_get_enum (value);
|
||||||
|
GST_CAT_DEBUG (GST_CAT_TEST_CLOCK, "clock-type set to %d",
|
||||||
|
priv->clock_type);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue