{
gboolean result = FALSE;
const GstStructure *structure;
+ GstState state;
+ GstStateChangeReturn ret;
- if (GST_STATE (dtmfsrc) != GST_STATE_PLAYING) {
+ ret = gst_element_get_state (dtmfsrc, &state, NULL, 0);
+ if (ret != GST_STATE_CHANGE_SUCCESS || state != GST_STATE_PLAYING) {
GST_DEBUG_OBJECT (dtmfsrc, "Received event while not in PLAYING state");
goto ret;
}
{
GstDTMFSrc *dtmfsrc;
gboolean result = FALSE;
-
- dtmfsrc = GST_DTMF_SRC (GST_PAD_PARENT (pad));
+ GstElement *parent = gst_pad_get_parent_element (pad);
+ dtmfsrc = GST_DTMF_SRC (parent);
GST_DEBUG_OBJECT (dtmfsrc, "Received an event on the src pad");
switch (GST_EVENT_TYPE (event)) {
result = TRUE;
break;
case GST_EVENT_FLUSH_STOP:
- gst_segment_init (&dtmfsrc->segment, GST_FORMAT_UNDEFINED);
+ gst_segment_init (&dtmfsrc->segment, GST_FORMAT_TIME);
break;
case GST_EVENT_NEWSEGMENT:
{
break;
}
+ gst_object_unref (parent);
gst_event_unref (event);
return result;
}
"lock", G_TYPE_BOOLEAN, lock, NULL);
event = gst_event_new_custom (GST_EVENT_CUSTOM_DOWNSTREAM_OOB, structure);
- gst_pad_push_event (dtmfsrc->srcpad, event);
+ if (!gst_pad_push_event (dtmfsrc->srcpad, event)) {
+ GST_WARNING_OBJECT (dtmfsrc, "stream-lock event not handled");
+ }
}
static void
{
GstClock *clock;
- clock = GST_ELEMENT_CLOCK (dtmfsrc);
- if (clock != NULL)
- dtmfsrc->timestamp = gst_clock_get_time (GST_ELEMENT_CLOCK (dtmfsrc));
-
- else {
- GST_ERROR_OBJECT (dtmfsrc, "No clock set for element %s",
- GST_ELEMENT_NAME (dtmfsrc));
+ clock = gst_element_get_clock (dtmfsrc);
+ if (clock != NULL) {
+ dtmfsrc->timestamp = gst_clock_get_time (clock);
+ gst_object_unref (clock);
+ } else {
+ gchar *dtmf_name = gst_element_get_name (dtmfsrc);
+ GST_ERROR_OBJECT (dtmfsrc, "No clock set for element %s", dtmf_name);
dtmfsrc->timestamp = GST_CLOCK_TIME_NONE;
+ g_free (dtmf_name);
}
}
{
GstClock *clock;
- clock = GST_ELEMENT_CLOCK (dtmfsrc);
+ clock = gst_element_get_clock (dtmfsrc);
if (clock != NULL) {
GstClockID clock_id;
GstClockReturn clock_ret;
clock_id = gst_clock_new_single_shot_id (clock, GST_BUFFER_TIMESTAMP (buf));
clock_ret = gst_clock_id_wait (clock_id, NULL);
if (clock_ret != GST_CLOCK_OK && clock_ret != GST_CLOCK_EARLY) {
- GST_ERROR_OBJECT (dtmfsrc, "Failed to wait on clock %s",
- GST_ELEMENT_NAME (clock));
+ gchar *clock_name = gst_element_get_name (clock);
+ GST_ERROR_OBJECT (dtmfsrc, "Failed to wait on clock %s", clock_name);
+ g_free (clock_name);
}
gst_clock_id_unref (clock_id);
+ gst_object_unref (clock);
}
else {
- GST_ERROR_OBJECT (dtmfsrc, "No clock set for element %s",
- GST_ELEMENT_NAME (dtmfsrc));
+ gchar *dtmf_name = gst_element_get_name (dtmfsrc);
+ GST_ERROR_OBJECT (dtmfsrc, "No clock set for element %s", dtmf_name);
+ g_free (dtmf_name);
}
}
gchar *struct_str;
const GstStructure *structure;
- if (GST_STATE (dtmfsrc) != GST_STATE_PLAYING) {
+ GstState state;
+ GstStateChangeReturn ret;
+
+ ret = gst_element_get_state (dtmfsrc, &state, NULL, 0);
+ if (ret != GST_STATE_CHANGE_SUCCESS || state != GST_STATE_PLAYING) {
GST_DEBUG_OBJECT (dtmfsrc, "Received event while not in PLAYING state");
goto ret;
}
{
GstRTPDTMFSrc *dtmfsrc;
gboolean result = FALSE;
+ GstElement *parent = gst_pad_get_parent_element (pad);
+ dtmfsrc = GST_DTMF_SRC (parent);
- dtmfsrc = GST_RTP_DTMF_SRC (GST_PAD_PARENT (pad));
GST_DEBUG_OBJECT (dtmfsrc, "Received an event on the src pad");
switch (GST_EVENT_TYPE (event)) {
break;
}
+ gst_object_unref (parent);
gst_event_unref (event);
return result;
}
"lock", G_TYPE_BOOLEAN, lock, NULL);
event = gst_event_new_custom (GST_EVENT_CUSTOM_DOWNSTREAM_OOB, structure);
- gst_pad_push_event (dtmfsrc->srcpad, event);
+ if (!gst_pad_push_event (dtmfsrc->srcpad, event)) {
+ GST_WARNING_OBJECT (dtmfsrc, "stream-lock event not handled");
+ }
+
}
static void
{
GstClock *clock;
- clock = GST_ELEMENT_CLOCK (dtmfsrc);
- if (clock != NULL)
- dtmfsrc->timestamp = gst_clock_get_time (GST_ELEMENT_CLOCK (dtmfsrc))
+ clock = gst_element_get_clock (dtmfsrc);
+ if (clock != NULL) {
+ dtmfsrc->timestamp = gst_clock_get_time (clock)
+ (MIN_INTER_DIGIT_INTERVAL * GST_MSECOND);
-
- else {
- GST_ERROR_OBJECT (dtmfsrc, "No clock set for element %s",
- GST_ELEMENT_NAME (dtmfsrc));
+ gst_object_unref (clock);
+ } else {
+ gchar *dtmf_name = gst_element_get_name (dtmfsrc);
+ GST_ERROR_OBJECT (dtmfsrc, "No clock set for element %s", dtmf_name);
dtmfsrc->timestamp = GST_CLOCK_TIME_NONE;
+ g_free (dtmf_name);
}
dtmfsrc->rtp_timestamp = dtmfsrc->ts_base +
{
GstClock *clock;
- clock = GST_ELEMENT_CLOCK (dtmfsrc);
+ clock = gst_element_get_clock (dtmfsrc);
if (clock != NULL) {
GstClockID clock_id;
GstClockReturn clock_ret;
clock_id = gst_clock_new_single_shot_id (clock, GST_BUFFER_TIMESTAMP (buf));
clock_ret = gst_clock_id_wait (clock_id, NULL);
if (clock_ret != GST_CLOCK_OK && clock_ret != GST_CLOCK_EARLY) {
- GST_ERROR_OBJECT (dtmfsrc, "Failed to wait on clock %s",
- GST_ELEMENT_NAME (clock));
+ gchar *clock_name = gst_element_get_name (clock);
+ GST_ERROR_OBJECT (dtmfsrc, "Failed to wait on clock %s", clock_name);
+ g_free (clock_name);
}
gst_clock_id_unref (clock_id);
+ gst_object_unref (clock);
}
else {
- GST_ERROR_OBJECT (dtmfsrc, "No clock set for element %s",
- GST_ELEMENT_NAME (dtmfsrc));
+ gchar *dtmf_name = gst_element_get_name (dtmfsrc);
+ GST_ERROR_OBJECT (dtmfsrc, "No clock set for element %s", dtmf_name);
+ g_free (dtmf_name);
}
}