summaryrefslogtreecommitdiffstats
path: root/gst/law/mulaw-encode.c
diff options
context:
space:
mode:
authorWim Taymans <wim.taymans@gmail.com>2006-05-24 10:00:50 +0000
committerWim Taymans <wim.taymans@gmail.com>2006-05-24 10:00:50 +0000
commit7b39d55850d32a2ecfb5c7552d2cd542f7897db5 (patch)
tree1a198a70d86b2c44b6042344d2b0c650aea20b81 /gst/law/mulaw-encode.c
parentd4e266cd6dd1d0aad4942f48fe427f2a6ccf870e (diff)
gst/law/: Some cleanups in the chain functions.
Original commit message from CVS: * gst/law/alaw-decode.c: (gst_alawdec_chain): * gst/law/alaw-decode.h: * gst/law/alaw-encode.c: (gst_alawenc_chain): * gst/law/alaw-encode.h: * gst/law/mulaw-decode.c: (gst_mulawdec_chain): * gst/law/mulaw-decode.h: * gst/law/mulaw-encode.c: (gst_mulawenc_chain): * gst/law/mulaw-encode.h: Some cleanups in the chain functions. Remove some GStreamer 0.0.2 bits.
Diffstat (limited to 'gst/law/mulaw-encode.c')
-rw-r--r--gst/law/mulaw-encode.c33
1 files changed, 21 insertions, 12 deletions
diff --git a/gst/law/mulaw-encode.c b/gst/law/mulaw-encode.c
index 467553bb..ae92fc40 100644
--- a/gst/law/mulaw-encode.c
+++ b/gst/law/mulaw-encode.c
@@ -205,34 +205,43 @@ gst_mulawenc_chain (GstPad * pad, GstBuffer * buffer)
GstMuLawEnc *mulawenc;
gint16 *linear_data;
guint8 *mulaw_data;
+ guint mulaw_size;
GstBuffer *outbuf;
- gint bufsize;
+ GstFlowReturn ret;
- mulawenc = GST_MULAWENC (GST_OBJECT_PARENT (pad));
+ mulawenc = GST_MULAWENC (gst_pad_get_parent (pad));
if (!mulawenc->rate || !mulawenc->channels)
goto not_negotiated;
linear_data = (gint16 *) GST_BUFFER_DATA (buffer);
- bufsize = GST_BUFFER_SIZE (buffer) / 2;
- outbuf = gst_buffer_new_and_alloc (bufsize);
+ mulaw_size = GST_BUFFER_SIZE (buffer) / 2;
+
+ outbuf = gst_buffer_new_and_alloc (mulaw_size);
+ mulaw_data = (guint8 *) GST_BUFFER_DATA (outbuf);
- GST_BUFFER_DURATION (outbuf) = GST_SECOND * (bufsize) /
- (mulawenc->rate * mulawenc->channels);
- GST_BUFFER_TIMESTAMP (outbuf) = mulawenc->ts;
- mulawenc->ts += GST_BUFFER_DURATION (outbuf);
+ /* copy discont flag */
+ if (GST_BUFFER_FLAG_IS_SET (buffer, GST_BUFFER_FLAG_DISCONT))
+ GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
+ GST_BUFFER_DURATION (outbuf) = GST_BUFFER_DURATION (buffer);
+ GST_BUFFER_TIMESTAMP (outbuf) = GST_BUFFER_TIMESTAMP (buffer);
gst_buffer_set_caps (outbuf, GST_PAD_CAPS (mulawenc->srcpad));
- mulaw_data = (guint8 *) GST_BUFFER_DATA (outbuf);
- mulaw_encode (linear_data, mulaw_data, GST_BUFFER_SIZE (outbuf));
+ mulaw_encode (linear_data, mulaw_data, mulaw_size);
gst_buffer_unref (buffer);
- return gst_pad_push (mulawenc->srcpad, outbuf);
+ ret = gst_pad_push (mulawenc->srcpad, outbuf);
+
+done:
+ gst_object_unref (mulawenc);
+
+ return ret;
not_negotiated:
{
- return GST_FLOW_NOT_NEGOTIATED;
+ ret = GST_FLOW_NOT_NEGOTIATED;
+ goto done;
}
}