Mercurial > libavformat.hg
annotate avformat.h @ 3901:f936c4b8b96d libavformat
Give register_dynamic_payload_handler() in rtpdec.c a ff_ prefix and export
it so that I can use it in rdt.c as well. See discussion in "Realmedia patch"
thread on ML.
author | rbultje |
---|---|
date | Sun, 07 Sep 2008 01:19:26 +0000 |
parents | 4703ed97ea9d |
children | 4b8eb4f03ac5 |
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 |
3852 | 21 #ifndef AVFORMAT_AVFORMAT_H |
22 #define AVFORMAT_AVFORMAT_H | |
0 | 23 |
3087 | 24 #define LIBAVFORMAT_VERSION_MAJOR 52 |
3879 | 25 #define LIBAVFORMAT_VERSION_MINOR 22 |
3900
4703ed97ea9d
bump lavf micro version to allow checking for the matroska/ASS bugfix in r15211
aurel
parents:
3880
diff
changeset
|
26 #define LIBAVFORMAT_VERSION_MICRO 1 |
3054 | 27 |
3087 | 28 #define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \ |
29 LIBAVFORMAT_VERSION_MINOR, \ | |
30 LIBAVFORMAT_VERSION_MICRO) | |
31 #define LIBAVFORMAT_VERSION AV_VERSION(LIBAVFORMAT_VERSION_MAJOR, \ | |
32 LIBAVFORMAT_VERSION_MINOR, \ | |
33 LIBAVFORMAT_VERSION_MICRO) | |
829 | 34 #define LIBAVFORMAT_BUILD LIBAVFORMAT_VERSION_INT |
218 | 35 |
829 | 36 #define LIBAVFORMAT_IDENT "Lavf" AV_STRINGIFY(LIBAVFORMAT_VERSION) |
0 | 37 |
3701 | 38 /** |
39 * Returns the LIBAVFORMAT_VERSION_INT constant. | |
40 */ | |
41 unsigned avformat_version(void); | |
42 | |
230
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
43 #include <time.h> |
314 | 44 #include <stdio.h> /* FILE */ |
3065 | 45 #include "libavcodec/avcodec.h" |
0 | 46 |
47 #include "avio.h" | |
48 | |
49 /* packet functions */ | |
50 | |
51 typedef struct AVPacket { | |
3333 | 52 /** |
53 * Presentation time stamp in time_base units. | |
54 * This is the time at which the decompressed packet will be presented | |
55 * to the user. | |
56 * Can be AV_NOPTS_VALUE if it is not stored in the file. | |
57 * pts MUST be larger or equal to dts as presentation can not happen before | |
58 * decompression, unless one wants to view hex dumps. Some formats misuse | |
59 * the terms dts and pts/cts to mean something different, these timestamps | |
60 * must be converted to true pts/dts before they are stored in AVPacket. | |
61 */ | |
62 int64_t pts; | |
63 /** | |
64 * Decompression time stamp in time_base units. | |
65 * This is the time at which the packet is decompressed. | |
66 * Can be AV_NOPTS_VALUE if it is not stored in the file. | |
67 */ | |
68 int64_t dts; | |
65 | 69 uint8_t *data; |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
70 int size; |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
71 int stream_index; |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
72 int flags; |
3878
ed2a8a769982
Try to clarify the semantics of AVPacket.duration.
michael
parents:
3852
diff
changeset
|
73 /** |
ed2a8a769982
Try to clarify the semantics of AVPacket.duration.
michael
parents:
3852
diff
changeset
|
74 * Duration of this packet in time_base units, 0 if unknown. |
ed2a8a769982
Try to clarify the semantics of AVPacket.duration.
michael
parents:
3852
diff
changeset
|
75 * Equals next_pts - this_pts in presentation order. |
ed2a8a769982
Try to clarify the semantics of AVPacket.duration.
michael
parents:
3852
diff
changeset
|
76 */ |
ed2a8a769982
Try to clarify the semantics of AVPacket.duration.
michael
parents:
3852
diff
changeset
|
77 int duration; |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
78 void (*destruct)(struct AVPacket *); |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
79 void *priv; |
775 | 80 int64_t pos; ///< byte position in stream, -1 if unknown |
3879 | 81 |
82 /** | |
83 * This is the time difference in stream timebase units from the pts at which | |
84 * the output from the decoder has converged independent from the availability | |
85 * of previous frames (that is the frames are virtually identical no matter | |
86 * if decoding started from the very first frame or from this keyframe). | |
87 * is AV_NOPTS_VALUE if unknown. | |
88 * | |
89 * The purpose of this field is to allow seeking in streams that have no | |
90 * keyframes in the conventional sense. It corresponds to the | |
91 * recovery point SEI in H.264 and match_time_delta in nut. It also is | |
92 * essential for some types of subtitle streams to ensure that all | |
93 * subtitles are correctly displayed after seeking. | |
94 */ | |
95 int64_t convergence_duration; | |
885 | 96 } AVPacket; |
0 | 97 #define PKT_FLAG_KEY 0x0001 |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
98 |
535 | 99 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
|
100 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
101 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
102 * Default packet destructor. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
103 */ |
797
f5a231a9a2f1
support changing in bitstream global headers into extradata style and back
michael
parents:
795
diff
changeset
|
104 void av_destruct_packet(AVPacket *pkt); |
535 | 105 |
2140 | 106 /** |
107 * Initialize optional fields of a packet to default values. | |
108 * | |
109 * @param pkt packet | |
110 */ | |
2139 | 111 void av_init_packet(AVPacket *pkt); |
0 | 112 |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
113 /** |
2148 | 114 * Allocate the payload of a packet and initialize its fields to default values. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
115 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
116 * @param pkt packet |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
117 * @param size wanted payload size |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
118 * @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
|
119 */ |
0 | 120 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
|
121 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
122 /** |
2148 | 123 * Allocate and read the payload of a packet and initialize its fields to default values. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
124 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
125 * @param pkt packet |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
126 * @param size wanted payload size |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
127 * @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
|
128 */ |
775 | 129 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
|
130 |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
131 /** |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
132 * @warning This is a hack - the packet memory allocation stuff is broken. The |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
133 * packet is allocated if it was not really allocated |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
134 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
135 int av_dup_packet(AVPacket *pkt); |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
136 |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
137 /** |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
138 * Free a packet |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
139 * |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
140 * @param pkt packet to free |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
141 */ |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
142 static inline void av_free_packet(AVPacket *pkt) |
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
143 { |
163
470456bd0065
av_free_packet SEGV fix by (Arthur van Hoff (javanator))
michaelni
parents:
159
diff
changeset
|
144 if (pkt && pkt->destruct) { |
887 | 145 pkt->destruct(pkt); |
163
470456bd0065
av_free_packet SEGV fix by (Arthur van Hoff (javanator))
michaelni
parents:
159
diff
changeset
|
146 } |
53
fb671d87824e
zero copy packet handling for DV1394 by Max Krasnyansky
bellard
parents:
52
diff
changeset
|
147 } |
0 | 148 |
149 /*************************************************/ | |
150 /* fractional numbers for exact pts handling */ | |
151 | |
2065
64bd1b09cef2
patch so that the deprecated items show up correctly
benoit
parents:
2061
diff
changeset
|
152 /** |
64bd1b09cef2
patch so that the deprecated items show up correctly
benoit
parents:
2061
diff
changeset
|
153 * the exact value of the fractional number is: 'val + num / den'. |
64bd1b09cef2
patch so that the deprecated items show up correctly
benoit
parents:
2061
diff
changeset
|
154 * num is assumed to be such as 0 <= num < den |
64bd1b09cef2
patch so that the deprecated items show up correctly
benoit
parents:
2061
diff
changeset
|
155 * @deprecated Use AVRational instead |
64bd1b09cef2
patch so that the deprecated items show up correctly
benoit
parents:
2061
diff
changeset
|
156 */ |
0 | 157 typedef struct AVFrac { |
885 | 158 int64_t val, num, den; |
1258 | 159 } AVFrac attribute_deprecated; |
0 | 160 |
161 /*************************************************/ | |
162 /* input/output formats */ | |
163 | |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
164 struct AVCodecTag; |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
165 |
0 | 166 struct AVFormatContext; |
167 | |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
168 /** this structure contains the data a format has to probe a file */ |
0 | 169 typedef struct AVProbeData { |
64 | 170 const char *filename; |
0 | 171 unsigned char *buf; |
172 int buf_size; | |
173 } AVProbeData; | |
174 | |
1304 | 175 #define AVPROBE_SCORE_MAX 100 ///< max score, half of that is used for file extension based detection |
2001
1a3c9056982a
allocate 32 extra bytes at the end of the probe buffer and remove most probe buf_size checks
michael
parents:
1986
diff
changeset
|
176 #define AVPROBE_PADDING_SIZE 32 ///< extra allocated bytes at the end of the probe buffer |
0 | 177 |
178 typedef struct AVFormatParameters { | |
743 | 179 AVRational time_base; |
0 | 180 int sample_rate; |
181 int channels; | |
182 int width; | |
183 int height; | |
184 enum PixelFormat pix_fmt; | |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
185 int channel; /**< used to select dv channel */ |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
186 const char *standard; /**< tv standard, NTSC, PAL, SECAM */ |
3553
c3b9334f46ae
One-bit bitfields should probably be unsigned. Unfortunately, it is left
takis
parents:
3445
diff
changeset
|
187 unsigned int mpeg2ts_raw:1; /**< force raw MPEG2 transport stream output, if possible */ |
c3b9334f46ae
One-bit bitfields should probably be unsigned. Unfortunately, it is left
takis
parents:
3445
diff
changeset
|
188 unsigned int mpeg2ts_compute_pcr:1; /**< compute exact PCR for each transport |
c3b9334f46ae
One-bit bitfields should probably be unsigned. Unfortunately, it is left
takis
parents:
3445
diff
changeset
|
189 stream packet (only meaningful if |
c3b9334f46ae
One-bit bitfields should probably be unsigned. Unfortunately, it is left
takis
parents:
3445
diff
changeset
|
190 mpeg2ts_raw is TRUE) */ |
c3b9334f46ae
One-bit bitfields should probably be unsigned. Unfortunately, it is left
takis
parents:
3445
diff
changeset
|
191 unsigned int initial_pause:1; /**< do not begin to play the stream |
c3b9334f46ae
One-bit bitfields should probably be unsigned. Unfortunately, it is left
takis
parents:
3445
diff
changeset
|
192 immediately (RTSP only) */ |
c3b9334f46ae
One-bit bitfields should probably be unsigned. Unfortunately, it is left
takis
parents:
3445
diff
changeset
|
193 unsigned int prealloced_context:1; |
2833
578a0c783eae
Remove *_codec_id from AVFormatParameters with the next major version bump.
michael
parents:
2832
diff
changeset
|
194 #if LIBAVFORMAT_VERSION_INT < (53<<16) |
583 | 195 enum CodecID video_codec_id; |
196 enum CodecID audio_codec_id; | |
2833
578a0c783eae
Remove *_codec_id from AVFormatParameters with the next major version bump.
michael
parents:
2832
diff
changeset
|
197 #endif |
0 | 198 } AVFormatParameters; |
199 | |
1675 | 200 //! demuxer will use url_fopen, no opened file should be provided by the caller |
201 #define AVFMT_NOFILE 0x0001 | |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
202 #define AVFMT_NEEDNUMBER 0x0002 /**< needs '%d' in filename */ |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
203 #define AVFMT_SHOW_IDS 0x0008 /**< show format stream IDs numbers */ |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
204 #define AVFMT_RAWPICTURE 0x0020 /**< format wants AVPicture structure for |
0 | 205 raw picture data */ |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
206 #define AVFMT_GLOBALHEADER 0x0040 /**< format wants global header */ |
2164 | 207 #define AVFMT_NOTIMESTAMPS 0x0080 /**< format does not need / have any timestamps */ |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
208 #define AVFMT_GENERIC_INDEX 0x0100 /**< use generic index building code */ |
3724
178cc6f9d5ec
Add flag to mark demuxers that can output discontinuous timestamps.
michael
parents:
3711
diff
changeset
|
209 #define AVFMT_TS_DISCONT 0x0200 /**< format allows timestamo discontinuities */ |
0 | 210 |
211 typedef struct AVOutputFormat { | |
212 const char *name; | |
3424
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
213 /** |
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
214 * Descriptive name for the format, meant to be more human-readable |
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
215 * than \p name. You \e should use the NULL_IF_CONFIG_SMALL() macro |
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
216 * to define it. |
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
217 */ |
0 | 218 const char *long_name; |
219 const char *mime_type; | |
1879 | 220 const char *extensions; /**< comma separated filename extensions */ |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
221 /** size of private data so that it can be allocated in the wrapper */ |
0 | 222 int priv_data_size; |
223 /* output support */ | |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
224 enum CodecID audio_codec; /**< default audio codec */ |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
225 enum CodecID video_codec; /**< default video codec */ |
0 | 226 int (*write_header)(struct AVFormatContext *); |
468 | 227 int (*write_packet)(struct AVFormatContext *, AVPacket *pkt); |
0 | 228 int (*write_trailer)(struct AVFormatContext *); |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
229 /** can use flags: AVFMT_NOFILE, AVFMT_NEEDNUMBER, AVFMT_GLOBALHEADER */ |
0 | 230 int flags; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
231 /** currently only used to set pixel format if not YUV420P */ |
17
e1200dd82537
added simple still image format support to simplify image and imagepipe video formats
bellard
parents:
5
diff
changeset
|
232 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
|
233 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
|
234 |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
235 /** |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
236 * 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
|
237 * the arrays are all CODEC_ID_NONE terminated |
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
238 */ |
3766
f062deeedb8d
Change codec_tag type from const struct AVCodecTag ** to const struct AVCodecTag * const *
reimar
parents:
3758
diff
changeset
|
239 const struct AVCodecTag * const *codec_tag; |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
240 |
2280
69270eb6b20c
add proper support for subtitles muxing/stream copying
aurel
parents:
2241
diff
changeset
|
241 enum CodecID subtitle_codec; /**< default subtitle codec */ |
69270eb6b20c
add proper support for subtitles muxing/stream copying
aurel
parents:
2241
diff
changeset
|
242 |
0 | 243 /* private fields */ |
244 struct AVOutputFormat *next; | |
245 } AVOutputFormat; | |
246 | |
247 typedef struct AVInputFormat { | |
248 const char *name; | |
3424
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
249 /** |
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
250 * Descriptive name for the format, meant to be more human-readable |
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
251 * than \p name. You \e should use the NULL_IF_CONFIG_SMALL() macro |
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
252 * to define it. |
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3334
diff
changeset
|
253 */ |
0 | 254 const char *long_name; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
255 /** size of private data so that it can be allocated in the wrapper */ |
0 | 256 int priv_data_size; |
2367
43a4290a6d77
mention AVPROBE_PADDING_SIZE at the read_probe() doxy
michael
parents:
2317
diff
changeset
|
257 /** |
2815 | 258 * Tell if a given file has a chance of being parsed by this format. |
259 * The buffer provided is guaranteed to be AVPROBE_PADDING_SIZE bytes | |
260 * big so you do not have to check for that unless you need more. | |
2367
43a4290a6d77
mention AVPROBE_PADDING_SIZE at the read_probe() doxy
michael
parents:
2317
diff
changeset
|
261 */ |
0 | 262 int (*read_probe)(AVProbeData *); |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
263 /** read the format header and initialize the AVFormatContext |
0 | 264 structure. Return 0 if OK. 'ap' if non NULL contains |
1986 | 265 additional paramters. Only used in raw format right |
0 | 266 now. 'av_new_stream' should be called to create new streams. */ |
267 int (*read_header)(struct AVFormatContext *, | |
268 AVFormatParameters *ap); | |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
269 /** read one packet and put it in 'pkt'. pts and flags are also |
0 | 270 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
|
271 AVFMTCTX_NOHEADER is used. */ |
0 | 272 int (*read_packet)(struct AVFormatContext *, AVPacket *pkt); |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
273 /** close the stream. The AVFormatContext and AVStreams are not |
0 | 274 freed by this function */ |
275 int (*read_close)(struct AVFormatContext *); | |
885 | 276 /** |
277 * seek to a given timestamp relative to the frames in | |
555 | 278 * stream component stream_index |
279 * @param stream_index must not be -1 | |
885 | 280 * @param flags selects which direction should be preferred if no exact |
555 | 281 * match is available |
2203
a81bd08b5ff2
* clarifying the AVInputFormat::read_seek return value
romansh
parents:
2190
diff
changeset
|
282 * @return >= 0 on success (but not necessarily the new offset) |
555 | 283 */ |
885 | 284 int (*read_seek)(struct AVFormatContext *, |
555 | 285 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
|
286 /** |
2876
067baa2b8f38
Correct doxy about timestamp units of read_timestamp().
michael
parents:
2875
diff
changeset
|
287 * gets the next timestamp in stream[stream_index].time_base units. |
3175 | 288 * @return the timestamp or AV_NOPTS_VALUE if an error occurred |
437
50bae308f71e
moving nearly identical binary search code from nut/mpeg/asf to utils.c
michael
parents:
420
diff
changeset
|
289 */ |
50bae308f71e
moving nearly identical binary search code from nut/mpeg/asf to utils.c
michael
parents:
420
diff
changeset
|
290 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
|
291 int64_t *pos, int64_t pos_limit); |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
292 /** can use flags: AVFMT_NOFILE, AVFMT_NEEDNUMBER */ |
0 | 293 int flags; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
294 /** if extensions are defined, then no probe is done. You should |
0 | 295 usually not use extension format guessing because it is not |
296 reliable enough */ | |
297 const char *extensions; | |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
298 /** general purpose read only value that the format can use */ |
0 | 299 int value; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
300 |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
301 /** start/resume playing - only meaningful if using a network based format |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
302 (RTSP) */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
303 int (*read_play)(struct AVFormatContext *); |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
304 |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
305 /** pause playing - only meaningful if using a network based format |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
306 (RTSP) */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
307 int (*read_pause)(struct AVFormatContext *); |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
308 |
3766
f062deeedb8d
Change codec_tag type from const struct AVCodecTag ** to const struct AVCodecTag * const *
reimar
parents:
3758
diff
changeset
|
309 const struct AVCodecTag * const *codec_tag; |
1677
2a85c82b8538
add codec_id <-> codec_tag tables to AVIn/OutputFormat
michael
parents:
1675
diff
changeset
|
310 |
0 | 311 /* private fields */ |
312 struct AVInputFormat *next; | |
313 } AVInputFormat; | |
314 | |
2023 | 315 enum AVStreamParseType { |
316 AVSTREAM_PARSE_NONE, | |
317 AVSTREAM_PARSE_FULL, /**< full parsing and repack */ | |
318 AVSTREAM_PARSE_HEADERS, /**< only parse headers, don't repack */ | |
319 AVSTREAM_PARSE_TIMESTAMPS, /**< full parsing and interpolation of timestamps for frames not starting on packet boundary */ | |
320 }; | |
321 | |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
322 typedef struct AVIndexEntry { |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
323 int64_t pos; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
324 int64_t timestamp; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
325 #define AVINDEX_KEYFRAME 0x0001 |
979 | 326 int flags:2; |
2165 | 327 int size:30; //Yeah, trying to keep the size of this small to reduce memory requirements (it is 24 vs 32 byte due to possible 8byte align). |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
328 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
|
329 } AVIndexEntry; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
330 |
3120
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
331 #define AV_DISPOSITION_DEFAULT 0x0001 |
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
332 #define AV_DISPOSITION_DUB 0x0002 |
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
333 #define AV_DISPOSITION_ORIGINAL 0x0004 |
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
334 #define AV_DISPOSITION_COMMENT 0x0008 |
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
335 #define AV_DISPOSITION_LYRICS 0x0010 |
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
336 #define AV_DISPOSITION_KARAOKE 0x0020 |
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
337 |
2846
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
338 /** |
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
339 * Stream structure. |
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
340 * New fields can be added to the end with minor version bumps. |
2851 | 341 * Removal, reordering and changes to existing fields require a major |
2846
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
342 * version bump. |
2851 | 343 * sizeof(AVStream) must not be used outside libav*. |
2846
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
344 */ |
0 | 345 typedef struct AVStream { |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
346 int index; /**< stream index in AVFormatContext */ |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
347 int id; /**< format specific stream id */ |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
348 AVCodecContext *codec; /**< codec context */ |
793 | 349 /** |
2851 | 350 * Real base frame rate of the stream. |
351 * This is the lowest frame rate with which all timestamps can be | |
2141 | 352 * represented accurately (it is the least common multiple of all |
2851 | 353 * frame rates in the stream), Note, this value is just a guess! |
354 * For example if the timebase is 1/90000 and all frames have either | |
355 * approximately 3600 or 1800 timer ticks then r_frame_rate will be 50/1. | |
793 | 356 */ |
357 AVRational r_frame_rate; | |
0 | 358 void *priv_data; |
2300
9c8cfadff191
correct initial timestamps which have AV_NOPTS_VALUE
michael
parents:
2284
diff
changeset
|
359 |
0 | 360 /* internal data used in av_find_stream_info() */ |
2300
9c8cfadff191
correct initial timestamps which have AV_NOPTS_VALUE
michael
parents:
2284
diff
changeset
|
361 int64_t first_dts; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
362 /** encoding: PTS generation when outputing stream */ |
2241 | 363 struct AVFrac pts; |
844
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
364 |
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
365 /** |
2851 | 366 * This is the fundamental unit of time (in seconds) in terms |
367 * of which frame timestamps are represented. For fixed-fps content, | |
368 * timebase should be 1/frame rate and timestamp increments should be | |
844
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
369 * identically 1. |
35e372e6a6c3
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
842
diff
changeset
|
370 */ |
462
b69898ffc92a
move time_base (pts_num/pts_den) from AVFormatContext -> AVStream
michael
parents:
437
diff
changeset
|
371 AVRational time_base; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
372 int pts_wrap_bits; /**< number of bits in pts (used for wrapping control) */ |
0 | 373 /* ffmpeg.c private use */ |
1878 | 374 int stream_copy; /**< if set, just copy stream */ |
2164 | 375 enum AVDiscard discard; ///< selects which packets can be discarded at will and do not need to be demuxed |
650 | 376 //FIXME move stuff to a flags field? |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
377 /** quality, as it has been removed from AVCodecContext and put in AVVideoFrame |
2164 | 378 * MN: dunno if that is the right place for it */ |
885 | 379 float quality; |
2386
2beaa59babad
elaborate a little on AVStream.start_time, it seems the comment is not clear
michael
parents:
2374
diff
changeset
|
380 /** |
2851 | 381 * Decoding: pts of the first frame of the stream, in stream time base. |
382 * Only set this if you are absolutely 100% sure that the value you set | |
383 * it to really is the pts of the first frame. | |
2396
28f19eb568a2
mention that start_time maybe AV_NOPTS_VALUE (from patch by neilb suse de)
michael
parents:
2386
diff
changeset
|
384 * This may be undefined (AV_NOPTS_VALUE). |
2851 | 385 * @note The ASF header does NOT contain a correct start_time the ASF |
386 * demuxer must NOT set this. | |
2386
2beaa59babad
elaborate a little on AVStream.start_time, it seems the comment is not clear
michael
parents:
2374
diff
changeset
|
387 */ |
885 | 388 int64_t start_time; |
2397
e5086ec7a4d4
more verbose doxy for duration (from patch by neilb suse de)
michael
parents:
2396
diff
changeset
|
389 /** |
2851 | 390 * Decoding: duration of the stream, in stream time base. |
2397
e5086ec7a4d4
more verbose doxy for duration (from patch by neilb suse de)
michael
parents:
2396
diff
changeset
|
391 * If a source file does not specify a duration, but does specify |
e5086ec7a4d4
more verbose doxy for duration (from patch by neilb suse de)
michael
parents:
2396
diff
changeset
|
392 * a bitrate, this value will be estimates from bit rate and file size. |
e5086ec7a4d4
more verbose doxy for duration (from patch by neilb suse de)
michael
parents:
2396
diff
changeset
|
393 */ |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
394 int64_t duration; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
395 |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
396 char language[4]; /** ISO 639 3-letter language code (empty string if undefined) */ |
784 | 397 |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
398 /* av_read_frame() support */ |
2023 | 399 enum AVStreamParseType need_parsing; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
400 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
|
401 |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
402 int64_t cur_dts; |
3058 | 403 int last_IP_duration; |
404 int64_t last_IP_pts; | |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
405 /* av_seek_frame() support */ |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
406 AVIndexEntry *index_entries; /**< only used if the format does not |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
407 support seeking natively */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
408 int nb_index_entries; |
1332 | 409 unsigned int index_entries_allocated_size; |
885 | 410 |
793 | 411 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
|
412 |
3711
a2bdb3bfeb99
increase MAX_REORDER_DELAY and pts_buffer size to 16, max for h264 atm
bcoudurier
parents:
3701
diff
changeset
|
413 #if LIBAVFORMAT_VERSION_INT < (53<<16) |
a2bdb3bfeb99
increase MAX_REORDER_DELAY and pts_buffer size to 16, max for h264 atm
bcoudurier
parents:
3701
diff
changeset
|
414 int64_t unused[4+1]; |
a2bdb3bfeb99
increase MAX_REORDER_DELAY and pts_buffer size to 16, max for h264 atm
bcoudurier
parents:
3701
diff
changeset
|
415 #endif |
2973 | 416 |
417 char *filename; /**< source filename of the stream */ | |
3120
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
418 |
ea5623a8efde
Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents:
3087
diff
changeset
|
419 int disposition; /**< AV_DISPOSITION_* bitfield */ |
3568 | 420 |
421 AVProbeData probe_data; | |
3711
a2bdb3bfeb99
increase MAX_REORDER_DELAY and pts_buffer size to 16, max for h264 atm
bcoudurier
parents:
3701
diff
changeset
|
422 #define MAX_REORDER_DELAY 16 |
a2bdb3bfeb99
increase MAX_REORDER_DELAY and pts_buffer size to 16, max for h264 atm
bcoudurier
parents:
3701
diff
changeset
|
423 int64_t pts_buffer[MAX_REORDER_DELAY+1]; |
3758
e966560661e5
export sample_aspect_ratio read by the demuxer in a separate field
aurel
parents:
3724
diff
changeset
|
424 |
e966560661e5
export sample_aspect_ratio read by the demuxer in a separate field
aurel
parents:
3724
diff
changeset
|
425 /** |
e966560661e5
export sample_aspect_ratio read by the demuxer in a separate field
aurel
parents:
3724
diff
changeset
|
426 * sample aspect ratio (0 if unknown) |
e966560661e5
export sample_aspect_ratio read by the demuxer in a separate field
aurel
parents:
3724
diff
changeset
|
427 * - encoding: Set by user. |
e966560661e5
export sample_aspect_ratio read by the demuxer in a separate field
aurel
parents:
3724
diff
changeset
|
428 * - decoding: Set by libavformat. |
e966560661e5
export sample_aspect_ratio read by the demuxer in a separate field
aurel
parents:
3724
diff
changeset
|
429 */ |
e966560661e5
export sample_aspect_ratio read by the demuxer in a separate field
aurel
parents:
3724
diff
changeset
|
430 AVRational sample_aspect_ratio; |
0 | 431 } AVStream; |
432 | |
2573
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
433 #define AV_PROGRAM_RUNNING 1 |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
434 |
2846
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
435 /** |
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
436 * New fields can be added to the end with minor version bumps. |
2851 | 437 * Removal, reordering and changes to existing fields require a major |
2846
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
438 * version bump. |
2851 | 439 * sizeof(AVProgram) must not be used outside libav*. |
2846
625c2c60f585
Document a few more structure change rules with relation to ABI/API.
michael
parents:
2844
diff
changeset
|
440 */ |
2573
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
441 typedef struct AVProgram { |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
442 int id; |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
443 char *provider_name; ///< Network name for DVB streams |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
444 char *name; ///< Service name for DVB streams |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
445 int flags; |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
446 enum AVDiscard discard; ///< selects which program to discard and which to feed to the caller |
2650
4e3d38c8896c
API extension: AVProgram now has an array (stream_index) containing the indexes of the streams in AVFormatContext
nicodvb
parents:
2620
diff
changeset
|
447 unsigned int *stream_index; |
4e3d38c8896c
API extension: AVProgram now has an array (stream_index) containing the indexes of the streams in AVFormatContext
nicodvb
parents:
2620
diff
changeset
|
448 unsigned int nb_stream_indexes; |
2573
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
449 } AVProgram; |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
450 |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
451 #define AVFMTCTX_NOHEADER 0x0001 /**< signal that no header is present |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
452 (streams are added dynamically) */ |
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
453 |
3314 | 454 typedef struct AVChapter { |
3320 | 455 int id; ///< Unique id to identify the chapter |
456 AVRational time_base; ///< Timebase in which the start/end timestamps are specified | |
3322 | 457 int64_t start, end; ///< chapter start/end time in time_base units |
3321 | 458 char *title; ///< chapter title |
3314 | 459 } AVChapter; |
460 | |
0 | 461 #define MAX_STREAMS 20 |
462 | |
2844
440267faee3c
Document structure change rules with relation to ABI/API.
michael
parents:
2836
diff
changeset
|
463 /** |
440267faee3c
Document structure change rules with relation to ABI/API.
michael
parents:
2836
diff
changeset
|
464 * format I/O context. |
440267faee3c
Document structure change rules with relation to ABI/API.
michael
parents:
2836
diff
changeset
|
465 * New fields can be added to the end with minor version bumps. |
2851 | 466 * Removal, reordering and changes to existing fields require a major |
2844
440267faee3c
Document structure change rules with relation to ABI/API.
michael
parents:
2836
diff
changeset
|
467 * version bump. |
2851 | 468 * sizeof(AVFormatContext) must not be used outside libav*. |
2844
440267faee3c
Document structure change rules with relation to ABI/API.
michael
parents:
2836
diff
changeset
|
469 */ |
0 | 470 typedef struct AVFormatContext { |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
471 const AVClass *av_class; /**< set by av_alloc_format_context */ |
0 | 472 /* can only be iformat or oformat, not both at the same time */ |
473 struct AVInputFormat *iformat; | |
474 struct AVOutputFormat *oformat; | |
475 void *priv_data; | |
2771
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2749
diff
changeset
|
476 ByteIOContext *pb; |
1663 | 477 unsigned int nb_streams; |
0 | 478 AVStream *streams[MAX_STREAMS]; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
479 char filename[1024]; /**< input or output filename */ |
0 | 480 /* stream info */ |
420
e440fb884442
* making it possible to specify recording date and time in a stream
romansh
parents:
384
diff
changeset
|
481 int64_t timestamp; |
0 | 482 char title[512]; |
483 char author[512]; | |
484 char copyright[512]; | |
485 char comment[512]; | |
234 | 486 char album[512]; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
487 int year; /**< ID3 year, 0 if none */ |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
488 int track; /**< track number, 0 if none */ |
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
489 char genre[32]; /**< ID3 genre */ |
234 | 490 |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
491 int ctx_flags; /**< format specific flags, see AVFMTCTX_xx */ |
0 | 492 /* private data for pts handling (do not modify directly) */ |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
493 /** This buffer is only needed when packets were already buffered but |
0 | 494 not decoded, for example to get the codec parameters in mpeg |
495 streams */ | |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
496 struct AVPacketList *packet_buffer; |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
497 |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
498 /** decoding: position of the first frame of the component, in |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
499 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
|
500 it is deduced from the AVStream values. */ |
885 | 501 int64_t start_time; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
502 /** decoding: duration of the stream, in AV_TIME_BASE fractional |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
503 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
|
504 AVStream values. */ |
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
505 int64_t duration; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
506 /** decoding: total file size. 0 if unknown */ |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
507 int64_t file_size; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
508 /** decoding: total stream bitrate in bit/s, 0 if not |
186
2265d21a04c8
added stream start time and duration API - AV_NOPTS_VALUE is no longer zero
bellard
parents:
184
diff
changeset
|
509 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
|
510 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
|
511 int bit_rate; |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
512 |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
513 /* av_read_frame() support */ |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
514 AVStream *cur_st; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
515 const uint8_t *cur_ptr; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
516 int cur_len; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
517 AVPacket cur_pkt; |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
518 |
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
519 /* av_seek_frame() support */ |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
520 int64_t data_offset; /** offset of the first packet */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
521 int index_built; |
885 | 522 |
551 | 523 int mux_rate; |
524 int packet_size; | |
566 | 525 int preload; |
526 int max_delay; | |
790
80aec794c2ed
Animated GIF looping patch by (Todd Kirby // ffmpeg.php gmail com)
michael
parents:
784
diff
changeset
|
527 |
885 | 528 #define AVFMT_NOOUTPUTLOOP -1 |
529 #define AVFMT_INFINITEOUTPUTLOOP 0 | |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
530 /** number of times to loop output in formats that support it */ |
790
80aec794c2ed
Animated GIF looping patch by (Todd Kirby // ffmpeg.php gmail com)
michael
parents:
784
diff
changeset
|
531 int loop_output; |
885 | 532 |
841
ba7631ba33a7
support fixing missing pts by parsing future frames
michael
parents:
829
diff
changeset
|
533 int flags; |
ba7631ba33a7
support fixing missing pts by parsing future frames
michael
parents:
829
diff
changeset
|
534 #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
|
535 #define AVFMT_FLAG_IGNIDX 0x0002 ///< ignore index |
2220 | 536 #define AVFMT_FLAG_NONBLOCK 0x0004 ///< do not block when reading packets from input |
1175
8b53c0f3e7ad
add loop_input to AVFormatContext, getting rid of old hack
mru
parents:
1167
diff
changeset
|
537 |
8b53c0f3e7ad
add loop_input to AVFormatContext, getting rid of old hack
mru
parents:
1167
diff
changeset
|
538 int loop_input; |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
539 /** decoding: size of data to probe; encoding unused */ |
1279
a12e0b434174
added option probesize; at the moment only used by mpegts.c
nicodvb
parents:
1278
diff
changeset
|
540 unsigned int probesize; |
1720
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
541 |
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
542 /** |
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
543 * 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
|
544 */ |
1a8d1f66c867
make av_find_stream_info() duration user selectable
michael
parents:
1679
diff
changeset
|
545 int max_analyze_duration; |
1778
d8c6b719a070
add key field to AVFormatContext for de/encryption support, patch by Reimar
bcoudurier
parents:
1756
diff
changeset
|
546 |
d8c6b719a070
add key field to AVFormatContext for de/encryption support, patch by Reimar
bcoudurier
parents:
1756
diff
changeset
|
547 const uint8_t *key; |
d8c6b719a070
add key field to AVFormatContext for de/encryption support, patch by Reimar
bcoudurier
parents:
1756
diff
changeset
|
548 int keylen; |
2573
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
549 |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
550 unsigned int nb_programs; |
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
551 AVProgram **programs; |
2832 | 552 |
553 /** | |
554 * Forced video codec_id. | |
555 * demuxing: set by user | |
556 */ | |
557 enum CodecID video_codec_id; | |
558 /** | |
559 * Forced audio codec_id. | |
560 * demuxing: set by user | |
561 */ | |
562 enum CodecID audio_codec_id; | |
563 /** | |
564 * Forced subtitle codec_id. | |
565 * demuxing: set by user | |
566 */ | |
567 enum CodecID subtitle_codec_id; | |
2932
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
568 |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
569 /** |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
570 * Maximum amount of memory in bytes to use per stream for the index. |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
571 * If the needed index exceeds this size entries will be discarded as |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
572 * needed to maintain a smaller size. This can lead to slower or less |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
573 * accurate seeking (depends on demuxer). |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
574 * Demuxers for which a full in memory index is mandatory will ignore |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
575 * this. |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
576 * muxing : unused |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
577 * demuxing: set by user |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
578 */ |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
579 unsigned int max_index_size; |
3128
b5e2ce291882
Introduce max_picture_buffer variable in AVFormatContext,
ramiro
parents:
3120
diff
changeset
|
580 |
b5e2ce291882
Introduce max_picture_buffer variable in AVFormatContext,
ramiro
parents:
3120
diff
changeset
|
581 /** |
3129 | 582 * Maximum amount of memory in bytes to use for buffering frames |
3128
b5e2ce291882
Introduce max_picture_buffer variable in AVFormatContext,
ramiro
parents:
3120
diff
changeset
|
583 * obtained from real-time capture devices. |
b5e2ce291882
Introduce max_picture_buffer variable in AVFormatContext,
ramiro
parents:
3120
diff
changeset
|
584 */ |
b5e2ce291882
Introduce max_picture_buffer variable in AVFormatContext,
ramiro
parents:
3120
diff
changeset
|
585 unsigned int max_picture_buffer; |
3314 | 586 |
3329 | 587 unsigned int nb_chapters; |
3314 | 588 AVChapter **chapters; |
3445 | 589 |
590 /** | |
591 * Flags to enable debuging. | |
592 */ | |
593 int debug; | |
594 #define FF_FDEBUG_TS 0x0001 | |
3568 | 595 |
596 /** | |
597 * raw packets from the demuxer, prior to parsing and decoding. | |
598 * This buffer is used for buffering packets until the codec can | |
599 * be identified, as parsing cannot be done without knowing the | |
600 * codec. | |
601 */ | |
602 struct AVPacketList *raw_packet_buffer; | |
3698
b7e347127897
Maintain pointer to end of AVFormatContext.packet_buffer list
mru
parents:
3617
diff
changeset
|
603 struct AVPacketList *raw_packet_buffer_end; |
b7e347127897
Maintain pointer to end of AVFormatContext.packet_buffer list
mru
parents:
3617
diff
changeset
|
604 |
b7e347127897
Maintain pointer to end of AVFormatContext.packet_buffer list
mru
parents:
3617
diff
changeset
|
605 struct AVPacketList *packet_buffer_end; |
0 | 606 } AVFormatContext; |
607 | |
608 typedef struct AVPacketList { | |
609 AVPacket pkt; | |
610 struct AVPacketList *next; | |
611 } AVPacketList; | |
612 | |
2812 | 613 #if LIBAVFORMAT_VERSION_INT < (53<<16) |
0 | 614 extern AVInputFormat *first_iformat; |
615 extern AVOutputFormat *first_oformat; | |
2812 | 616 #endif |
617 | |
618 AVInputFormat *av_iformat_next(AVInputFormat *f); | |
619 AVOutputFormat *av_oformat_next(AVOutputFormat *f); | |
0 | 620 |
583 | 621 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
|
622 |
0 | 623 /* XXX: use automatic init with either ELF sections or C file parser */ |
624 /* modules */ | |
625 | |
626 /* utils.c */ | |
627 void av_register_input_format(AVInputFormat *format); | |
628 void av_register_output_format(AVOutputFormat *format); | |
885 | 629 AVOutputFormat *guess_stream_format(const char *short_name, |
0 | 630 const char *filename, const char *mime_type); |
885 | 631 AVOutputFormat *guess_format(const char *short_name, |
0 | 632 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
|
633 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
634 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
635 * 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
|
636 */ |
885 | 637 enum CodecID av_guess_codec(AVOutputFormat *fmt, const char *short_name, |
583 | 638 const char *filename, const char *mime_type, enum CodecType type); |
0 | 639 |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
640 /** |
1908
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
641 * Send a nice hexadecimal dump of a buffer to the specified file stream. |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
642 * |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
643 * @param f The file stream pointer where the dump should be sent to. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
644 * @param buf buffer |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
645 * @param size buffer size |
1908
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
646 * |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
647 * @see av_hex_dump_log, av_pkt_dump, av_pkt_dump_log |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
648 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
649 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
|
650 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
651 /** |
1908
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
652 * Send a nice hexadecimal dump of a buffer to the log. |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
653 * |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
654 * @param avcl A pointer to an arbitrary struct of which the first field is a |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
655 * pointer to an AVClass struct. |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
656 * @param level The importance level of the message, lower values signifying |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
657 * higher importance. |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
658 * @param buf buffer |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
659 * @param size buffer size |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
660 * |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
661 * @see av_hex_dump, av_pkt_dump, av_pkt_dump_log |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
662 */ |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
663 void av_hex_dump_log(void *avcl, int level, uint8_t *buf, int size); |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
664 |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
665 /** |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
666 * Send a nice dump of a packet to the specified file stream. |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
667 * |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
668 * @param f The file stream pointer where the dump should be sent to. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
669 * @param pkt packet to dump |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
670 * @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
|
671 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
672 void av_pkt_dump(FILE *f, AVPacket *pkt, int dump_payload); |
0 | 673 |
1908
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
674 /** |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
675 * Send a nice dump of a packet to the log. |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
676 * |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
677 * @param avcl A pointer to an arbitrary struct of which the first field is a |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
678 * pointer to an AVClass struct. |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
679 * @param level The importance level of the message, lower values signifying |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
680 * higher importance. |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
681 * @param pkt packet to dump |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
682 * @param dump_payload true if the payload must be displayed too |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
683 */ |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
684 void av_pkt_dump_log(void *avcl, int level, AVPacket *pkt, int dump_payload); |
174083eafc6c
Introduce two new logging functions av_hex_dump_log() and av_pkt_dump_log()
takis
parents:
1906
diff
changeset
|
685 |
0 | 686 void av_register_all(void); |
687 | |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
688 /** codec tag <-> codec id */ |
1679 | 689 enum CodecID av_codec_get_id(const struct AVCodecTag **tags, unsigned int tag); |
690 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
|
691 |
0 | 692 /* media file input */ |
1840
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 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
695 * 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
|
696 */ |
0 | 697 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
|
698 |
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 * Guess file format. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
701 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
702 * @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
|
703 * 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
|
704 */ |
0 | 705 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
|
706 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
707 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
708 * 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
|
709 * 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
|
710 */ |
885 | 711 int av_open_input_stream(AVFormatContext **ic_ptr, |
712 ByteIOContext *pb, const char *filename, | |
293
62cec412a186
make AVFMT_NOHEADER flag dynamic - added av_open_input_stream()
bellard
parents:
274
diff
changeset
|
713 AVInputFormat *fmt, AVFormatParameters *ap); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
714 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
715 /** |
2141 | 716 * Open a media file as input. The codecs are not opened. Only the file |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
717 * header (if present) is read. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
718 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
719 * @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
|
720 * @param filename filename to open. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
721 * @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
|
722 * @param buf_size optional buffer size (zero if default is OK) |
1986 | 723 * @param ap additional parameters needed when opening the file (NULL if default) |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
724 * @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
|
725 */ |
885 | 726 int av_open_input_file(AVFormatContext **ic_ptr, const char *filename, |
0 | 727 AVInputFormat *fmt, |
728 int buf_size, | |
729 AVFormatParameters *ap); | |
2813
9d53cc092c55
document how to free the result of av_alloc_format_context()
michael
parents:
2812
diff
changeset
|
730 /** |
9d53cc092c55
document how to free the result of av_alloc_format_context()
michael
parents:
2812
diff
changeset
|
731 * Allocate an AVFormatContext. |
2815 | 732 * Can be freed with av_free() but do not forget to free everything you |
2813
9d53cc092c55
document how to free the result of av_alloc_format_context()
michael
parents:
2812
diff
changeset
|
733 * explicitly allocated as well! |
9d53cc092c55
document how to free the result of av_alloc_format_context()
michael
parents:
2812
diff
changeset
|
734 */ |
370
845f9de2c883
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
369
diff
changeset
|
735 AVFormatContext *av_alloc_format_context(void); |
0 | 736 |
1840
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 * 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
|
739 * 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
|
740 * 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
|
741 * frame mode. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
742 * 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
|
743 * 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
|
744 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
745 * @param ic media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
746 * @return >=0 if OK. AVERROR_xxx if error. |
2745 | 747 * @todo Let user decide somehow what information is needed so we do not waste time getting stuff the user does not need. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
748 */ |
0 | 749 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
|
750 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
751 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
752 * 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
|
753 * |
2141 | 754 * This function is obsolete and should never be used. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
755 * Use av_read_frame() instead. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
756 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
757 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
758 * @param pkt is filled |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
759 * @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
|
760 */ |
0 | 761 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
|
762 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
763 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
764 * 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
|
765 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
766 * The returned packet is valid |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
767 * 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
|
768 * 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
|
769 * 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
|
770 * 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
|
771 * 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
|
772 * then it contains one frame. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
773 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
774 * pkt->pts, pkt->dts and pkt->duration are always set to correct |
1844 | 775 * values in AVStream.timebase units (and guessed if the format cannot |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
776 * 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
|
777 * 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
|
778 * decompress the payload. |
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 * @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
|
781 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
782 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
|
783 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
784 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
785 * 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
|
786 * 'timestamp' in 'stream_index'. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
787 * @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
|
788 * 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
|
789 * 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
|
790 * @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
|
791 * 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
|
792 * @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
|
793 * @return >= 0 on success |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
794 */ |
555 | 795 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
|
796 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
797 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
798 * 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
|
799 * current position |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
800 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
801 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
|
802 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
803 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
804 * 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
|
805 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
806 * 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
|
807 */ |
303
2833c2311b66
initial av_read_frame() and av_seek_frame() support
bellard
parents:
293
diff
changeset
|
808 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
|
809 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
810 /** |
2835 | 811 * Free a AVFormatContext allocated by av_open_input_stream. |
812 * @param s context to free | |
813 */ | |
814 void av_close_input_stream(AVFormatContext *s); | |
815 | |
816 /** | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
817 * 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
|
818 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
819 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
820 */ |
0 | 821 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
|
822 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
823 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
824 * 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
|
825 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
826 * 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
|
827 * 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
|
828 * 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
|
829 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
830 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
831 * @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
|
832 */ |
0 | 833 AVStream *av_new_stream(AVFormatContext *s, int id); |
2573
2842354cb9a4
Added definition and utility functions to handle AVProgram(s) in AVFormatContext
nicodvb
parents:
2559
diff
changeset
|
834 AVProgram *av_new_program(AVFormatContext *s, int id); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
835 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
836 /** |
3314 | 837 * Add a new chapter. |
838 * This function is NOT part of the public API | |
839 * and should be ONLY used by demuxers. | |
840 * | |
841 * @param s media file handle | |
3323
4bf98e198eec
Add id to AVChapter, untested (where do i find matroska files with chapters?).
michael
parents:
3322
diff
changeset
|
842 * @param id unique id for this chapter |
3334
7a823a401282
Pass time_base as argument to new_chapter() as well.
michael
parents:
3333
diff
changeset
|
843 * @param start chapter start time in time_base units |
7a823a401282
Pass time_base as argument to new_chapter() as well.
michael
parents:
3333
diff
changeset
|
844 * @param end chapter end time in time_base units |
3314 | 845 * @param title chapter title |
3330
374e74567a4e
Make ff_new_chapter() return AVChapter instead of int so its consistant with
michael
parents:
3329
diff
changeset
|
846 * |
374e74567a4e
Make ff_new_chapter() return AVChapter instead of int so its consistant with
michael
parents:
3329
diff
changeset
|
847 * @return AVChapter or NULL if error. |
3314 | 848 */ |
3334
7a823a401282
Pass time_base as argument to new_chapter() as well.
michael
parents:
3333
diff
changeset
|
849 AVChapter *ff_new_chapter(AVFormatContext *s, int id, AVRational time_base, int64_t start, int64_t end, const char *title); |
3314 | 850 |
851 /** | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
852 * 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
|
853 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
854 * @param s stream |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
855 * @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
|
856 * (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
|
857 * @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
|
858 * @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
|
859 */ |
462
b69898ffc92a
move time_base (pts_num/pts_den) from AVFormatContext -> AVStream
michael
parents:
437
diff
changeset
|
860 void av_set_pts_info(AVStream *s, int pts_wrap_bits, |
0 | 861 int pts_num, int pts_den); |
862 | |
555 | 863 #define AVSEEK_FLAG_BACKWARD 1 ///< seek backward |
864 #define AVSEEK_FLAG_BYTE 2 ///< seeking based on position in bytes | |
698 | 865 #define AVSEEK_FLAG_ANY 4 ///< seek to any frame, even non keyframes |
555 | 866 |
346
e154eb1b7149
caching of timestamps for mpeg-ps so seeking is faster
michael
parents:
338
diff
changeset
|
867 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
|
868 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
869 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
870 * 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
|
871 * @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
|
872 * 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
|
873 * then it will be >= |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
874 * 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
|
875 * @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
|
876 */ |
597
d814669d2c13
int / int64 fix by (Wolfram Gloger <wmglo @@@ dent:med:uni-muenchen:de>)
michael
parents:
594
diff
changeset
|
877 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
|
878 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
879 /** |
2932
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
880 * Ensures the index uses less memory than the maximum specified in |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
881 * AVFormatContext.max_index_size, by discarding entries if it grows |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
882 * too large. |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
883 * This function is not part of the public API and should only be called |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
884 * by demuxers. |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
885 */ |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
886 void ff_reduce_index(AVFormatContext *s, int stream_index); |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
887 |
f5de41d943e2
user specifyable maximum amount of memory to use for the index.
michael
parents:
2876
diff
changeset
|
888 /** |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
889 * 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
|
890 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
891 * @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
|
892 */ |
354
6770ca07abe2
store searched distance in index, so we dont waste time searching for keyframes where we already searched
michael
parents:
346
diff
changeset
|
893 int av_add_index_entry(AVStream *st, |
979 | 894 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
|
895 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
896 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
897 * Does a binary search using av_index_search_timestamp() and AVCodec.read_timestamp(). |
2164 | 898 * This is not supposed to be called directly by a user application, but by demuxers. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
899 * @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
|
900 * @param stream_index stream number |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
901 */ |
555 | 902 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
|
903 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
904 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
905 * 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
|
906 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
907 * Stream ref_st unchanged, others set cur_dts in their native timebase |
2164 | 908 * only needed for timestamp wrapping or if (dts not set and pts!=dts). |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
909 * @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
|
910 * @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
|
911 */ |
1185
13dc486b272b
Try to find out correct start time to make seeking faster and add some
reimar
parents:
1175
diff
changeset
|
912 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
|
913 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
914 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
915 * Does a binary search using read_timestamp(). |
2164 | 916 * This is not supposed to be called directly by a user application, but by demuxers. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
917 * @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
|
918 * @param stream_index stream number |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
919 */ |
1496
7e288adde245
split av_seek_frame_binary() so the code becomes idependant of AVInputFormat and AVIndex
michael
parents:
1486
diff
changeset
|
920 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
|
921 |
1858
7ce72baa2ce5
Doxygenize the existing comments in avformat.h. The contents of the comments
takis
parents:
1844
diff
changeset
|
922 /** media file output */ |
17
e1200dd82537
added simple still image format support to simplify image and imagepipe video formats
bellard
parents:
5
diff
changeset
|
923 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
|
924 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
925 /** |
2164 | 926 * Allocate the stream private data and write the stream header to an |
927 * output media file. | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
928 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
929 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
930 * @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
|
931 */ |
0 | 932 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
|
933 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
934 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
935 * 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
|
936 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
937 * 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
|
938 * 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
|
939 * 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
|
940 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
941 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
942 * @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
|
943 * @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
|
944 */ |
468 | 945 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
|
946 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
947 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
948 * 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
|
949 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
950 * 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
|
951 * If the packets are already correctly interleaved the application should |
2165 | 952 * call av_write_frame() instead as it is slightly faster. It is also important |
953 * to keep in mind that completely non-interleaved input will need huge amounts | |
954 * of memory to interleave with this, so it is preferable to interleave at the | |
955 * demuxer level. | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
956 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
957 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
958 * @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
|
959 * @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
|
960 */ |
470 | 961 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
|
962 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
963 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
964 * 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
|
965 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
966 * 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
|
967 * 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
|
968 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
969 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
970 * @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
|
971 * @param in the input packet |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
972 * @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
|
973 * remaining packets should be output |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
974 * @return 1 if a packet was output, 0 if no packet could be output, |
3175 | 975 * < 0 if an error occurred |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
976 */ |
1251 | 977 int av_interleave_packet_per_dts(AVFormatContext *s, AVPacket *out, AVPacket *pkt, int flush); |
468 | 978 |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
979 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
980 * @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
|
981 * free the file private data. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
982 * |
3880
5245e7006f4c
Change doxygen comment: Clarify when av_write_trailer should be called.
reimar
parents:
3879
diff
changeset
|
983 * May only be called after a successful call to av_write_header. |
5245e7006f4c
Change doxygen comment: Clarify when av_write_trailer should be called.
reimar
parents:
3879
diff
changeset
|
984 * |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
985 * @param s media file handle |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
986 * @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
|
987 */ |
0 | 988 int av_write_trailer(AVFormatContext *s); |
989 | |
990 void dump_format(AVFormatContext *ic, | |
885 | 991 int index, |
0 | 992 const char *url, |
993 int is_output); | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
994 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
995 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
996 * parses width and height out of string str. |
2163
6c0176688fae
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
2148
diff
changeset
|
997 * @deprecated Use av_parse_video_frame_size instead. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
998 */ |
2163
6c0176688fae
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
2148
diff
changeset
|
999 attribute_deprecated 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
|
1000 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1001 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1002 * Converts frame rate from string to a fraction. |
2163
6c0176688fae
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
2148
diff
changeset
|
1003 * @deprecated Use av_parse_video_frame_rate instead. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1004 */ |
2163
6c0176688fae
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
2148
diff
changeset
|
1005 attribute_deprecated 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
|
1006 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1007 /** |
2559
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1008 * Parses \p datestr and returns a corresponding number of microseconds. |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1009 * @param datestr String representing a date or a duration. |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1010 * - If a date the syntax is: |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1011 * @code |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1012 * [{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
|
1013 * @endcode |
2559
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1014 * Time is localtime unless Z is appended, in which case it is |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1015 * interpreted as UTC. |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1016 * If the year-month-day part isn't specified it takes the current |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1017 * year-month-day. |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1018 * Returns the number of microseconds since 1st of January, 1970 up to |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1019 * the time of the parsed date or INT64_MIN if \p datestr cannot be |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1020 * successfully parsed. |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1021 * - If a duration the syntax is: |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1022 * @code |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1023 * [-]HH[:MM[:SS[.m...]]] |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1024 * [-]S+[.m...] |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1025 * @endcode |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1026 * Returns the number of microseconds contained in a time interval |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1027 * with the specified duration or INT64_MIN if \p datestr cannot be |
2788 | 1028 * successfully parsed. |
2559
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1029 * @param duration Flag which tells how to interpret \p datestr, if |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1030 * not zero \p datestr is interpreted as a duration, otherwise as a |
c57d3d6c8f44
Make parse_date return INT64_MIN in case of unparsable input.
benoit
parents:
2548
diff
changeset
|
1031 * date. |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1032 */ |
65 | 1033 int64_t parse_date(const char *datestr, int duration); |
0 | 1034 |
65 | 1035 int64_t av_gettime(void); |
0 | 1036 |
1037 /* ffm specific for ffserver */ | |
1038 #define FFM_PACKET_SIZE 4096 | |
1039 offset_t ffm_read_write_index(int fd); | |
1040 void ffm_write_write_index(int fd, offset_t pos); | |
1041 void ffm_set_write_index(AVFormatContext *s, offset_t pos, offset_t file_size); | |
1042 | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1043 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1044 * 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
|
1045 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1046 * 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
|
1047 * Return 1 if found. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1048 */ |
0 | 1049 int find_info_tag(char *arg, int arg_size, const char *tag1, const char *info); |
1050 | |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1051 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1052 * 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
|
1053 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1054 * 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
|
1055 * of digits and '%%'. |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1056 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1057 * @param buf destination buffer |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1058 * @param buf_size destination buffer size |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1059 * @param path numbered sequence string |
2749 | 1060 * @param number frame number |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1061 * @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
|
1062 */ |
1291
185190bdc185
Clarified API for numbered sequences, patch by Michel Bardiaux % mbardiaux A mediaxim P be %
gpoirier
parents:
1289
diff
changeset
|
1063 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
|
1064 const char *path, int number); |
1840
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1065 |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1066 /** |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1067 * 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
|
1068 * |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1069 * @param filename possible numbered sequence string |
daaa79ca14f0
Move the libavformat public API comments to avformat.h. The comments are
takis
parents:
1795
diff
changeset
|
1070 * @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
|
1071 */ |
1291
185190bdc185
Clarified API for numbered sequences, patch by Michel Bardiaux % mbardiaux A mediaxim P be %
gpoirier
parents:
1289
diff
changeset
|
1072 int av_filename_number_test(const char *filename); |
0 | 1073 |
2284 | 1074 /** |
1075 * Generate an SDP for an RTP session. | |
1076 * | |
1077 * @param ac array of AVFormatContexts describing the RTP streams. If the | |
1078 * array is composed by only one context, such context can contain | |
1079 * multiple AVStreams (one AVStream per RTP stream). Otherwise, | |
1080 * all the contexts in the array (an AVCodecContext per RTP stream) | |
1081 * must contain only one AVStream | |
2317
2adc9f64ecfb
Change avf_sdp_create() to get a pre-allocated buffer as input, and to
lucabe
parents:
2300
diff
changeset
|
1082 * @param n_files number of AVCodecContexts contained in ac |
2adc9f64ecfb
Change avf_sdp_create() to get a pre-allocated buffer as input, and to
lucabe
parents:
2300
diff
changeset
|
1083 * @param buff buffer where the SDP will be stored (must be allocated by |
2adc9f64ecfb
Change avf_sdp_create() to get a pre-allocated buffer as input, and to
lucabe
parents:
2300
diff
changeset
|
1084 * the caller |
2adc9f64ecfb
Change avf_sdp_create() to get a pre-allocated buffer as input, and to
lucabe
parents:
2300
diff
changeset
|
1085 * @param size the size of the buffer |
2adc9f64ecfb
Change avf_sdp_create() to get a pre-allocated buffer as input, and to
lucabe
parents:
2300
diff
changeset
|
1086 * @return 0 if OK. AVERROR_xxx if error. |
2284 | 1087 */ |
2317
2adc9f64ecfb
Change avf_sdp_create() to get a pre-allocated buffer as input, and to
lucabe
parents:
2300
diff
changeset
|
1088 int avf_sdp_create(AVFormatContext *ac[], int n_files, char *buff, int size); |
2284 | 1089 |
0 | 1090 #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
|
1091 |
3249 | 1092 void ff_dynarray_add(unsigned long **tab_ptr, int *nb_ptr, unsigned long elem); |
151 | 1093 |
255 | 1094 #ifdef __GNUC__ |
151 | 1095 #define dynarray_add(tab, nb_ptr, elem)\ |
1096 do {\ | |
1097 typeof(tab) _tab = (tab);\ | |
1098 typeof(elem) _elem = (elem);\ | |
1099 (void)sizeof(**_tab == _elem); /* check that types are compatible */\ | |
3249 | 1100 ff_dynarray_add((unsigned long **)_tab, nb_ptr, (unsigned long)_elem);\ |
151 | 1101 } while(0) |
255 | 1102 #else |
1103 #define dynarray_add(tab, nb_ptr, elem)\ | |
1104 do {\ | |
3249 | 1105 ff_dynarray_add((unsigned long **)(tab), nb_ptr, (unsigned long)(elem));\ |
255 | 1106 } while(0) |
1107 #endif | |
151 | 1108 |
230
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
1109 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
|
1110 struct tm *brktimegm(time_t secs, struct tm *tm); |
885 | 1111 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
|
1112 struct tm *dt); |
9f4f4ca9f7b5
simpler strptime - added os_support.[ch] - moved localtime_r to os_support.c
bellard
parents:
225
diff
changeset
|
1113 |
0 | 1114 struct in_addr; |
1115 int resolve_host(struct in_addr *sin_addr, const char *hostname); | |
1116 | |
1117 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
|
1118 char *authorization, int authorization_size, |
0 | 1119 char *hostname, int hostname_size, |
1120 int *port_ptr, | |
1121 char *path, int path_size, | |
1122 const char *url); | |
1123 | |
1124 int match_ext(const char *filename, const char *extensions); | |
1125 | |
1126 #endif /* HAVE_AV_CONFIG_H */ | |
1127 | |
3852 | 1128 #endif /* AVFORMAT_AVFORMAT_H */ |