annotate src/ffmpeg/libavformat/avformat.h @ 823:a195f1259a6b trunk

[svn] - merge VFS support from wma plugin.
author nenolod
date Mon, 12 Mar 2007 14:12:00 -0700
parents a35b692388f6
children 3cbdc6e19d7c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
1 /*
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
2 * copyright (c) 2001 Fabrice Bellard
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
3 *
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
4 * This file is part of FFmpeg.
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
5 *
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
6 * FFmpeg is free software; you can redistribute it and/or
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
7 * modify it under the terms of the GNU Lesser General Public
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
8 * License as published by the Free Software Foundation; either
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
9 * version 2.1 of the License, or (at your option) any later version.
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
10 *
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
11 * FFmpeg is distributed in the hope that it will be useful,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
14 * Lesser General Public License for more details.
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
15 *
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
16 * You should have received a copy of the GNU Lesser General Public
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
17 * License along with FFmpeg; if not, write to the Free Software
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
19 */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
20
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
21 #ifndef AVFORMAT_H
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
22 #define AVFORMAT_H
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
23
823
a195f1259a6b [svn] - merge VFS support from wma plugin.
nenolod
parents: 822
diff changeset
24 #include <audacious/util.h>
a195f1259a6b [svn] - merge VFS support from wma plugin.
nenolod
parents: 822
diff changeset
25 #include <audacious/vfs.h>
a195f1259a6b [svn] - merge VFS support from wma plugin.
nenolod
parents: 822
diff changeset
26
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
27 #ifdef __cplusplus
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
28 extern "C" {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
29 #endif
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
30
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
31 #define LIBAVFORMAT_VERSION_INT ((50<<16)+(6<<8)+0)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
32 #define LIBAVFORMAT_VERSION 50.6.0
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
33 #define LIBAVFORMAT_BUILD LIBAVFORMAT_VERSION_INT
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
34
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
35 #define LIBAVFORMAT_IDENT "Lavf" AV_STRINGIFY(LIBAVFORMAT_VERSION)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
36
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
37 #include <time.h>
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
38 #include <stdio.h> /* FILE */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
39 #include "avcodec.h"
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
40
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
41 #include "avio.h"
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
42
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
43 /* packet functions */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
44
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
45 #ifndef MAXINT64
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
46 #define MAXINT64 int64_t_C(0x7fffffffffffffff)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
47 #endif
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
48
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
49 #ifndef MININT64
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
50 #define MININT64 int64_t_C(0x8000000000000000)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
51 #endif
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
52
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
53 typedef struct AVPacket {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
54 int64_t pts; ///< presentation time stamp in time_base units
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
55 int64_t dts; ///< decompression time stamp in time_base units
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
56 uint8_t *data;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
57 int size;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
58 int stream_index;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
59 int flags;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
60 int duration; ///< presentation duration in time_base units (0 if not available)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
61 void (*destruct)(struct AVPacket *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
62 void *priv;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
63 int64_t pos; ///< byte position in stream, -1 if unknown
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
64 } AVPacket;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
65 #define PKT_FLAG_KEY 0x0001
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
66
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
67 void av_destruct_packet_nofree(AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
68 void av_destruct_packet(AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
69
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
70 /* initialize optional fields of a packet */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
71 static inline void av_init_packet(AVPacket *pkt)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
72 {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
73 pkt->pts = AV_NOPTS_VALUE;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
74 pkt->dts = AV_NOPTS_VALUE;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
75 pkt->pos = -1;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
76 pkt->duration = 0;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
77 pkt->flags = 0;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
78 pkt->stream_index = 0;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
79 pkt->destruct= av_destruct_packet_nofree;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
80 }
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
81
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
82 int av_new_packet(AVPacket *pkt, int size);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
83 int av_get_packet(ByteIOContext *s, AVPacket *pkt, int size);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
84 int av_dup_packet(AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
85
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
86 /**
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
87 * Free a packet
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
88 *
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
89 * @param pkt packet to free
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
90 */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
91 static inline void av_free_packet(AVPacket *pkt)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
92 {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
93 if (pkt && pkt->destruct) {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
94 pkt->destruct(pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
95 }
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
96 }
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
97
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
98 /*************************************************/
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
99 /* fractional numbers for exact pts handling */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
100
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
101 /* the exact value of the fractional number is: 'val + num / den'. num
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
102 is assumed to be such as 0 <= num < den */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
103 typedef struct AVFrac {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
104 int64_t val, num, den;
822
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
105 } AVFrac;
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
106
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
107 /*************************************************/
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
108 /* input/output formats */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
109
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
110 struct AVFormatContext;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
111
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
112 /* this structure contains the data a format has to probe a file */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
113 typedef struct AVProbeData {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
114 const char *filename;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
115 unsigned char *buf;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
116 int buf_size;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
117 } AVProbeData;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
118
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
119 #define AVPROBE_SCORE_MAX 100 ///< max score, half of that is used for file extension based detection
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
120
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
121 typedef struct AVFormatParameters {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
122 AVRational time_base;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
123 int sample_rate;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
124 int channels;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
125 int width;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
126 int height;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
127 enum PixelFormat pix_fmt;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
128 struct AVImageFormat *image_format;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
129 int channel; /* used to select dv channel */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
130 const char *device; /* video, audio or DV device */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
131 const char *standard; /* tv standard, NTSC, PAL, SECAM */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
132 int mpeg2ts_raw:1; /* force raw MPEG2 transport stream output, if possible */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
133 int mpeg2ts_compute_pcr:1; /* compute exact PCR for each transport
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
134 stream packet (only meaningful if
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
135 mpeg2ts_raw is TRUE */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
136 int initial_pause:1; /* do not begin to play the stream
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
137 immediately (RTSP only) */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
138 int prealloced_context:1;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
139 enum CodecID video_codec_id;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
140 enum CodecID audio_codec_id;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
141 } AVFormatParameters;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
142
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
143 #define AVFMT_NOFILE 0x0001 /* no file should be opened */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
144 #define AVFMT_NEEDNUMBER 0x0002 /* needs '%d' in filename */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
145 #define AVFMT_SHOW_IDS 0x0008 /* show format stream IDs numbers */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
146 #define AVFMT_RAWPICTURE 0x0020 /* format wants AVPicture structure for
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
147 raw picture data */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
148 #define AVFMT_GLOBALHEADER 0x0040 /* format wants global header */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
149 #define AVFMT_NOTIMESTAMPS 0x0080 /* format doesnt need / has any timestamps */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
150
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
151 typedef struct AVOutputFormat {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
152 const char *name;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
153 const char *long_name;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
154 const char *mime_type;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
155 const char *extensions; /* comma separated extensions */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
156 /* size of private data so that it can be allocated in the wrapper */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
157 int priv_data_size;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
158 /* output support */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
159 enum CodecID audio_codec; /* default audio codec */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
160 enum CodecID video_codec; /* default video codec */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
161 int (*write_header)(struct AVFormatContext *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
162 int (*write_packet)(struct AVFormatContext *, AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
163 int (*write_trailer)(struct AVFormatContext *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
164 /* can use flags: AVFMT_NOFILE, AVFMT_NEEDNUMBER, AVFMT_GLOBALHEADER */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
165 int flags;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
166 /* currently only used to set pixel format if not YUV420P */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
167 int (*set_parameters)(struct AVFormatContext *, AVFormatParameters *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
168 int (*interleave_packet)(struct AVFormatContext *, AVPacket *out, AVPacket *in, int flush);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
169 /* private fields */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
170 struct AVOutputFormat *next;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
171 } AVOutputFormat;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
172
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
173 typedef struct AVInputFormat {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
174 const char *name;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
175 const char *long_name;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
176 /* size of private data so that it can be allocated in the wrapper */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
177 int priv_data_size;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
178 /* tell if a given file has a chance of being parsing by this format */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
179 int (*read_probe)(AVProbeData *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
180 /* read the format header and initialize the AVFormatContext
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
181 structure. Return 0 if OK. 'ap' if non NULL contains
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
182 additionnal paramters. Only used in raw format right
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
183 now. 'av_new_stream' should be called to create new streams. */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
184 int (*read_header)(struct AVFormatContext *,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
185 AVFormatParameters *ap);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
186 /* read one packet and put it in 'pkt'. pts and flags are also
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
187 set. 'av_new_stream' can be called only if the flag
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
188 AVFMTCTX_NOHEADER is used. */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
189 int (*read_packet)(struct AVFormatContext *, AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
190 /* close the stream. The AVFormatContext and AVStreams are not
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
191 freed by this function */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
192 int (*read_close)(struct AVFormatContext *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
193 /**
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
194 * seek to a given timestamp relative to the frames in
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
195 * stream component stream_index
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
196 * @param stream_index must not be -1
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
197 * @param flags selects which direction should be preferred if no exact
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
198 * match is available
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
199 */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
200 int (*read_seek)(struct AVFormatContext *,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
201 int stream_index, int64_t timestamp, int flags);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
202 /**
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
203 * gets the next timestamp in AV_TIME_BASE units.
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
204 */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
205 int64_t (*read_timestamp)(struct AVFormatContext *s, int stream_index,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
206 int64_t *pos, int64_t pos_limit);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
207 /* can use flags: AVFMT_NOFILE, AVFMT_NEEDNUMBER */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
208 int flags;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
209 /* if extensions are defined, then no probe is done. You should
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
210 usually not use extension format guessing because it is not
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
211 reliable enough */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
212 const char *extensions;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
213 /* general purpose read only value that the format can use */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
214 int value;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
215
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
216 /* start/resume playing - only meaningful if using a network based format
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
217 (RTSP) */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
218 int (*read_play)(struct AVFormatContext *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
219
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
220 /* pause playing - only meaningful if using a network based format
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
221 (RTSP) */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
222 int (*read_pause)(struct AVFormatContext *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
223
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
224 /* private fields */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
225 struct AVInputFormat *next;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
226 } AVInputFormat;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
227
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
228 typedef struct AVIndexEntry {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
229 int64_t pos;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
230 int64_t timestamp;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
231 #define AVINDEX_KEYFRAME 0x0001
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
232 int flags:2;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
233 int size:30; //yeah trying to keep the size of this small to reduce memory requirements (its 24 vs 32 byte due to possible 8byte align)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
234 int min_distance; /* min distance between this and the previous keyframe, used to avoid unneeded searching */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
235 } AVIndexEntry;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
236
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
237 typedef struct AVStream {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
238 int index; /* stream index in AVFormatContext */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
239 int id; /* format specific stream id */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
240 AVCodecContext *codec; /* codec context */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
241 /**
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
242 * real base frame rate of the stream.
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
243 * for example if the timebase is 1/90000 and all frames have either
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
244 * approximately 3600 or 1800 timer ticks then r_frame_rate will be 50/1
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
245 */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
246 AVRational r_frame_rate;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
247 void *priv_data;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
248 /* internal data used in av_find_stream_info() */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
249 int64_t codec_info_duration;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
250 int codec_info_nb_frames;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
251 /* encoding: PTS generation when outputing stream */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
252 AVFrac pts;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
253
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
254 /**
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
255 * this is the fundamental unit of time (in seconds) in terms
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
256 * of which frame timestamps are represented. for fixed-fps content,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
257 * timebase should be 1/framerate and timestamp increments should be
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
258 * identically 1.
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
259 */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
260 AVRational time_base;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
261 int pts_wrap_bits; /* number of bits in pts (used for wrapping control) */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
262 /* ffmpeg.c private use */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
263 int stream_copy; /* if TRUE, just copy stream */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
264 enum AVDiscard discard; ///< selects which packets can be discarded at will and dont need to be demuxed
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
265 //FIXME move stuff to a flags field?
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
266 /* quality, as it has been removed from AVCodecContext and put in AVVideoFrame
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
267 * MN:dunno if thats the right place, for it */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
268 float quality;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
269 /* decoding: position of the first frame of the component, in
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
270 AV_TIME_BASE fractional seconds. */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
271 int64_t start_time;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
272 /* decoding: duration of the stream, in AV_TIME_BASE fractional
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
273 seconds. */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
274 int64_t duration;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
275
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
276 char language[4]; /* ISO 639 3-letter language code (empty string if undefined) */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
277
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
278 /* av_read_frame() support */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
279 int need_parsing; ///< 1->full parsing needed, 2->only parse headers dont repack
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
280 struct AVCodecParserContext *parser;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
281
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
282 int64_t cur_dts;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
283 int last_IP_duration;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
284 int64_t last_IP_pts;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
285 /* av_seek_frame() support */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
286 AVIndexEntry *index_entries; /* only used if the format does not
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
287 support seeking natively */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
288 int nb_index_entries;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
289 unsigned int index_entries_allocated_size;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
290
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
291 int64_t nb_frames; ///< number of frames in this stream if known or 0
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
292
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
293 #define MAX_REORDER_DELAY 4
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
294 int64_t pts_buffer[MAX_REORDER_DELAY+1];
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
295 } AVStream;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
296
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
297 #define AVFMTCTX_NOHEADER 0x0001 /* signal that no header is present
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
298 (streams are added dynamically) */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
299
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
300 #define MAX_STREAMS 20
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
301
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
302 /* format I/O context */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
303 typedef struct AVFormatContext {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
304 const AVClass *av_class; /* set by av_alloc_format_context */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
305 /* can only be iformat or oformat, not both at the same time */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
306 struct AVInputFormat *iformat;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
307 struct AVOutputFormat *oformat;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
308 void *priv_data;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
309 ByteIOContext pb;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
310 int nb_streams;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
311 AVStream *streams[MAX_STREAMS];
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
312 char filename[1024]; /* input or output filename */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
313 /* stream info */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
314 int64_t timestamp;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
315 char title[512];
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
316 char author[512];
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
317 char copyright[512];
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
318 char comment[512];
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
319 char album[512];
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
320 int year; /* ID3 year, 0 if none */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
321 int track; /* track number, 0 if none */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
322 char genre[32]; /* ID3 genre */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
323
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
324 int ctx_flags; /* format specific flags, see AVFMTCTX_xx */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
325 /* private data for pts handling (do not modify directly) */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
326 /* This buffer is only needed when packets were already buffered but
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
327 not decoded, for example to get the codec parameters in mpeg
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
328 streams */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
329 struct AVPacketList *packet_buffer;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
330
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
331 /* decoding: position of the first frame of the component, in
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
332 AV_TIME_BASE fractional seconds. NEVER set this value directly:
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
333 it is deduced from the AVStream values. */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
334 int64_t start_time;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
335 /* decoding: duration of the stream, in AV_TIME_BASE fractional
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
336 seconds. NEVER set this value directly: it is deduced from the
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
337 AVStream values. */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
338 int64_t duration;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
339 /* decoding: total file size. 0 if unknown */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
340 int64_t file_size;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
341 /* decoding: total stream bitrate in bit/s, 0 if not
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
342 available. Never set it directly if the file_size and the
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
343 duration are known as ffmpeg can compute it automatically. */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
344 int bit_rate;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
345
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
346 /* av_read_frame() support */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
347 AVStream *cur_st;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
348 const uint8_t *cur_ptr;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
349 int cur_len;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
350 AVPacket cur_pkt;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
351
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
352 /* av_seek_frame() support */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
353 int64_t data_offset; /* offset of the first packet */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
354 int index_built;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
355
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
356 int mux_rate;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
357 int packet_size;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
358 int preload;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
359 int max_delay;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
360
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
361 #define AVFMT_NOOUTPUTLOOP -1
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
362 #define AVFMT_INFINITEOUTPUTLOOP 0
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
363 /* number of times to loop output in formats that support it */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
364 int loop_output;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
365
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
366 int flags;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
367 #define AVFMT_FLAG_GENPTS 0x0001 ///< generate pts if missing even if it requires parsing future frames
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
368 #define AVFMT_FLAG_IGNIDX 0x0002 ///< ignore index
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
369
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
370 int loop_input;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
371 /* decoding: size of data to probe; encoding unused */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
372 unsigned int probesize;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
373 } AVFormatContext;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
374
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
375 typedef struct AVPacketList {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
376 AVPacket pkt;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
377 struct AVPacketList *next;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
378 } AVPacketList;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
379
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
380 extern AVInputFormat *first_iformat;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
381 extern AVOutputFormat *first_oformat;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
382
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
383 /* still image support */
822
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
384 struct AVInputImageContext;
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
385 typedef struct AVInputImageContext AVInputImageContext;
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
386
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
387 typedef struct AVImageInfo {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
388 enum PixelFormat pix_fmt; /* requested pixel format */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
389 int width; /* requested width */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
390 int height; /* requested height */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
391 int interleaved; /* image is interleaved (e.g. interleaved GIF) */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
392 AVPicture pict; /* returned allocated image */
822
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
393 } AVImageInfo;
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
394
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
395 /* AVImageFormat.flags field constants */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
396 #define AVIMAGE_INTERLEAVED 0x0001 /* image format support interleaved output */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
397
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
398 typedef struct AVImageFormat {
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
399 const char *name;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
400 const char *extensions;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
401 /* tell if a given file has a chance of being parsing by this format */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
402 int (*img_probe)(AVProbeData *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
403 /* read a whole image. 'alloc_cb' is called when the image size is
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
404 known so that the caller can allocate the image. If 'allo_cb'
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
405 returns non zero, then the parsing is aborted. Return '0' if
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
406 OK. */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
407 int (*img_read)(ByteIOContext *,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
408 int (*alloc_cb)(void *, AVImageInfo *info), void *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
409 /* write the image */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
410 int supported_pixel_formats; /* mask of supported formats for output */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
411 int (*img_write)(ByteIOContext *, AVImageInfo *);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
412 int flags;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
413 struct AVImageFormat *next;
822
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
414 } AVImageFormat;
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
415
822
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
416 void av_register_image_format(AVImageFormat *img_fmt);
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
417 AVImageFormat *av_probe_image_format(AVProbeData *pd);
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
418 AVImageFormat *guess_image_format(const char *filename);
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
419 enum CodecID av_guess_image2_codec(const char *filename);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
420 int av_read_image(ByteIOContext *pb, const char *filename,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
421 AVImageFormat *fmt,
822
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
422 int (*alloc_cb)(void *, AVImageInfo *info), void *opaque);
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
423 int av_write_image(ByteIOContext *pb, AVImageFormat *fmt, AVImageInfo *img);
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
424
822
a35b692388f6 [svn] - i don't want to hear about deprecation, thanks.
nenolod
parents: 814
diff changeset
425 extern AVImageFormat *first_image_format;
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
426
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
427 /* XXX: use automatic init with either ELF sections or C file parser */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
428 /* modules */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
429
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
430 /* utils.c */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
431 void av_register_input_format(AVInputFormat *format);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
432 void av_register_output_format(AVOutputFormat *format);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
433 AVOutputFormat *guess_stream_format(const char *short_name,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
434 const char *filename, const char *mime_type);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
435 AVOutputFormat *guess_format(const char *short_name,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
436 const char *filename, const char *mime_type);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
437 enum CodecID av_guess_codec(AVOutputFormat *fmt, const char *short_name,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
438 const char *filename, const char *mime_type, enum CodecType type);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
439
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
440 void av_hex_dump(FILE *f, uint8_t *buf, int size);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
441 void av_pkt_dump(FILE *f, AVPacket *pkt, int dump_payload);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
442
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
443 void av_register_all(void);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
444
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
445 /* media file input */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
446 AVInputFormat *av_find_input_format(const char *short_name);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
447 AVInputFormat *av_probe_input_format(AVProbeData *pd, int is_opened);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
448 int av_open_input_stream(AVFormatContext **ic_ptr,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
449 ByteIOContext *pb, const char *filename,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
450 AVInputFormat *fmt, AVFormatParameters *ap);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
451 int av_open_input_file(AVFormatContext **ic_ptr, const char *filename,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
452 AVInputFormat *fmt,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
453 int buf_size,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
454 AVFormatParameters *ap);
823
a195f1259a6b [svn] - merge VFS support from wma plugin.
nenolod
parents: 822
diff changeset
455 int av_open_input_vfsfile(AVFormatContext **ic_ptr, const char *fn, VFSFile *fd,
a195f1259a6b [svn] - merge VFS support from wma plugin.
nenolod
parents: 822
diff changeset
456 AVInputFormat *fmt,
a195f1259a6b [svn] - merge VFS support from wma plugin.
nenolod
parents: 822
diff changeset
457 int buf_size,
a195f1259a6b [svn] - merge VFS support from wma plugin.
nenolod
parents: 822
diff changeset
458 AVFormatParameters *ap);
808
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
459 /* no av_open for output, so applications will need this: */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
460 AVFormatContext *av_alloc_format_context(void);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
461
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
462 #define AVERROR_UNKNOWN (-1) /* unknown error */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
463 #define AVERROR_IO (-2) /* i/o error */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
464 #define AVERROR_NUMEXPECTED (-3) /* number syntax expected in filename */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
465 #define AVERROR_INVALIDDATA (-4) /* invalid data found */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
466 #define AVERROR_NOMEM (-5) /* not enough memory */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
467 #define AVERROR_NOFMT (-6) /* unknown format */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
468 #define AVERROR_NOTSUPP (-7) /* operation not supported */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
469
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
470 int av_find_stream_info(AVFormatContext *ic);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
471 int av_read_packet(AVFormatContext *s, AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
472 int av_read_frame(AVFormatContext *s, AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
473 int av_seek_frame(AVFormatContext *s, int stream_index, int64_t timestamp, int flags);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
474 int av_read_play(AVFormatContext *s);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
475 int av_read_pause(AVFormatContext *s);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
476 void av_close_input_file(AVFormatContext *s);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
477 AVStream *av_new_stream(AVFormatContext *s, int id);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
478 void av_set_pts_info(AVStream *s, int pts_wrap_bits,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
479 int pts_num, int pts_den);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
480
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
481 #define AVSEEK_FLAG_BACKWARD 1 ///< seek backward
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
482 #define AVSEEK_FLAG_BYTE 2 ///< seeking based on position in bytes
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
483 #define AVSEEK_FLAG_ANY 4 ///< seek to any frame, even non keyframes
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
484
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
485 int av_find_default_stream_index(AVFormatContext *s);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
486 int av_index_search_timestamp(AVStream *st, int64_t timestamp, int flags);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
487 int av_add_index_entry(AVStream *st,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
488 int64_t pos, int64_t timestamp, int size, int distance, int flags);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
489 int av_seek_frame_binary(AVFormatContext *s, int stream_index, int64_t target_ts, int flags);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
490 void av_update_cur_dts(AVFormatContext *s, AVStream *ref_st, int64_t timestamp);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
491
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
492 /* media file output */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
493 int av_set_parameters(AVFormatContext *s, AVFormatParameters *ap);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
494 int av_write_header(AVFormatContext *s);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
495 int av_write_frame(AVFormatContext *s, AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
496 int av_interleaved_write_frame(AVFormatContext *s, AVPacket *pkt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
497 int av_interleave_packet_per_dts(AVFormatContext *s, AVPacket *out, AVPacket *pkt, int flush);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
498
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
499 int av_write_trailer(AVFormatContext *s);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
500
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
501 void dump_format(AVFormatContext *ic,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
502 int index,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
503 const char *url,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
504 int is_output);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
505 int parse_image_size(int *width_ptr, int *height_ptr, const char *str);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
506 int parse_frame_rate(int *frame_rate, int *frame_rate_base, const char *arg);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
507 int64_t parse_date(const char *datestr, int duration);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
508
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
509 int64_t av_gettime(void);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
510
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
511 /* ffm specific for ffserver */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
512 #define FFM_PACKET_SIZE 4096
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
513 offset_t ffm_read_write_index(int fd);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
514 void ffm_write_write_index(int fd, offset_t pos);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
515 void ffm_set_write_index(AVFormatContext *s, offset_t pos, offset_t file_size);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
516
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
517 int find_info_tag(char *arg, int arg_size, const char *tag1, const char *info);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
518
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
519 int av_get_frame_filename(char *buf, int buf_size,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
520 const char *path, int number);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
521 int av_filename_number_test(const char *filename);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
522
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
523 /* grab specific */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
524 int video_grab_init(void);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
525 int audio_init(void);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
526
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
527 /* DV1394 */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
528 int dv1394_init(void);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
529 int dc1394_init(void);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
530
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
531 #ifdef HAVE_AV_CONFIG_H
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
532
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
533 #include "os_support.h"
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
534
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
535 int strstart(const char *str, const char *val, const char **ptr);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
536 int stristart(const char *str, const char *val, const char **ptr);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
537 void pstrcpy(char *buf, int buf_size, const char *str);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
538 char *pstrcat(char *buf, int buf_size, const char *s);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
539
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
540 void __dynarray_add(unsigned long **tab_ptr, int *nb_ptr, unsigned long elem);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
541
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
542 #ifdef __GNUC__
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
543 #define dynarray_add(tab, nb_ptr, elem)\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
544 do {\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
545 typeof(tab) _tab = (tab);\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
546 typeof(elem) _elem = (elem);\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
547 (void)sizeof(**_tab == _elem); /* check that types are compatible */\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
548 __dynarray_add((unsigned long **)_tab, nb_ptr, (unsigned long)_elem);\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
549 } while(0)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
550 #else
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
551 #define dynarray_add(tab, nb_ptr, elem)\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
552 do {\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
553 __dynarray_add((unsigned long **)(tab), nb_ptr, (unsigned long)(elem));\
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
554 } while(0)
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
555 #endif
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
556
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
557 time_t mktimegm(struct tm *tm);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
558 struct tm *brktimegm(time_t secs, struct tm *tm);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
559 const char *small_strptime(const char *p, const char *fmt,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
560 struct tm *dt);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
561
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
562 struct in_addr;
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
563 int resolve_host(struct in_addr *sin_addr, const char *hostname);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
564
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
565 void url_split(char *proto, int proto_size,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
566 char *authorization, int authorization_size,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
567 char *hostname, int hostname_size,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
568 int *port_ptr,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
569 char *path, int path_size,
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
570 const char *url);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
571
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
572 int match_ext(const char *filename, const char *extensions);
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
573
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
574 #endif /* HAVE_AV_CONFIG_H */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
575
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
576 #ifdef __cplusplus
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
577 }
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
578 #endif
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
579
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
580 #endif /* AVFORMAT_H */
e8776388b02a [svn] - add ffmpeg
nenolod
parents:
diff changeset
581