138                    "FLV only supports wideband (16kHz) Speex audio\n");
 
  175                    "FLV does not support sample rate %d, " 
  176                    "choose from (44100, 22050, 11025)\n", par->
sample_rate);
 
  228     size_t len = strlen(str);
 
  238     avio_w8(pb, (ts >> 24) & 0x7F); 
 
  274     int metadata_count = 0;
 
  275     int64_t metadata_count_pos;
 
  297     if (write_duration_filesize) {
 
  302     if (write_duration_filesize) {
 
  353         if(   !strcmp(tag->
key, 
"width")
 
  354             ||!strcmp(tag->
key, 
"height")
 
  355             ||!strcmp(tag->
key, 
"videodatarate")
 
  356             ||!strcmp(tag->
key, 
"framerate")
 
  357             ||!strcmp(tag->
key, 
"videocodecid")
 
  358             ||!strcmp(tag->
key, 
"audiodatarate")
 
  359             ||!strcmp(tag->
key, 
"audiosamplerate")
 
  360             ||!strcmp(tag->
key, 
"audiosamplesize")
 
  361             ||!strcmp(tag->
key, 
"stereo")
 
  362             ||!strcmp(tag->
key, 
"audiocodecid")
 
  363             ||!strcmp(tag->
key, 
"duration")
 
  364             ||!strcmp(tag->
key, 
"onMetaData")
 
  365             ||!strcmp(tag->
key, 
"datasize")
 
  366             ||!strcmp(tag->
key, 
"lasttimestamp")
 
  367             ||!strcmp(tag->
key, 
"totalframes")
 
  368             ||!strcmp(tag->
key, 
"hasAudio")
 
  369             ||!strcmp(tag->
key, 
"hasVideo")
 
  370             ||!strcmp(tag->
key, 
"hasCuePoints")
 
  371             ||!strcmp(tag->
key, 
"hasMetadata")
 
  372             ||!strcmp(tag->
key, 
"hasKeyframes")
 
  383     if (write_duration_filesize) {
 
  462     avio_seek(pb, metadata_count_pos, SEEK_SET);
 
  477            "%s codec %s not compatible with flv\n",
 
  479             desc ? desc->
name : 
"unknown");
 
  505                 int samplerate_index;
 
  510                 for (samplerate_index = 0; samplerate_index < 16;
 
  518                 put_bits(&pbc, 4, samplerate_index); 
 
  539         avio_seek(pb, -data_size - 10, SEEK_CUR);
 
  577     int64_t metadata_size = 0;
 
  586     metadata_size += 2 + 13; 
 
  587     metadata_size += 2 + 5; 
 
  592     if (metadata_size < 0)
 
  593         return metadata_size;
 
  600     read_buf[1] = buf + metadata_size;
 
  616                "the second pass (add_keyframe_index)\n", s->
url);
 
  629 #define READ_BLOCK do {                                                             \ 
  630     read_size[read_buf_id] = avio_read(read_pb, read_buf[read_buf_id], metadata_size);  \ 
  638         n = read_size[read_buf_id];
 
  643     } 
while (pos <= pos_end);
 
  670                        "at most one video stream is supported in flv\n");
 
  685                            "use vstrict=-1 / -strict -1 to use it anyway.\n");
 
  690                        "Muxing VP6 in flv will produce flipped video on playback.\n");
 
  696                        "at most one audio stream is supported in flv\n");
 
  704                        "16-bit big-endian audio in flv is valid but most likely unplayable (hardware dependent); use s16le\n");
 
  713                 av_log(s, 
AV_LOG_ERROR, 
"Subtitle codec '%s' for stream %d is not compatible with FLV\n",
 
  775     if (build_keyframes_idx) {
 
  812         while (newflv_posinfo) {
 
  813             p = newflv_posinfo->
next;
 
  820                 newflv_posinfo = 
NULL;
 
  846     if (build_keyframes_idx) {
 
  879     int flags = -1, flags_size, ret;
 
  912                "Packets are not in the proper order with respect to DTS\n");
 
  958                "use the audio bitstream filter 'aac_adtstoasc' to fix it " 
  959                "('-bsf:a aac_adtstoasc' option with ffmpeg)\n");
 
  968                                   "8 frames per packet. Adobe Flash " 
  969                                   "Player cannot handle this!\n");
 
  974     if (size + flags_size >= 1<<24) {
 
  976                size + flags_size, 1<<24);
 
  982     avio_w8(pb, (ts >> 24) & 0x7F); 
 
  988         int64_t metadata_size_pos = 
avio_tell(pb);
 
 1008         data_size = 
avio_tell(pb) - metadata_size_pos;
 
 1009         avio_seek(pb, metadata_size_pos - 10, SEEK_SET);
 
 1011         avio_seek(pb, data_size + 10 - 3, SEEK_CUR);
 
 1045                     int64_t pos = cur_offset;
 
 1070     { 
"flvflags", 
"FLV muxer flags", offsetof(
FLVContext, 
flags), 
AV_OPT_TYPE_FLAGS, {.i64 = 0}, INT_MIN, INT_MAX, 
AV_OPT_FLAG_ENCODING_PARAM, 
"flvflags" },
 
 1089     .mime_type      = 
"video/x-flv",
 
 1090     .extensions     = 
"flv",
 
static void write_packet(OutputFile *of, AVPacket *pkt, OutputStream *ost, int unqueue)
void avio_wb64(AVIOContext *s, uint64_t val)
#define AVERROR_INVALIDDATA
Invalid data found when processing input. 
ptrdiff_t const GLvoid * data
int64_t delay
first dts delay (needed for AVC & Speex) 
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit 
#define AV_LOG_WARNING
Something somehow does not look correct. 
#define LIBAVUTIL_VERSION_INT
enum AVCodecID codec_id
Specific type of the encoded data (the codec used). 
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext. 
const char * av_default_item_name(void *ptr)
Return the context name. 
#define AVIO_FLAG_READ
read-only 
static av_always_inline uint64_t av_double2int(double f)
Reinterpret a double as a 64-bit integer. 
int event_flags
Flags for the user to detect events happening on the file. 
int64_t metadata_totalsize
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward. 
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
double lastkeyframetimestamp
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_WB32 unsigned int_TMPL AV_WB24 unsigned int_TMPL AV_RB16
int strict_std_compliance
Allow non-standard and experimental extension. 
This struct describes the properties of an encoded stream. 
int64_t keyframe_index_size
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
#define av_assert0(cond)
assert() equivalent, that is always enabled. 
FLVFileposition * head_filepositions
Opaque data information usually continuous. 
AVCodecParameters * video_par
static av_cold int end(AVCodecContext *avctx)
int64_t duration
Duration of this packet in AVStream->time_base units, 0 if unknown. 
double keyframe_timestamp
void avio_write_marker(AVIOContext *s, int64_t time, enum AVIODataMarkerType type)
Mark the written bytestream as a specific type. 
AVStream ** streams
A list of all streams in the file. 
A point in the output bytestream where a demuxer can start parsing (for non self synchronizing bytest...
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key. 
static double av_q2d(AVRational a)
Convert an AVRational to a double. 
AVCodecParameters * audio_par
int64_t keyframes_info_offset
int64_t metadata_totalsize_pos
static av_always_inline int64_t avio_tell(AVIOContext *s)
ftell() equivalent for AVIOContext. 
void avio_write(AVIOContext *s, const unsigned char *buf, int size)
int64_t lastkeyframelocation_offset
#define AV_OPT_FLAG_ENCODING_PARAM
a generic parameter which can be set by the user for muxing or encoding 
int64_t bit_rate
The average bitrate of the encoded data (in bits per second). 
#define FF_COMPLIANCE_UNOFFICIAL
Allow unofficial extensions. 
#define AV_PKT_FLAG_KEY
The packet contains a keyframe. 
int64_t filepositions_count
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered. 
AVDictionary * metadata
Metadata that applies to the whole file. 
uint8_t * av_packet_get_side_data(const AVPacket *pkt, enum AVPacketSideDataType type, int *size)
Get side information from packet. 
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
char * url
input or output URL. 
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers. 
preferred ID for decoding MPEG audio layer 1, 2 or 3 
enum AVMediaType codec_type
General type of the encoded data. 
static const int mpeg4audio_sample_rates[16]
simple assert() macros that are a bit more flexible than ISO C assert(). 
AVRational avg_frame_rate
Average framerate. 
FLVFileposition * filepositions
int ff_avc_parse_nal_units_buf(const uint8_t *buf_in, uint8_t **buf, int *size)
int flags
A combination of AV_PKT_FLAG values. 
const AVCodecDescriptor * avcodec_descriptor_get(enum AVCodecID id)
int extradata_size
Size of the extradata content in bytes. 
unsigned int nb_streams
Number of elements in AVFormatContext.streams. 
int seekable
A combination of AVIO_SEEKABLE_ flags or 0 when the stream is not seekable. 
int void avio_flush(AVIOContext *s)
Force flushing of buffered data. 
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code. 
int64_t av_rescale(int64_t a, int64_t b, int64_t c)
Rescale a 64-bit integer with rounding to nearest. 
#define AV_TIME_BASE
Internal time base represented as integer. 
int64_t lasttimestamp_offset
static int write_trailer(AVFormatContext *s1)
void avio_wb24(AVIOContext *s, unsigned int val)
int64_t lastkeyframelocation
static void error(const char *err)
struct FLVFileposition * next
const char * avcodec_get_name(enum AVCodecID id)
Get the name of a codec. 
The AV_PKT_DATA_NEW_EXTRADATA is used to notify the codec or the format that the extradata buffer was...
AVIOContext * pb
I/O context. 
void avio_w8(AVIOContext *s, int b)
int64_t keyframe_position
Describe the class of an AVClass context structure. 
AVCodecParameters * data_par
int64_t lastkeyframetimestamp_offset
const char * name
Name of the codec described by this descriptor. 
int error
contains the error code or 0 if no error happened 
This struct describes the properties of a single codec described by an AVCodecID. ...
void avio_wb16(AVIOContext *s, unsigned int val)
const char * av_get_media_type_string(enum AVMediaType media_type)
Return a string describing the media_type enum, NULL if media_type is unknown. 
int sample_rate
Audio only. 
static void flush_put_bits(PutBitContext *s)
Pad the end of the output stream with zeros. 
int profile
Codec-specific bitstream restrictions that the stream conforms to. 
int64_t nb_frames
number of frames in this stream if known or 0 
static void init_put_bits(PutBitContext *s, uint8_t *buffer, int buffer_size)
Initialize the PutBitContext s. 
#define AV_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
A point in the output bytestream where a decoder can start decoding (i.e. 
void * priv_data
Format private data. 
static void write_header(FFV1Context *f)
int bits_per_coded_sample
The number of bits per sample in the codedwords. 
uint8_t * extradata
Extra binary data needed for initializing the decoder, codec-dependent. 
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed...
void avio_wb32(AVIOContext *s, unsigned int val)
int64_t duration
Duration of the stream, in AV_TIME_BASE fractional seconds. 
#define AV_DICT_IGNORE_SUFFIX
Return first entry in a dictionary whose first part corresponds to the search key, ignoring the suffix of the found key string. 
AVCodecParameters * codecpar
Codec parameters associated with this stream. 
#define av_malloc_array(a, b)
uint32_t codec_tag
Additional information about the codec (corresponds to the AVI FOURCC). 
int64_t metadata_size_pos
int(* io_open)(struct AVFormatContext *s, AVIOContext **pb, const char *url, int flags, AVDictionary **options)
A callback for opening new IO streams. 
This structure stores compressed data. 
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
int64_t last_ts
last timestamp for each stream 
int ff_isom_write_avcc(AVIOContext *pb, const uint8_t *data, int len)
#define AV_NOPTS_VALUE
Undefined timestamp value.