mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 00:58:12 +00:00
Cleanups
Original commit message from CVS: Cleanups Add streaminfo
This commit is contained in:
parent
9ba6871226
commit
0207f453bb
2 changed files with 56 additions and 26 deletions
|
@ -48,7 +48,8 @@ enum
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
ARG_0,
|
ARG_0,
|
||||||
ARG_DRC
|
ARG_DRC,
|
||||||
|
ARG_STREAMINFO
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -138,6 +139,9 @@ gst_a52dec_class_init (GstA52DecClass * klass)
|
||||||
g_param_spec_boolean ("drc", "Dynamic Range Compression",
|
g_param_spec_boolean ("drc", "Dynamic Range Compression",
|
||||||
"Use Dynamic Range Compression", FALSE,
|
"Use Dynamic Range Compression", FALSE,
|
||||||
G_PARAM_READWRITE));
|
G_PARAM_READWRITE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_STREAMINFO,
|
||||||
|
g_param_spec_boxed ("streaminfo", "Streaminfo", "Streaminfo",
|
||||||
|
GST_TYPE_CAPS, G_PARAM_READABLE));
|
||||||
|
|
||||||
gobject_class->set_property = gst_a52dec_set_property;
|
gobject_class->set_property = gst_a52dec_set_property;
|
||||||
gobject_class->get_property = gst_a52dec_get_property;
|
gobject_class->get_property = gst_a52dec_get_property;
|
||||||
|
@ -157,6 +161,7 @@ gst_a52dec_init (GstA52Dec * a52dec)
|
||||||
gst_element_add_pad (GST_ELEMENT (a52dec), a52dec->srcpad);
|
gst_element_add_pad (GST_ELEMENT (a52dec), a52dec->srcpad);
|
||||||
|
|
||||||
a52dec->dynamic_range_compression = FALSE;
|
a52dec->dynamic_range_compression = FALSE;
|
||||||
|
a52dec->streaminfo = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* BEGIN modified a52dec conversion code */
|
/* BEGIN modified a52dec conversion code */
|
||||||
|
@ -294,7 +299,7 @@ gst_a52dec_channels (int flags)
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* error */
|
/* error */
|
||||||
fprintf (stderr, "a52dec invalid flags?");
|
g_warning ("a52dec invalid flags %d", flags);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return chans;
|
return chans;
|
||||||
|
@ -379,6 +384,25 @@ gst_a52dec_handle_event (GstA52Dec *a52dec)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_a52dec_update_streaminfo (GstA52Dec *a52dec)
|
||||||
|
{
|
||||||
|
GstProps *props;
|
||||||
|
GstPropsEntry *entry;
|
||||||
|
|
||||||
|
props = gst_props_empty_new ();
|
||||||
|
|
||||||
|
entry = gst_props_entry_new ("bitrate", GST_PROPS_INT (a52dec->bit_rate));
|
||||||
|
gst_props_add_entry (props, (GstPropsEntry *) entry);
|
||||||
|
|
||||||
|
gst_caps_unref (a52dec->streaminfo);
|
||||||
|
|
||||||
|
a52dec->streaminfo = gst_caps_new ("a52dec_streaminfo",
|
||||||
|
"application/x-gst-streaminfo",
|
||||||
|
props);
|
||||||
|
g_object_notify (G_OBJECT (a52dec), "streaminfo");
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_a52dec_loop (GstElement *element)
|
gst_a52dec_loop (GstElement *element)
|
||||||
{
|
{
|
||||||
|
@ -421,8 +445,10 @@ gst_a52dec_loop (GstElement *element)
|
||||||
|
|
||||||
a52dec->stream_channels = flags & A52_CHANNEL_MASK;
|
a52dec->stream_channels = flags & A52_CHANNEL_MASK;
|
||||||
|
|
||||||
/* FIXME: perhaps this change should be announced? */
|
if (bit_rate != a52dec->bit_rate) {
|
||||||
a52dec->bit_rate = bit_rate;
|
a52dec->bit_rate = bit_rate;
|
||||||
|
gst_a52dec_update_streaminfo (a52dec);
|
||||||
|
}
|
||||||
|
|
||||||
/* read the header + rest of frame */
|
/* read the header + rest of frame */
|
||||||
got_bytes = gst_bytestream_read (a52dec->bs, &buf, length);
|
got_bytes = gst_bytestream_read (a52dec->bs, &buf, length);
|
||||||
|
@ -438,7 +464,7 @@ gst_a52dec_loop (GstElement *element)
|
||||||
a52dec->level = 1;
|
a52dec->level = 1;
|
||||||
|
|
||||||
if (a52_frame (a52dec->state, data, &flags, &a52dec->level, a52dec->bias)) {
|
if (a52_frame (a52dec->state, data, &flags, &a52dec->level, a52dec->bias)) {
|
||||||
fprintf (stderr, "a52dec a52_frame error\n");
|
g_warning ("a52dec: a52_frame error\n");
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -450,7 +476,7 @@ gst_a52dec_loop (GstElement *element)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (need_reneg == TRUE) {
|
if (need_reneg == TRUE) {
|
||||||
fprintf (stderr, "a52dec reneg: sample_rate:%d stream_chans:%d using_chans:%d\n",
|
GST_DEBUG (0, "a52dec reneg: sample_rate:%d stream_chans:%d using_chans:%d\n",
|
||||||
a52dec->sample_rate, a52dec->stream_channels, a52dec->using_channels);
|
a52dec->sample_rate, a52dec->stream_channels, a52dec->using_channels);
|
||||||
gst_a52dec_reneg (a52dec->srcpad,
|
gst_a52dec_reneg (a52dec->srcpad,
|
||||||
gst_a52dec_channels (a52dec->using_channels), a52dec->sample_rate);
|
gst_a52dec_channels (a52dec->using_channels), a52dec->sample_rate);
|
||||||
|
@ -472,7 +498,6 @@ gst_a52dec_loop (GstElement *element)
|
||||||
}
|
}
|
||||||
|
|
||||||
end:
|
end:
|
||||||
/* FIXME, this is a possible leak */
|
|
||||||
gst_buffer_unref (buf);
|
gst_buffer_unref (buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -507,6 +532,7 @@ gst_a52dec_change_state (GstElement * element)
|
||||||
a52dec->samples = NULL;
|
a52dec->samples = NULL;
|
||||||
a52_free (a52dec->state);
|
a52_free (a52dec->state);
|
||||||
a52dec->state = NULL;
|
a52dec->state = NULL;
|
||||||
|
gst_caps_unref (a52dec->streaminfo);
|
||||||
break;
|
break;
|
||||||
case GST_STATE_READY_TO_NULL:
|
case GST_STATE_READY_TO_NULL:
|
||||||
break;
|
break;
|
||||||
|
@ -552,6 +578,9 @@ gst_a52dec_get_property (GObject * object, guint prop_id, GValue * value, GParam
|
||||||
case ARG_DRC:
|
case ARG_DRC:
|
||||||
g_value_set_boolean (value, src->dynamic_range_compression);
|
g_value_set_boolean (value, src->dynamic_range_compression);
|
||||||
break;
|
break;
|
||||||
|
case ARG_STREAMINFO:
|
||||||
|
g_value_set_boxed (value, src->streaminfo);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -25,16 +25,14 @@
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include <gst/bytestream/bytestream.h>
|
#include <gst/bytestream/bytestream.h>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
G_BEGIN_DECLS
|
||||||
extern "C" {
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#define GST_TYPE_A52DEC \
|
#define GST_TYPE_A52DEC \
|
||||||
(gst_a52dec_get_type())
|
(gst_a52dec_get_type())
|
||||||
#define GST_A52DEC(obj) \
|
#define GST_A52DEC(obj) \
|
||||||
(G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_A52DEC,GstA52Dec))
|
(G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_A52DEC,GstA52Dec))
|
||||||
#define GST_A52DEC_CLASS(klass) \
|
#define GST_A52DEC_CLASS(klass) \
|
||||||
(G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_A52DEC,GstA52Dec))
|
(G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_A52DEC,GstA52DecClass))
|
||||||
#define GST_IS_A52DEC(obj) \
|
#define GST_IS_A52DEC(obj) \
|
||||||
(G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_A52DEC))
|
(G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_A52DEC))
|
||||||
#define GST_IS_A52DEC_CLASS(obj) \
|
#define GST_IS_A52DEC_CLASS(obj) \
|
||||||
|
@ -47,26 +45,29 @@ struct _GstA52Dec {
|
||||||
GstElement element;
|
GstElement element;
|
||||||
|
|
||||||
/* pads */
|
/* pads */
|
||||||
GstPad *sinkpad,*srcpad;
|
GstPad *sinkpad,
|
||||||
|
*srcpad;
|
||||||
int bit_rate;
|
int bit_rate;
|
||||||
int sample_rate;
|
int sample_rate;
|
||||||
int stream_channels;
|
int stream_channels;
|
||||||
int request_channels;
|
int request_channels;
|
||||||
int using_channels;
|
int using_channels;
|
||||||
|
|
||||||
sample_t level;
|
sample_t level;
|
||||||
sample_t bias;
|
sample_t bias;
|
||||||
gboolean dynamic_range_compression;
|
gboolean dynamic_range_compression;
|
||||||
sample_t *samples;
|
sample_t *samples;
|
||||||
a52_state_t *state;
|
a52_state_t *state;
|
||||||
|
|
||||||
GstByteStream *bs;
|
GstByteStream *bs;
|
||||||
|
|
||||||
|
GstCaps *streaminfo;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _GstA52DecClass {
|
struct _GstA52DecClass {
|
||||||
GstElementClass parent_class;
|
GstElementClass parent_class;
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef __cplusplus
|
G_END_DECLS
|
||||||
}
|
|
||||||
#endif /* __cplusplus */
|
|
||||||
|
|
||||||
#endif /* __GST_A52DEC_H__ */
|
#endif /* __GST_A52DEC_H__ */
|
||||||
|
|
Loading…
Reference in a new issue