1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
|
/* GStreamer
* Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu>
* Copyright (C) <2006> Nokia Corporation, Stefan Kost <stefan.kost@nokia.com>.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
* Boston, MA 02111-1307, USA.
*/
#ifndef __GST_WAVPARSE_H__
#define __GST_WAVPARSE_H__
#include <gst/gst.h>
#include "gst/riff/riff-ids.h"
#include "gst/riff/riff-read.h"
#include <gst/base/gstadapter.h>
G_BEGIN_DECLS
#define GST_TYPE_WAVPARSE \
(gst_wavparse_get_type())
#define GST_WAVPARSE(obj) \
(G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_WAVPARSE,GstWavParse))
#define GST_WAVPARSE_CLASS(klass) \
(G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_WAVPARSE,GstWavParseClass))
#define GST_IS_WAVPARSE(obj) \
(G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_WAVPARSE))
#define GST_IS_WAVPARSE_CLASS(klass) \
(G_TYPE_CHECK_CLASS_TYPE((klass),GST_TYPE_WAVPARSE))
typedef enum {
GST_WAVPARSE_START,
GST_WAVPARSE_HEADER,
GST_WAVPARSE_DATA
} GstWavParseState;
typedef struct _GstWavParse GstWavParse;
typedef struct _GstWavParseClass GstWavParseClass;
/**
* GstWavParse:
*
* Opaque data structure.
*/
struct _GstWavParse {
GstElement parent;
/* pads */
GstPad *sinkpad,*srcpad;
/* for delayed source pad creation for when
* we have the first chunk of data and know
* the format for sure */
GstCaps *caps;
GstTagList *tags;
GstToc *toc;
GList *cues;
GList *labls;
GstEvent *start_segment;
/* WAVE decoding state */
GstWavParseState state;
gboolean abort_buffering;
/* format of audio, see defines below */
gint format;
/* useful audio data */
guint16 depth;
guint32 rate;
guint16 channels;
guint16 blockalign;
guint16 width;
guint32 av_bps;
guint32 fact;
/* real bps used or 0 when no bitrate is known */
guint32 bps;
gboolean vbr;
guint bytes_per_sample;
guint max_buf_size;
/* position in data part */
guint64 offset;
guint64 end_offset;
guint64 dataleft;
/* offset/length of data part */
guint64 datastart;
guint64 datasize;
/* duration in time */
guint64 duration;
/* pending seek */
GstEvent *seek_event;
/* For streaming */
GstAdapter *adapter;
gboolean got_fmt;
gboolean streaming;
/* configured segment, start/stop expressed in time or bytes */
GstSegment segment;
/* for late pad configuration */
gboolean first;
/* discont after seek */
gboolean discont;
gboolean ignore_length;
};
struct _GstWavParseClass {
GstElementClass parent_class;
};
GType gst_wavparse_get_type(void);
G_END_DECLS
#endif /* __GST_WAVPARSE_H__ */
|