Mercurial > libavformat.hg
annotate avformat.h @ 1840:daaa79ca14f0 libavformat
Move the libavformat public API comments to avformat.h. The comments are
unmodified.
author | takis |
---|---|
date | Sat, 03 Mar 2007 12:23:20 +0000 |
parents | 62792a60f740 |
children | 2c91663b3bc6 |
rev | line source |
---|---|
1306
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
1 /* |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
2 * copyright (c) 2001 Fabrice Bellard |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
3 * |
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
4 * This file is part of FFmpeg. |
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
5 * |
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
6 * FFmpeg is free software; you can redistribute it and/or |
1306
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
7 * modify it under the terms of the GNU Lesser General Public |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
8 * License as published by the Free Software Foundation; either |
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
9 * version 2.1 of the License, or (at your option) any later version. |
1306
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
10 * |
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
11 * FFmpeg is distributed in the hope that it will be useful, |
1306
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
14 * Lesser General Public License for more details. |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
15 * |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
16 * You should have received a copy of the GNU Lesser General Public |
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
17 * License along with FFmpeg; if not, write to the Free Software |
1306
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
19 */ |
8bf9be9bb107
Add official LGPL license headers to the files that were missing them.
diego
parents:
1304
diff
changeset
|
20 |
0 | 21 #ifndef AVFORMAT_H |
22 #define AVFORMAT_H | |
23 | |
39 | 24 #ifdef __cplusplus |
25 extern "C" { | |
26 #endif | |
27 | |
1787
eb16c64144ee
This fixes error handling for BeOS, removing the need for some ifdefs.
mmu_man
parents:
1778
diff
changeset
|
28 #define LIBAVFORMAT_VERSION_INT ((51<<16)+(10<<8)+0) |
eb16c64144ee
This fixes error handling for BeOS, removing the need for some ifdefs.
mmu_man
parents:
1778
diff
changeset
|
29 #define LIBAVFORMAT_VERSION 51.10.0 |
829 | 30 #define LIBAVFORMAT_BUILD LIBAVFORMAT_VERSION_INT |
218 | 31 |
829 | 32 #define LIBAVFORMAT_IDENT "Lavf" AV_STRINGIFY(LIBAVFORMAT_VERSION) |
0 | 33 |
230
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
34 #include <time.h> |
314 | 35 #include <stdio.h> /* FILE */ |
0 | 36 #include "avcodec.h" |
37 | |
38 #include "avio.h" | |
39 | |
40 /* packet functions */ | |
41 | |
42 typedef struct AVPacket { | |
775 | 43 int64_t pts; ///< presentation time stamp in time_base units |
44 int64_t dts; ///< decompression time stamp in time_base units | |
65 | 45 uint8_t *data; |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
46 int size; |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
47 int stream_index; |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
48 int flags; |
775 | 49 int duration; ///< presentation duration in time_base units (0 if not available) |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
50 void (*destruct)(struct AVPacket *); |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
51 void *priv; |
775 | 52 int64_t pos; ///< byte position in stream, -1 if unknown |
885 | 53 } AVPacket; |
0 | 54 #define PKT_FLAG_KEY 0x0001 |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
55 |
535 | 56 void av_destruct_packet_nofree(AVPacket *pkt); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
57 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
58 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
59 * Default packet destructor. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
60 */ |
797
f5a231a9a2f1
support changing in bitstream global headers into extradata style and back
michael
parents:
795
diff
changeset
|
61 void av_destruct_packet(AVPacket *pkt); |
535 | 62 |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
63 /* initialize optional fields of a packet */ |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
64 static inline void av_init_packet(AVPacket *pkt) |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
65 { |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
66 pkt->pts = AV_NOPTS_VALUE; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
67 pkt->dts = AV_NOPTS_VALUE; |
775 | 68 pkt->pos = -1; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
69 pkt->duration = 0; |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
70 pkt->flags = 0; |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
71 pkt->stream_index = 0; |
535 | 72 pkt->destruct= av_destruct_packet_nofree; |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
73 } |
0 | 74 |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
75 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
76 * Allocate the payload of a packet and intialized its fields to default values. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
77 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
78 * @param pkt packet |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
79 * @param size wanted payload size |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
80 * @return 0 if OK. AVERROR_xxx otherwise. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
81 */ |
0 | 82 int av_new_packet(AVPacket *pkt, int size); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
83 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
84 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
85 * Allocate and read the payload of a packet and intialized its fields to default values. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
86 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
87 * @param pkt packet |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
88 * @param size wanted payload size |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
89 * @return >0 (read size) if OK. AVERROR_xxx otherwise. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
90 */ |
775 | 91 int av_get_packet(ByteIOContext *s, AVPacket *pkt, int size); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
92 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
93 /* This is a hack - the packet memory allocation stuff is broken. The |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
94 packet is allocated if it was not really allocated */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
95 int av_dup_packet(AVPacket *pkt); |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
96 |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
97 /** |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
98 * Free a packet |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
99 * |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
100 * @param pkt packet to free |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
101 */ |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
102 static inline void av_free_packet(AVPacket *pkt) |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
103 { |
163
470456bd0065
av_free_packet SEGV fix by (Arthur van Hoff (javanator))
michaelni
parents:
159
diff
changeset
|
104 if (pkt && pkt->destruct) { |
887 | 105 pkt->destruct(pkt); |
163
470456bd0065
av_free_packet SEGV fix by (Arthur van Hoff (javanator))
michaelni
parents:
159
diff
changeset
|
106 } |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
107 } |
0 | 108 |
109 /*************************************************/ | |
110 /* fractional numbers for exact pts handling */ | |
111 | |
112 /* the exact value of the fractional number is: 'val + num / den'. num | |
113 is assumed to be such as 0 <= num < den */ | |
114 typedef struct AVFrac { | |
885 | 115 int64_t val, num, den; |
1258 | 116 } AVFrac attribute_deprecated; |
0 | 117 |
118 /*************************************************/ | |
119 /* input/output formats */ | |
120 | |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
121 struct AVCodecTag; |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
122 |
0 | 123 struct AVFormatContext; |
124 | |
125 /* this structure contains the data a format has to probe a file */ | |
126 typedef struct AVProbeData { | |
64 | 127 const char *filename; |
0 | 128 unsigned char *buf; |
129 int buf_size; | |
130 } AVProbeData; | |
131 | |
1304 | 132 #define AVPROBE_SCORE_MAX 100 ///< max score, half of that is used for file extension based detection |
0 | 133 |
134 typedef struct AVFormatParameters { | |
743 | 135 AVRational time_base; |
0 | 136 int sample_rate; |
137 int channels; | |
138 int width; | |
139 int height; | |
140 enum PixelFormat pix_fmt; | |
30
90fd30dd68b3
grab device is in AVFormatParameter (at least better than global variable)
bellard
parents:
29
diff
changeset
|
141 int channel; /* used to select dv channel */ |
1795
62792a60f740
implement new grabbing interface, as described here:
gpoirier
parents:
1787
diff
changeset
|
142 #if LIBAVFORMAT_VERSION_INT < (52<<16) |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
793
diff
changeset
|
143 const char *device; /* video, audio or DV device */ |
1795
62792a60f740
implement new grabbing interface, as described here:
gpoirier
parents:
1787
diff
changeset
|
144 #endif |
159
7d698c3213a0
tv standard selection support for dv1394 and grab (v4l)
al3x
parents:
151
diff
changeset
|
145 const char *standard; /* tv standard, NTSC, PAL, SECAM */ |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
146 int mpeg2ts_raw:1; /* force raw MPEG2 transport stream output, if possible */ |
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
147 int mpeg2ts_compute_pcr:1; /* compute exact PCR for each transport |
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
148 stream packet (only meaningful if |
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
149 mpeg2ts_raw is TRUE */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
150 int initial_pause:1; /* do not begin to play the stream |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
151 immediately (RTSP only) */ |
1278 | 152 int prealloced_context:1; |
583 | 153 enum CodecID video_codec_id; |
154 enum CodecID audio_codec_id; | |
0 | 155 } AVFormatParameters; |
156 | |
1675 | 157 //! demuxer will use url_fopen, no opened file should be provided by the caller |
158 #define AVFMT_NOFILE 0x0001 | |
885 | 159 #define AVFMT_NEEDNUMBER 0x0002 /* needs '%d' in filename */ |
0 | 160 #define AVFMT_SHOW_IDS 0x0008 /* show format stream IDs numbers */ |
161 #define AVFMT_RAWPICTURE 0x0020 /* format wants AVPicture structure for | |
162 raw picture data */ | |
715
e214703e4b76
30_clean_up_global_header_flag.patch by (Calcium | calcium nurs or jp)
michael
parents:
708
diff
changeset
|
163 #define AVFMT_GLOBALHEADER 0x0040 /* format wants global header */ |
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1185
diff
changeset
|
164 #define AVFMT_NOTIMESTAMPS 0x0080 /* format doesnt need / has any timestamps */ |
1756 | 165 #define AVFMT_GENERIC_INDEX 0x0100 /* use generic index building code */ |
0 | 166 |
167 typedef struct AVOutputFormat { | |
168 const char *name; | |
169 const char *long_name; | |
170 const char *mime_type; | |
171 const char *extensions; /* comma separated extensions */ | |
172 /* size of private data so that it can be allocated in the wrapper */ | |
173 int priv_data_size; | |
174 /* output support */ | |
175 enum CodecID audio_codec; /* default audio codec */ | |
176 enum CodecID video_codec; /* default video codec */ | |
177 int (*write_header)(struct AVFormatContext *); | |
468 | 178 int (*write_packet)(struct AVFormatContext *, AVPacket *pkt); |
0 | 179 int (*write_trailer)(struct AVFormatContext *); |
715
e214703e4b76
30_clean_up_global_header_flag.patch by (Calcium | calcium nurs or jp)
michael
parents:
708
diff
changeset
|
180 /* can use flags: AVFMT_NOFILE, AVFMT_NEEDNUMBER, AVFMT_GLOBALHEADER */ |
0 | 181 int flags; |
17
e1200dd82537
added simple still image format support to simplify image and imagepipe video formats
bellard
parents:
5
diff
changeset
|
182 /* currently only used to set pixel format if not YUV420P */ |
e1200dd82537
added simple still image format support to simplify image and imagepipe video formats
bellard
parents:
5
diff
changeset
|
183 int (*set_parameters)(struct AVFormatContext *, AVFormatParameters *); |
536
76c47c58064f
move packet interleaving function into AVOutputFormat, so it can be overriden easily instead of doing reordering twice if the muxer needs some other interleaving then dts based
michael
parents:
535
diff
changeset
|
184 int (*interleave_packet)(struct AVFormatContext *, AVPacket *out, AVPacket *in, int flush); |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
185 |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
186 /** |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
187 * list of supported codec_id-codec_tag pairs, ordered by "better choice first" |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
188 * the arrays are all CODEC_ID_NONE terminated |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
189 */ |
1679 | 190 const struct AVCodecTag **codec_tag; |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
191 |
0 | 192 /* private fields */ |
193 struct AVOutputFormat *next; | |
194 } AVOutputFormat; | |
195 | |
196 typedef struct AVInputFormat { | |
197 const char *name; | |
198 const char *long_name; | |
199 /* size of private data so that it can be allocated in the wrapper */ | |
200 int priv_data_size; | |
201 /* tell if a given file has a chance of being parsing by this format */ | |
202 int (*read_probe)(AVProbeData *); | |
203 /* read the format header and initialize the AVFormatContext | |
204 structure. Return 0 if OK. 'ap' if non NULL contains | |
205 additionnal paramters. Only used in raw format right | |
206 now. 'av_new_stream' should be called to create new streams. */ | |
207 int (*read_header)(struct AVFormatContext *, | |
208 AVFormatParameters *ap); | |
209 /* read one packet and put it in 'pkt'. pts and flags are also | |
210 set. 'av_new_stream' can be called only if the flag | |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
211 AVFMTCTX_NOHEADER is used. */ |
0 | 212 int (*read_packet)(struct AVFormatContext *, AVPacket *pkt); |
213 /* close the stream. The AVFormatContext and AVStreams are not | |
214 freed by this function */ | |
215 int (*read_close)(struct AVFormatContext *); | |
885 | 216 /** |
217 * seek to a given timestamp relative to the frames in | |
555 | 218 * stream component stream_index |
219 * @param stream_index must not be -1 | |
885 | 220 * @param flags selects which direction should be preferred if no exact |
555 | 221 * match is available |
222 */ | |
885 | 223 int (*read_seek)(struct AVFormatContext *, |
555 | 224 int stream_index, int64_t timestamp, int flags); |
437
50bae308f71e
moving nearly identical binary search code from nut/mpeg/asf to utils.c
michael
parents:
420
diff
changeset
|
225 /** |
50bae308f71e
moving nearly identical binary search code from nut/mpeg/asf to utils.c
michael
parents:
420
diff
changeset
|
226 * gets the next timestamp in AV_TIME_BASE units. |
50bae308f71e
moving nearly identical binary search code from nut/mpeg/asf to utils.c
michael
parents:
420
diff
changeset
|
227 */ |
50bae308f71e
moving nearly identical binary search code from nut/mpeg/asf to utils.c
michael
parents:
420
diff
changeset
|
228 int64_t (*read_timestamp)(struct AVFormatContext *s, int stream_index, |
50bae308f71e
moving nearly identical binary search code from nut/mpeg/asf to utils.c
michael
parents:
420
diff
changeset
|
229 int64_t *pos, int64_t pos_limit); |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
230 /* can use flags: AVFMT_NOFILE, AVFMT_NEEDNUMBER */ |
0 | 231 int flags; |
232 /* if extensions are defined, then no probe is done. You should | |
233 usually not use extension format guessing because it is not | |
234 reliable enough */ | |
235 const char *extensions; | |
236 /* general purpose read only value that the format can use */ | |
237 int value; | |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
238 |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
239 /* start/resume playing - only meaningful if using a network based format |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
240 (RTSP) */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
241 int (*read_play)(struct AVFormatContext *); |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
242 |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
243 /* pause playing - only meaningful if using a network based format |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
244 (RTSP) */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
245 int (*read_pause)(struct AVFormatContext *); |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
246 |
1679 | 247 const struct AVCodecTag **codec_tag; |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
248 |
0 | 249 /* private fields */ |
250 struct AVInputFormat *next; | |
251 } AVInputFormat; | |
252 | |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
253 typedef struct AVIndexEntry { |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
254 int64_t pos; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
255 int64_t timestamp; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
256 #define AVINDEX_KEYFRAME 0x0001 |
979 | 257 int flags:2; |
258 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) | |
354
6770ca07abe2
store searched distance in index, so we dont waste time searching for keyframes where we already searched
michael
parents:
346
diff
changeset
|
259 int min_distance; /* min distance between this and the previous keyframe, used to avoid unneeded searching */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
260 } AVIndexEntry; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
261 |
0 | 262 typedef struct AVStream { |
263 int index; /* stream index in AVFormatContext */ | |
264 int id; /* format specific stream id */ | |
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
818
diff
changeset
|
265 AVCodecContext *codec; /* codec context */ |
793 | 266 /** |
267 * real base frame rate of the stream. | |
1486 | 268 * this is the lowest framerate with which all timestamps can be |
269 * represented accurately (its the least common multiple of all | |
270 * framerates in the stream), Note, this value is just a guess! | |
885 | 271 * for example if the timebase is 1/90000 and all frames have either |
793 | 272 * approximately 3600 or 1800 timer ticks then r_frame_rate will be 50/1 |
273 */ | |
274 AVRational r_frame_rate; | |
0 | 275 void *priv_data; |
276 /* internal data used in av_find_stream_info() */ | |
885 | 277 int64_t codec_info_duration; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
278 int codec_info_nb_frames; |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
279 /* encoding: PTS generation when outputing stream */ |
0 | 280 AVFrac pts; |
844
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
281 |
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
282 /** |
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
283 * this is the fundamental unit of time (in seconds) in terms |
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
284 * of which frame timestamps are represented. for fixed-fps content, |
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
285 * timebase should be 1/framerate and timestamp increments should be |
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
286 * identically 1. |
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
287 */ |
462
b69898ffc92a
move time_base (pts_num/pts_den) from AVFormatContext -> AVStream
michael
parents:
437
diff
changeset
|
288 AVRational time_base; |
b69898ffc92a
move time_base (pts_num/pts_den) from AVFormatContext -> AVStream
michael
parents:
437
diff
changeset
|
289 int pts_wrap_bits; /* number of bits in pts (used for wrapping control) */ |
0 | 290 /* ffmpeg.c private use */ |
291 int stream_copy; /* if TRUE, just copy stream */ | |
708 | 292 enum AVDiscard discard; ///< selects which packets can be discarded at will and dont need to be demuxed |
650 | 293 //FIXME move stuff to a flags field? |
5 | 294 /* quality, as it has been removed from AVCodecContext and put in AVVideoFrame |
295 * MN:dunno if thats the right place, for it */ | |
885 | 296 float quality; |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
297 /* decoding: position of the first frame of the component, in |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
298 AV_TIME_BASE fractional seconds. */ |
885 | 299 int64_t start_time; |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
300 /* decoding: duration of the stream, in AV_TIME_BASE fractional |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
301 seconds. */ |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
302 int64_t duration; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
303 |
784 | 304 char language[4]; /* ISO 639 3-letter language code (empty string if undefined) */ |
305 | |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
306 /* av_read_frame() support */ |
842 | 307 int need_parsing; ///< 1->full parsing needed, 2->only parse headers dont repack |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
308 struct AVCodecParserContext *parser; |
334
7f089db11f9a
fixed incorrect PTS/DTS logic in MPEG video case (caused rare PTS glitches if start codes were between two PES packets)
bellard
parents:
315
diff
changeset
|
309 |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
310 int64_t cur_dts; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
311 int last_IP_duration; |
464 | 312 int64_t last_IP_pts; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
313 /* av_seek_frame() support */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
314 AVIndexEntry *index_entries; /* only used if the format does not |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
315 support seeking natively */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
316 int nb_index_entries; |
1332 | 317 unsigned int index_entries_allocated_size; |
885 | 318 |
793 | 319 int64_t nb_frames; ///< number of frames in this stream if known or 0 |
1285
b5226e679a31
fix b pyramid in mp4 muxing if no dts are provided to the muxer
michael
parents:
1279
diff
changeset
|
320 |
b5226e679a31
fix b pyramid in mp4 muxing if no dts are provided to the muxer
michael
parents:
1279
diff
changeset
|
321 #define MAX_REORDER_DELAY 4 |
b5226e679a31
fix b pyramid in mp4 muxing if no dts are provided to the muxer
michael
parents:
1279
diff
changeset
|
322 int64_t pts_buffer[MAX_REORDER_DELAY+1]; |
0 | 323 } AVStream; |
324 | |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
325 #define AVFMTCTX_NOHEADER 0x0001 /* signal that no header is present |
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
326 (streams are added dynamically) */ |
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
327 |
0 | 328 #define MAX_STREAMS 20 |
329 | |
330 /* format I/O context */ | |
331 typedef struct AVFormatContext { | |
549 | 332 const AVClass *av_class; /* set by av_alloc_format_context */ |
0 | 333 /* can only be iformat or oformat, not both at the same time */ |
334 struct AVInputFormat *iformat; | |
335 struct AVOutputFormat *oformat; | |
336 void *priv_data; | |
337 ByteIOContext pb; | |
1663 | 338 unsigned int nb_streams; |
0 | 339 AVStream *streams[MAX_STREAMS]; |
340 char filename[1024]; /* input or output filename */ | |
341 /* stream info */ | |
420
e440fb884442
* making it possible to specify recording date and time in a stream
romansh
parents:
384
diff
changeset
|
342 int64_t timestamp; |
0 | 343 char title[512]; |
344 char author[512]; | |
345 char copyright[512]; | |
346 char comment[512]; | |
234 | 347 char album[512]; |
348 int year; /* ID3 year, 0 if none */ | |
349 int track; /* track number, 0 if none */ | |
350 char genre[32]; /* ID3 genre */ | |
351 | |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
352 int ctx_flags; /* format specific flags, see AVFMTCTX_xx */ |
0 | 353 /* private data for pts handling (do not modify directly) */ |
354 /* This buffer is only needed when packets were already buffered but | |
355 not decoded, for example to get the codec parameters in mpeg | |
356 streams */ | |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
357 struct AVPacketList *packet_buffer; |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
358 |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
359 /* decoding: position of the first frame of the component, in |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
360 AV_TIME_BASE fractional seconds. NEVER set this value directly: |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
361 it is deduced from the AVStream values. */ |
885 | 362 int64_t start_time; |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
363 /* decoding: duration of the stream, in AV_TIME_BASE fractional |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
364 seconds. NEVER set this value directly: it is deduced from the |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
365 AVStream values. */ |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
366 int64_t duration; |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
367 /* decoding: total file size. 0 if unknown */ |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
368 int64_t file_size; |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
369 /* decoding: total stream bitrate in bit/s, 0 if not |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
370 available. Never set it directly if the file_size and the |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
371 duration are known as ffmpeg can compute it automatically. */ |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
372 int bit_rate; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
373 |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
374 /* av_read_frame() support */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
375 AVStream *cur_st; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
376 const uint8_t *cur_ptr; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
377 int cur_len; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
378 AVPacket cur_pkt; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
379 |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
380 /* av_seek_frame() support */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
381 int64_t data_offset; /* offset of the first packet */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
382 int index_built; |
885 | 383 |
551 | 384 int mux_rate; |
385 int packet_size; | |
566 | 386 int preload; |
387 int max_delay; | |
790
80aec794c2ed
Animated GIF looping patch by (Todd Kirby // ffmpeg.php gmail com)
michael
parents:
784
diff
changeset
|
388 |
885 | 389 #define AVFMT_NOOUTPUTLOOP -1 |
390 #define AVFMT_INFINITEOUTPUTLOOP 0 | |
790
80aec794c2ed
Animated GIF looping patch by (Todd Kirby // ffmpeg.php gmail com)
michael
parents:
784
diff
changeset
|
391 /* number of times to loop output in formats that support it */ |
80aec794c2ed
Animated GIF looping patch by (Todd Kirby // ffmpeg.php gmail com)
michael
parents:
784
diff
changeset
|
392 int loop_output; |
885 | 393 |
841
ba7631ba33a7
support fixing missing pts by parsing future frames
michael
parents:
829
diff
changeset
|
394 int flags; |
ba7631ba33a7
support fixing missing pts by parsing future frames
michael
parents:
829
diff
changeset
|
395 #define AVFMT_FLAG_GENPTS 0x0001 ///< generate pts if missing even if it requires parsing future frames |
1294
12398b868e18
ignore index parameter to ignore the ODML index in avi
michael
parents:
1291
diff
changeset
|
396 #define AVFMT_FLAG_IGNIDX 0x0002 ///< ignore index |
1175
8b53c0f3e7ad
add loop_input to AVFormatContext, getting rid of old hack
mru
parents:
1167
diff
changeset
|
397 |
8b53c0f3e7ad
add loop_input to AVFormatContext, getting rid of old hack
mru
parents:
1167
diff
changeset
|
398 int loop_input; |
1279
a12e0b434174
added option probesize; at the moment only used by mpegts.c
nicodvb
parents:
1278
diff
changeset
|
399 /* decoding: size of data to probe; encoding unused */ |
a12e0b434174
added option probesize; at the moment only used by mpegts.c
nicodvb
parents:
1278
diff
changeset
|
400 unsigned int probesize; |
1720
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
401 |
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
402 /** |
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
403 * maximum duration in AV_TIME_BASE units over which the input should be analyzed in av_find_stream_info() |
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
404 */ |
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
405 int max_analyze_duration; |
1778
d8c6b719a070
add key field to AVFormatContext for de/encryption support, patch by Reimar
bcoudurier
parents:
1756
diff
changeset
|
406 |
d8c6b719a070
add key field to AVFormatContext for de/encryption support, patch by Reimar
bcoudurier
parents:
1756
diff
changeset
|
407 const uint8_t *key; |
d8c6b719a070
add key field to AVFormatContext for de/encryption support, patch by Reimar
bcoudurier
parents:
1756
diff
changeset
|
408 int keylen; |
0 | 409 } AVFormatContext; |
410 | |
411 typedef struct AVPacketList { | |
412 AVPacket pkt; | |
413 struct AVPacketList *next; | |
414 } AVPacketList; | |
415 | |
416 extern AVInputFormat *first_iformat; | |
417 extern AVOutputFormat *first_oformat; | |
418 | |
583 | 419 enum CodecID av_guess_image2_codec(const char *filename); |
17
e1200dd82537
added simple still image format support to simplify image and imagepipe video formats
bellard
parents:
5
diff
changeset
|
420 |
0 | 421 /* XXX: use automatic init with either ELF sections or C file parser */ |
422 /* modules */ | |
423 | |
424 #include "rtp.h" | |
425 | |
426 #include "rtsp.h" | |
427 | |
428 /* utils.c */ | |
429 void av_register_input_format(AVInputFormat *format); | |
430 void av_register_output_format(AVOutputFormat *format); | |
885 | 431 AVOutputFormat *guess_stream_format(const char *short_name, |
0 | 432 const char *filename, const char *mime_type); |
885 | 433 AVOutputFormat *guess_format(const char *short_name, |
0 | 434 const char *filename, const char *mime_type); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
435 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
436 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
437 * Guesses the codec id based upon muxer and filename. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
438 */ |
885 | 439 enum CodecID av_guess_codec(AVOutputFormat *fmt, const char *short_name, |
583 | 440 const char *filename, const char *mime_type, enum CodecType type); |
0 | 441 |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
442 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
443 * Print nice hexa dump of a buffer |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
444 * @param f stream for output |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
445 * @param buf buffer |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
446 * @param size buffer size |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
447 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
448 void av_hex_dump(FILE *f, uint8_t *buf, int size); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
449 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
450 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
451 * Print on 'f' a nice dump of a packet |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
452 * @param f stream for output |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
453 * @param pkt packet to dump |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
454 * @param dump_payload true if the payload must be displayed too |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
455 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
456 void av_pkt_dump(FILE *f, AVPacket *pkt, int dump_payload); |
0 | 457 |
458 void av_register_all(void); | |
459 | |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
460 /* codec tag <-> codec id */ |
1679 | 461 enum CodecID av_codec_get_id(const struct AVCodecTag **tags, unsigned int tag); |
462 unsigned int av_codec_get_tag(const struct AVCodecTag **tags, enum CodecID id); | |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
463 |
0 | 464 /* media file input */ |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
465 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
466 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
467 * finds AVInputFormat based on input format's short name. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
468 */ |
0 | 469 AVInputFormat *av_find_input_format(const char *short_name); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
470 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
471 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
472 * Guess file format. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
473 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
474 * @param is_opened whether the file is already opened, determines whether |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
475 * demuxers with or without AVFMT_NOFILE are probed |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
476 */ |
0 | 477 AVInputFormat *av_probe_input_format(AVProbeData *pd, int is_opened); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
478 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
479 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
480 * Allocates all the structures needed to read an input stream. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
481 * This does not open the needed codecs for decoding the stream[s]. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
482 */ |
885 | 483 int av_open_input_stream(AVFormatContext **ic_ptr, |
484 ByteIOContext *pb, const char *filename, | |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
485 AVInputFormat *fmt, AVFormatParameters *ap); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
486 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
487 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
488 * Open a media file as input. The codec are not opened. Only the file |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
489 * header (if present) is read. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
490 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
491 * @param ic_ptr the opened media file handle is put here |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
492 * @param filename filename to open. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
493 * @param fmt if non NULL, force the file format to use |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
494 * @param buf_size optional buffer size (zero if default is OK) |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
495 * @param ap additionnal parameters needed when opening the file (NULL if default) |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
496 * @return 0 if OK. AVERROR_xxx otherwise. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
497 */ |
885 | 498 int av_open_input_file(AVFormatContext **ic_ptr, const char *filename, |
0 | 499 AVInputFormat *fmt, |
500 int buf_size, | |
501 AVFormatParameters *ap); | |
370
845f9de2c883
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
369
diff
changeset
|
502 /* no av_open for output, so applications will need this: */ |
845f9de2c883
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
369
diff
changeset
|
503 AVFormatContext *av_alloc_format_context(void); |
0 | 504 |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
505 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
506 * Read packets of a media file to get stream information. This |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
507 * is useful for file formats with no headers such as MPEG. This |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
508 * function also computes the real frame rate in case of mpeg2 repeat |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
509 * frame mode. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
510 * The logical file position is not changed by this function; |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
511 * examined packets may be buffered for later processing. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
512 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
513 * @param ic media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
514 * @return >=0 if OK. AVERROR_xxx if error. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
515 * @todo let user decide somehow what information is needed so we dont waste time geting stuff the user doesnt need |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
516 */ |
0 | 517 int av_find_stream_info(AVFormatContext *ic); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
518 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
519 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
520 * Read a transport packet from a media file. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
521 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
522 * This function is absolete and should never be used. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
523 * Use av_read_frame() instead. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
524 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
525 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
526 * @param pkt is filled |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
527 * @return 0 if OK. AVERROR_xxx if error. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
528 */ |
0 | 529 int av_read_packet(AVFormatContext *s, AVPacket *pkt); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
530 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
531 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
532 * Return the next frame of a stream. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
533 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
534 * The returned packet is valid |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
535 * until the next av_read_frame() or until av_close_input_file() and |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
536 * must be freed with av_free_packet. For video, the packet contains |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
537 * exactly one frame. For audio, it contains an integer number of |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
538 * frames if each frame has a known fixed size (e.g. PCM or ADPCM |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
539 * data). If the audio frames have a variable size (e.g. MPEG audio), |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
540 * then it contains one frame. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
541 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
542 * pkt->pts, pkt->dts and pkt->duration are always set to correct |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
543 * values in AV_TIME_BASE unit (and guessed if the format cannot |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
544 * provided them). pkt->pts can be AV_NOPTS_VALUE if the video format |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
545 * has B frames, so it is better to rely on pkt->dts if you do not |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
546 * decompress the payload. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
547 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
548 * @return 0 if OK, < 0 if error or end of file. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
549 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
550 int av_read_frame(AVFormatContext *s, AVPacket *pkt); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
551 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
552 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
553 * Seek to the key frame at timestamp. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
554 * 'timestamp' in 'stream_index'. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
555 * @param stream_index If stream_index is (-1), a default |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
556 * stream is selected, and timestamp is automatically converted |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
557 * from AV_TIME_BASE units to the stream specific time_base. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
558 * @param timestamp timestamp in AVStream.time_base units |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
559 * or if there is no stream specified then in AV_TIME_BASE units |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
560 * @param flags flags which select direction and seeking mode |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
561 * @return >= 0 on success |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
562 */ |
555 | 563 int av_seek_frame(AVFormatContext *s, int stream_index, int64_t timestamp, int flags); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
564 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
565 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
566 * start playing a network based stream (e.g. RTSP stream) at the |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
567 * current position |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
568 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
569 int av_read_play(AVFormatContext *s); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
570 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
571 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
572 * Pause a network based stream (e.g. RTSP stream). |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
573 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
574 * Use av_read_play() to resume it. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
575 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
576 int av_read_pause(AVFormatContext *s); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
577 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
578 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
579 * Close a media file (but not its codecs). |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
580 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
581 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
582 */ |
0 | 583 void av_close_input_file(AVFormatContext *s); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
584 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
585 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
586 * Add a new stream to a media file. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
587 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
588 * Can only be called in the read_header() function. If the flag |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
589 * AVFMTCTX_NOHEADER is in the format context, then new streams |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
590 * can be added in read_packet too. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
591 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
592 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
593 * @param id file format dependent stream id |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
594 */ |
0 | 595 AVStream *av_new_stream(AVFormatContext *s, int id); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
596 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
597 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
598 * Set the pts for a given stream. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
599 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
600 * @param s stream |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
601 * @param pts_wrap_bits number of bits effectively used by the pts |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
602 * (used for wrap control, 33 is the value for MPEG) |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
603 * @param pts_num numerator to convert to seconds (MPEG: 1) |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
604 * @param pts_den denominator to convert to seconds (MPEG: 90000) |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
605 */ |
462
b69898ffc92a
move time_base (pts_num/pts_den) from AVFormatContext -> AVStream
michael
parents:
437
diff
changeset
|
606 void av_set_pts_info(AVStream *s, int pts_wrap_bits, |
0 | 607 int pts_num, int pts_den); |
608 | |
555 | 609 #define AVSEEK_FLAG_BACKWARD 1 ///< seek backward |
610 #define AVSEEK_FLAG_BYTE 2 ///< seeking based on position in bytes | |
698 | 611 #define AVSEEK_FLAG_ANY 4 ///< seek to any frame, even non keyframes |
555 | 612 |
346
e154eb1b7149
caching of timestamps for mpeg-ps so seeking is faster
michael
parents:
338
diff
changeset
|
613 int av_find_default_stream_index(AVFormatContext *s); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
614 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
615 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
616 * Gets the index for a specific timestamp. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
617 * @param flags if AVSEEK_FLAG_BACKWARD then the returned index will correspond to |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
618 * the timestamp which is <= the requested one, if backward is 0 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
619 * then it will be >= |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
620 * if AVSEEK_FLAG_ANY seek to any frame, only keyframes otherwise |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
621 * @return < 0 if no such timestamp could be found |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
622 */ |
597
d814669d2c13
int / int64 fix by (Wolfram Gloger <wmglo @@@ dent:med:uni-muenchen:de>)
michael
parents:
594
diff
changeset
|
623 int av_index_search_timestamp(AVStream *st, int64_t timestamp, int flags); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
624 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
625 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
626 * Add a index entry into a sorted list updateing if it is already there. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
627 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
628 * @param timestamp timestamp in the timebase of the given stream |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
629 */ |
354
6770ca07abe2
store searched distance in index, so we dont waste time searching for keyframes where we already searched
michael
parents:
346
diff
changeset
|
630 int av_add_index_entry(AVStream *st, |
979 | 631 int64_t pos, int64_t timestamp, int size, int distance, int flags); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
632 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
633 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
634 * Does a binary search using av_index_search_timestamp() and AVCodec.read_timestamp(). |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
635 * this isnt supposed to be called directly by a user application, but by demuxers |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
636 * @param target_ts target timestamp in the time base of the given stream |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
637 * @param stream_index stream number |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
638 */ |
555 | 639 int av_seek_frame_binary(AVFormatContext *s, int stream_index, int64_t target_ts, int flags); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
640 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
641 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
642 * Updates cur_dts of all streams based on given timestamp and AVStream. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
643 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
644 * Stream ref_st unchanged, others set cur_dts in their native timebase |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
645 * only needed for timestamp wrapping or if (dts not set and pts!=dts) |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
646 * @param timestamp new dts expressed in time_base of param ref_st |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
647 * @param ref_st reference stream giving time_base of param timestamp |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
648 */ |
1185
13dc486b272b
Try to find out correct start time to make seeking faster and add some
reimar
parents:
1175
diff
changeset
|
649 void av_update_cur_dts(AVFormatContext *s, AVStream *ref_st, int64_t timestamp); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
650 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
651 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
652 * Does a binary search using read_timestamp(). |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
653 * this isnt supposed to be called directly by a user application, but by demuxers |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
654 * @param target_ts target timestamp in the time base of the given stream |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
655 * @param stream_index stream number |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
656 */ |
1496
7e288adde245
split av_seek_frame_binary() so the code becomes idependant of AVInputFormat and AVIndex
michael
parents:
1486
diff
changeset
|
657 int64_t av_gen_search(AVFormatContext *s, int stream_index, int64_t target_ts, int64_t pos_min, int64_t pos_max, int64_t pos_limit, int64_t ts_min, int64_t ts_max, int flags, int64_t *ts_ret, int64_t (*read_timestamp)(struct AVFormatContext *, int , int64_t *, int64_t )); |
346
e154eb1b7149
caching of timestamps for mpeg-ps so seeking is faster
michael
parents:
338
diff
changeset
|
658 |
0 | 659 /* media file output */ |
17
e1200dd82537
added simple still image format support to simplify image and imagepipe video formats
bellard
parents:
5
diff
changeset
|
660 int av_set_parameters(AVFormatContext *s, AVFormatParameters *ap); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
661 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
662 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
663 * allocate the stream private data and write the stream header to an |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
664 * output media file |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
665 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
666 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
667 * @return 0 if OK. AVERROR_xxx if error. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
668 */ |
0 | 669 int av_write_header(AVFormatContext *s); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
670 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
671 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
672 * Write a packet to an output media file. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
673 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
674 * The packet shall contain one audio or video frame. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
675 * The packet must be correctly interleaved according to the container specification, |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
676 * if not then av_interleaved_write_frame must be used |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
677 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
678 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
679 * @param pkt the packet, which contains the stream_index, buf/buf_size, dts/pts, ... |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
680 * @return < 0 if error, = 0 if OK, 1 if end of stream wanted. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
681 */ |
468 | 682 int av_write_frame(AVFormatContext *s, AVPacket *pkt); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
683 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
684 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
685 * Writes a packet to an output media file ensuring correct interleaving. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
686 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
687 * The packet must contain one audio or video frame. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
688 * If the packets are already correctly interleaved the application should |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
689 * call av_write_frame() instead as its slightly faster, its also important |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
690 * to keep in mind that completly non interleaved input will need huge amounts |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
691 * of memory to interleave with this, so its prefereable to interleave at the |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
692 * demuxer level |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
693 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
694 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
695 * @param pkt the packet, which contains the stream_index, buf/buf_size, dts/pts, ... |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
696 * @return < 0 if error, = 0 if OK, 1 if end of stream wanted. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
697 */ |
470 | 698 int av_interleaved_write_frame(AVFormatContext *s, AVPacket *pkt); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
699 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
700 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
701 * Interleave a packet per DTS in an output media file. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
702 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
703 * Packets with pkt->destruct == av_destruct_packet will be freed inside this function, |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
704 * so they cannot be used after it, note calling av_free_packet() on them is still safe. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
705 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
706 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
707 * @param out the interleaved packet will be output here |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
708 * @param in the input packet |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
709 * @param flush 1 if no further packets are available as input and all |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
710 * remaining packets should be output |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
711 * @return 1 if a packet was output, 0 if no packet could be output, |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
712 * < 0 if an error occured |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
713 */ |
1251 | 714 int av_interleave_packet_per_dts(AVFormatContext *s, AVPacket *out, AVPacket *pkt, int flush); |
468 | 715 |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
716 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
717 * @brief Write the stream trailer to an output media file and |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
718 * free the file private data. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
719 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
720 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
721 * @return 0 if OK. AVERROR_xxx if error. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
722 */ |
0 | 723 int av_write_trailer(AVFormatContext *s); |
724 | |
725 void dump_format(AVFormatContext *ic, | |
885 | 726 int index, |
0 | 727 const char *url, |
728 int is_output); | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
729 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
730 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
731 * parses width and height out of string str. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
732 */ |
0 | 733 int parse_image_size(int *width_ptr, int *height_ptr, const char *str); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
734 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
735 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
736 * Converts frame rate from string to a fraction. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
737 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
738 * First we try to get an exact integer or fractional frame rate. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
739 * If this fails we convert the frame rate to a double and return |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
740 * an approximate fraction using the DEFAULT_FRAME_RATE_BASE. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
741 */ |
168 | 742 int parse_frame_rate(int *frame_rate, int *frame_rate_base, const char *arg); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
743 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
744 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
745 * Converts date string to number of seconds since Jan 1st, 1970. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
746 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
747 * @code |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
748 * Syntax: |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
749 * - If not a duration: |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
750 * [{YYYY-MM-DD|YYYYMMDD}]{T| }{HH[:MM[:SS[.m...]]][Z]|HH[MM[SS[.m...]]][Z]} |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
751 * Time is localtime unless Z is suffixed to the end. In this case GMT |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
752 * Return the date in micro seconds since 1970 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
753 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
754 * - If a duration: |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
755 * HH[:MM[:SS[.m...]]] |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
756 * S+[.m...] |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
757 * @endcode |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
758 */ |
65 | 759 int64_t parse_date(const char *datestr, int duration); |
0 | 760 |
65 | 761 int64_t av_gettime(void); |
0 | 762 |
763 /* ffm specific for ffserver */ | |
764 #define FFM_PACKET_SIZE 4096 | |
765 offset_t ffm_read_write_index(int fd); | |
766 void ffm_write_write_index(int fd, offset_t pos); | |
767 void ffm_set_write_index(AVFormatContext *s, offset_t pos, offset_t file_size); | |
768 | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
769 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
770 * Attempts to find a specific tag in a URL. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
771 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
772 * syntax: '?tag1=val1&tag2=val2...'. Little URL decoding is done. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
773 * Return 1 if found. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
774 */ |
0 | 775 int find_info_tag(char *arg, int arg_size, const char *tag1, const char *info); |
776 | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
777 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
778 * Returns in 'buf' the path with '%d' replaced by number. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
779 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
780 * Also handles the '%0nd' format where 'n' is the total number |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
781 * of digits and '%%'. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
782 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
783 * @param buf destination buffer |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
784 * @param buf_size destination buffer size |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
785 * @param path numbered sequence string |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
786 * @number frame number |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
787 * @return 0 if OK, -1 if format error. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
788 */ |
1291
185190bdc185
Clarified API for numbered sequences, patch by Michel Bardiaux % mbardiaux A mediaxim P be %
gpoirier
parents:
1289
diff
changeset
|
789 int av_get_frame_filename(char *buf, int buf_size, |
185190bdc185
Clarified API for numbered sequences, patch by Michel Bardiaux % mbardiaux A mediaxim P be %
gpoirier
parents:
1289
diff
changeset
|
790 const char *path, int number); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
791 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
792 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
793 * Check whether filename actually is a numbered sequence generator. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
794 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
795 * @param filename possible numbered sequence string |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
796 * @return 1 if a valid numbered sequence string, 0 otherwise. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
797 */ |
1291
185190bdc185
Clarified API for numbered sequences, patch by Michel Bardiaux % mbardiaux A mediaxim P be %
gpoirier
parents:
1289
diff
changeset
|
798 int av_filename_number_test(const char *filename); |
0 | 799 |
800 /* grab specific */ | |
801 int video_grab_init(void); | |
802 int audio_init(void); | |
803 | |
29 | 804 /* DV1394 */ |
805 int dv1394_init(void); | |
571 | 806 int dc1394_init(void); |
0 | 807 |
808 #ifdef HAVE_AV_CONFIG_H | |
230
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
809 |
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
810 #include "os_support.h" |
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
811 |
0 | 812 int strstart(const char *str, const char *val, const char **ptr); |
813 int stristart(const char *str, const char *val, const char **ptr); | |
814 void pstrcpy(char *buf, int buf_size, const char *str); | |
815 char *pstrcat(char *buf, int buf_size, const char *s); | |
816 | |
151 | 817 void __dynarray_add(unsigned long **tab_ptr, int *nb_ptr, unsigned long elem); |
818 | |
255 | 819 #ifdef __GNUC__ |
151 | 820 #define dynarray_add(tab, nb_ptr, elem)\ |
821 do {\ | |
822 typeof(tab) _tab = (tab);\ | |
823 typeof(elem) _elem = (elem);\ | |
824 (void)sizeof(**_tab == _elem); /* check that types are compatible */\ | |
825 __dynarray_add((unsigned long **)_tab, nb_ptr, (unsigned long)_elem);\ | |
826 } while(0) | |
255 | 827 #else |
828 #define dynarray_add(tab, nb_ptr, elem)\ | |
829 do {\ | |
830 __dynarray_add((unsigned long **)(tab), nb_ptr, (unsigned long)(elem));\ | |
831 } while(0) | |
832 #endif | |
151 | 833 |
230
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
834 time_t mktimegm(struct tm *tm); |
515
ad72189eec07
* replacing calls to not-always-available gmtime_r with our own code.
romansh
parents:
511
diff
changeset
|
835 struct tm *brktimegm(time_t secs, struct tm *tm); |
885 | 836 const char *small_strptime(const char *p, const char *fmt, |
230
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
837 struct tm *dt); |
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
838 |
0 | 839 struct in_addr; |
840 int resolve_host(struct in_addr *sin_addr, const char *hostname); | |
841 | |
842 void url_split(char *proto, int proto_size, | |
511
056991ab9f10
HTTP Authentication Patch by (Petr Doubek <doubek at vision dot ee dot ethz dot ch>)
michael
parents:
497
diff
changeset
|
843 char *authorization, int authorization_size, |
0 | 844 char *hostname, int hostname_size, |
845 int *port_ptr, | |
846 char *path, int path_size, | |
847 const char *url); | |
848 | |
849 int match_ext(const char *filename, const char *extensions); | |
850 | |
851 #endif /* HAVE_AV_CONFIG_H */ | |
852 | |
39 | 853 #ifdef __cplusplus |
854 } | |
855 #endif | |
856 | |
0 | 857 #endif /* AVFORMAT_H */ |
708 | 858 |