Converted some send_event to properties

Original commit message from CVS:
Converted some send_event to properties
This commit is contained in:
Wim Taymans 2002-02-06 23:34:56 +00:00
parent 6fb62bbc9a
commit 16da17addc
2 changed files with 111 additions and 44 deletions

View file

@ -47,11 +47,23 @@ enum
enum enum
{ {
ARG_0, ARG_0,
ARG_COMMENT,
ARG_VENDOR,
ARG_VERSION,
ARG_CHANNELS,
ARG_RATE,
ARG_BITRATE_UPPER,
ARG_BITRATE_NOMINAL,
ARG_BITRATE_LOWER,
ARG_BITRATE_WINDOW,
}; };
static void gst_vorbisdec_class_init (VorbisDecClass *klass); static void gst_vorbisdec_class_init (VorbisDecClass *klass);
static void gst_vorbisdec_init (VorbisDec *vorbisdec); static void gst_vorbisdec_init (VorbisDec *vorbisdec);
static void gst_vorbisdec_get_property (GObject *object, guint prop_id,
GValue *value, GParamSpec *pspec);
static void gst_vorbisdec_loop (GstElement *element); static void gst_vorbisdec_loop (GstElement *element);
static GstElementClass *parent_class = NULL; static GstElementClass *parent_class = NULL;
@ -83,11 +95,43 @@ vorbisdec_get_type (void)
static void static void
gst_vorbisdec_class_init (VorbisDecClass * klass) gst_vorbisdec_class_init (VorbisDecClass * klass)
{ {
GObjectClass *gobject_class;
GstElementClass *gstelement_class; GstElementClass *gstelement_class;
gobject_class = (GObjectClass*) klass;
gstelement_class = (GstElementClass *) klass; gstelement_class = (GstElementClass *) klass;
parent_class = g_type_class_ref (GST_TYPE_ELEMENT); parent_class = g_type_class_ref (GST_TYPE_ELEMENT);
g_object_class_install_property (gobject_class, ARG_COMMENT,
g_param_spec_string ("comment", "Comment", "The comment tags for this vorbis stream",
"", G_PARAM_READABLE));
g_object_class_install_property (gobject_class, ARG_VENDOR,
g_param_spec_string ("vendor", "Vendor", "The vendor for this vorbis stream",
"", G_PARAM_READABLE));
g_object_class_install_property (gobject_class, ARG_VERSION,
g_param_spec_int ("version", "Version", "The version",
0, G_MAXINT, 0, G_PARAM_READABLE));
g_object_class_install_property (gobject_class, ARG_CHANNELS,
g_param_spec_int ("channels", "Channels", "The number of channels",
0, G_MAXINT, 0, G_PARAM_READABLE));
g_object_class_install_property (gobject_class, ARG_RATE,
g_param_spec_int ("rate", "Rate", "The samplerate",
0, G_MAXINT, 0, G_PARAM_READABLE));
g_object_class_install_property (gobject_class, ARG_BITRATE_UPPER,
g_param_spec_int ("bitrate_upper", "bitrate_upper", "bitrate_upper",
0, G_MAXINT, 0, G_PARAM_READABLE));
g_object_class_install_property (gobject_class, ARG_BITRATE_NOMINAL,
g_param_spec_int ("bitrate_nominal", "bitrate_nominal", "bitrate_nominal",
0, G_MAXINT, 0, G_PARAM_READABLE));
g_object_class_install_property (gobject_class, ARG_BITRATE_LOWER,
g_param_spec_int ("bitrate_lower", "bitrate_lower", "bitrate_lower",
0, G_MAXINT, 0, G_PARAM_READABLE));
g_object_class_install_property (gobject_class, ARG_BITRATE_WINDOW,
g_param_spec_int ("bitrate_window", "bitrate_window", "bitrate_window",
0, G_MAXINT, 0, G_PARAM_READABLE));
gobject_class->get_property = gst_vorbisdec_get_property;
} }
static void static void
@ -146,9 +190,6 @@ gst_vorbisdec_loop (GstElement * element)
ogg_page og; /* one Ogg bitstream page. Vorbis packets are inside */ ogg_page og; /* one Ogg bitstream page. Vorbis packets are inside */
ogg_packet op; /* one raw packet of data for decode */ ogg_packet op; /* one raw packet of data for decode */
vorbis_info vi; /* struct that stores all the static vorbis bitstream
settings */
vorbis_comment vc; /* struct that stores all the bitstream user comments */
vorbis_dsp_state vd; /* central working state for the packet->PCM decoder */ vorbis_dsp_state vd; /* central working state for the packet->PCM decoder */
vorbis_block vb; /* local working space for packet->PCM decode */ vorbis_block vb; /* local working space for packet->PCM decode */
@ -201,8 +242,8 @@ gst_vorbisdec_loop (GstElement * element)
header is an easy way to identify a Vorbis bitstream and it's header is an easy way to identify a Vorbis bitstream and it's
useful to see that functionality seperated out. */ useful to see that functionality seperated out. */
vorbis_info_init (&vi); vorbis_info_init (&vorbisdec->vi);
vorbis_comment_init (&vc); vorbis_comment_init (&vorbisdec->vc);
if (ogg_stream_pagein (&os, &og) < 0) { if (ogg_stream_pagein (&os, &og) < 0) {
/* error; stream version mismatch perhaps */ /* error; stream version mismatch perhaps */
g_warning ("Error reading first page of Ogg bitstream data.\n"); g_warning ("Error reading first page of Ogg bitstream data.\n");
@ -215,7 +256,7 @@ gst_vorbisdec_loop (GstElement * element)
return; return;
} }
if (vorbis_synthesis_headerin (&vi, &vc, &op) < 0) { if (vorbis_synthesis_headerin (&vorbisdec->vi, &vorbisdec->vc, &op) < 0) {
/* error case; not a vorbis header */ /* error case; not a vorbis header */
g_warning ("This Ogg bitstream does not contain Vorbis audio data.\n"); g_warning ("This Ogg bitstream does not contain Vorbis audio data.\n");
return; return;
@ -253,7 +294,7 @@ gst_vorbisdec_loop (GstElement * element)
We can't tolerate that in a header. Die. */ We can't tolerate that in a header. Die. */
g_warning ("Corrupt secondary header. expect trouble\n"); g_warning ("Corrupt secondary header. expect trouble\n");
} }
vorbis_synthesis_headerin (&vi, &vc, &op); vorbis_synthesis_headerin (&vorbisdec->vi, &vorbisdec->vc, &op);
i++; i++;
} }
} }
@ -275,30 +316,23 @@ gst_vorbisdec_loop (GstElement * element)
/* Throw the comments plus a few lines about the bitstream we're /* Throw the comments plus a few lines about the bitstream we're
decoding */ decoding */
{ {
char **ptr = vc.user_comments; char **ptr = vorbisdec->vc.user_comments;
while (*ptr) { while (*ptr) {
gst_element_send_event (GST_ELEMENT (vorbisdec), /* FIXME parse comments */
gst_event_new_info ("comment", GST_PROPS_STRING (*ptr), NULL));
++ptr; ++ptr;
} }
gst_element_send_event (GST_ELEMENT (vorbisdec), g_object_freeze_notify (G_OBJECT (vorbisdec));
gst_event_new_info ("vendor", GST_PROPS_STRING (vc.vendor), NULL)); g_object_notify (G_OBJECT (vorbisdec), "comment");
g_object_notify (G_OBJECT (vorbisdec), "vendor");
gst_element_send_event (GST_ELEMENT (vorbisdec), g_object_notify (G_OBJECT (vorbisdec), "version");
gst_event_new_info ("version", GST_PROPS_INT (vi.version), NULL)); g_object_notify (G_OBJECT (vorbisdec), "channels");
gst_element_send_event (GST_ELEMENT (vorbisdec), g_object_notify (G_OBJECT (vorbisdec), "rate");
gst_event_new_info ("channels", GST_PROPS_INT (vi.channels), NULL)); g_object_notify (G_OBJECT (vorbisdec), "bitrate_upper");
gst_element_send_event (GST_ELEMENT (vorbisdec), g_object_notify (G_OBJECT (vorbisdec), "bitrate_nominal");
gst_event_new_info ("rate", GST_PROPS_INT (vi.rate), NULL)); g_object_notify (G_OBJECT (vorbisdec), "bitrate_lower");
gst_element_send_event (GST_ELEMENT (vorbisdec), g_object_notify (G_OBJECT (vorbisdec), "bitrate_window");
gst_event_new_info ("bitrate_upper", GST_PROPS_INT (vi.bitrate_upper), NULL)); g_object_thaw_notify (G_OBJECT (vorbisdec));
gst_element_send_event (GST_ELEMENT (vorbisdec),
gst_event_new_info ("bitrate_nominal", GST_PROPS_INT (vi.bitrate_nominal), NULL));
gst_element_send_event (GST_ELEMENT (vorbisdec),
gst_event_new_info ("bitrate_lower", GST_PROPS_INT (vi.bitrate_lower), NULL));
gst_element_send_event (GST_ELEMENT (vorbisdec),
gst_event_new_info ("bitrate_window", GST_PROPS_INT (vi.bitrate_window), NULL));
} }
gst_pad_try_set_caps (vorbisdec->srcpad, gst_pad_try_set_caps (vorbisdec->srcpad,
@ -310,15 +344,15 @@ gst_vorbisdec_loop (GstElement * element)
"signed", GST_PROPS_BOOLEAN (TRUE), "signed", GST_PROPS_BOOLEAN (TRUE),
"width", GST_PROPS_INT (16), "width", GST_PROPS_INT (16),
"depth", GST_PROPS_INT (16), "depth", GST_PROPS_INT (16),
"rate", GST_PROPS_INT (vi.rate), "rate", GST_PROPS_INT (vorbisdec->vi.rate),
"channels", GST_PROPS_INT (vi.channels) "channels", GST_PROPS_INT (vorbisdec->vi.channels)
)); ));
vorbisdec->convsize = 4096 / vi.channels; vorbisdec->convsize = 4096 / vorbisdec->vi.channels;
/* OK, got and parsed all three headers. Initialize the Vorbis /* OK, got and parsed all three headers. Initialize the Vorbis
packet->PCM decoder. */ packet->PCM decoder. */
vorbis_synthesis_init (&vd, &vi); /* central decode state */ vorbis_synthesis_init (&vd, &vorbisdec->vi); /* central decode state */
vorbis_block_init (&vd, &vb); /* local state for most of the decode vorbis_block_init (&vd, &vb); /* local state for most of the decode
so multiple block decodes can so multiple block decodes can
proceed in parallel. We could init proceed in parallel. We could init
@ -366,15 +400,15 @@ gst_vorbisdec_loop (GstElement * element)
outbuf = gst_buffer_new (); outbuf = gst_buffer_new ();
GST_BUFFER_DATA (outbuf) = g_malloc (2 * vi.channels * bout); GST_BUFFER_DATA (outbuf) = g_malloc (2 * vorbisdec->vi.channels * bout);
GST_BUFFER_SIZE (outbuf) = 2 * vi.channels * bout; GST_BUFFER_SIZE (outbuf) = 2 * vorbisdec->vi.channels * bout;
GST_BUFFER_TIMESTAMP (outbuf) = vorbisdec->total_out * 1000000LL / vi.rate; GST_BUFFER_TIMESTAMP (outbuf) = vorbisdec->total_out * 1000000LL / vorbisdec->vi.rate;
vorbisdec->total_out += bout; vorbisdec->total_out += bout;
/* convert doubles to 16 bit signed ints (host order) and /* convert doubles to 16 bit signed ints (host order) and
interleave */ interleave */
for (i = 0; i < vi.channels; i++) { for (i = 0; i < vorbisdec->vi.channels; i++) {
int16_t *ptr = ((int16_t *) GST_BUFFER_DATA (outbuf)) + i; int16_t *ptr = ((int16_t *) GST_BUFFER_DATA (outbuf)) + i;
float *mono = pcm[i]; float *mono = pcm[i];
@ -391,7 +425,7 @@ gst_vorbisdec_loop (GstElement * element)
clipflag = 1; clipflag = 1;
} }
*ptr = val; *ptr = val;
ptr += vi.channels; ptr += vorbisdec->vi.channels;
} }
} }
@ -435,9 +469,49 @@ gst_vorbisdec_loop (GstElement * element)
vorbis_block_clear (&vb); vorbis_block_clear (&vb);
vorbis_dsp_clear (&vd); vorbis_dsp_clear (&vd);
vorbis_info_clear (&vi); /* must be called last */ vorbis_info_clear (&vorbisdec->vi); /* must be called last */
} }
/* OK, clean up the framer */ /* OK, clean up the framer */
ogg_sync_clear (&oy); ogg_sync_clear (&oy);
} }
static void
gst_vorbisdec_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec)
{
VorbisDec *vorbisdec;
g_return_if_fail (GST_IS_VORBISDEC (object));
vorbisdec = GST_VORBISDEC (object);
switch (prop_id) {
case ARG_COMMENT:
g_value_set_string (value, "comment");
break;
case ARG_VENDOR:
g_value_set_string (value, vorbisdec->vc.vendor);
break;
case ARG_VERSION:
g_value_set_int (value, vorbisdec->vi.version);
break;
case ARG_CHANNELS:
g_value_set_int (value, vorbisdec->vi.channels);
break;
case ARG_RATE:
g_value_set_int (value, vorbisdec->vi.rate);
break;
case ARG_BITRATE_UPPER:
g_value_set_int (value, vorbisdec->vi.bitrate_upper);
break;
case ARG_BITRATE_NOMINAL:
g_value_set_int (value, vorbisdec->vi.bitrate_nominal);
break;
case ARG_BITRATE_LOWER:
g_value_set_int (value, vorbisdec->vi.bitrate_lower);
break;
case ARG_BITRATE_WINDOW:
g_value_set_int (value, vorbisdec->vi.bitrate_window);
break;
}
}

View file

@ -162,13 +162,6 @@ gst_vorbisenc_setup (VorbisEnc * vorbisenc)
vorbis_encode_init (&vorbisenc->vi, vorbisenc->channels, vorbisenc->frequency, vorbis_encode_init (&vorbisenc->vi, vorbisenc->channels, vorbisenc->frequency,
-1, vorbisenc->bitrate, -1); -1, vorbisenc->bitrate, -1);
gst_element_send_event (GST_ELEMENT (vorbisenc),
gst_event_new_info ("channels", GST_PROPS_INT (vorbisenc->channels), NULL));
gst_element_send_event (GST_ELEMENT (vorbisenc),
gst_event_new_info ("rate", GST_PROPS_INT (vorbisenc->frequency), NULL));
gst_element_send_event (GST_ELEMENT (vorbisenc),
gst_event_new_info ("bitrate_nominal", GST_PROPS_INT (vorbisenc->bitrate), NULL));
/* add a comment */ /* add a comment */
vorbis_comment_init (&vorbisenc->vc); vorbis_comment_init (&vorbisenc->vc);
vorbis_comment_add (&vorbisenc->vc, (gchar *)comment); vorbis_comment_add (&vorbisenc->vc, (gchar *)comment);