98 }
else if (num >= den) {
115 for (j=2; j<14; j+= 1+(j>2))
116 while (q.
den / q.
num < min_precission && q.
num % j == 0)
118 while (q.
den / q.
num < min_precission && q.
den < (1<<24))
125 const char *format,
const char *filename)
138 av_log(s,
AV_LOG_ERROR,
"Requested output format '%s' is not a suitable output format\n", format);
177 #if FF_API_ALLOC_OUTPUT_CONTEXT
183 return ret < 0 ? NULL : avctx;
192 unsigned int tag = 0;
282 "(%d/%d) and encoder layer (%d/%d)\n",
305 char tagbuf[32], tagbuf2[32];
309 "Tag %s/0x%08x incompatible with output codec id '%d' (%s)\n",
321 "Codec for stream %d does not use global headers "
322 "but container format requires global headers\n", i);
396 if (ret >= 0 && s->
pb && s->
pb->
error < 0)
421 av_dlog(s,
"compute_pkt_fields2: pts:%s dts:%s cur_dts:%s b:%d size:%d st:%d\n",
462 "Application provided invalid, non monotonically increasing dts to muxer in stream %d: %s >= %s\n",
472 av_dlog(s,
"av_write_frame: pts2:%s dts2:%s\n",
520 if (s->
offset && !offset) {
557 if (ret >= 0 && s->
pb && s->
pb->
error < 0)
570 if (ret >= 0 && s->
pb && s->
pb->
error < 0)
578 #define CHUNK_START 0x1000
591 #if FF_API_DESTRUCT_PACKET
593 pkt->destruct = NULL;
616 int64_t syncto =
av_rescale(pkt->
dts + syncoffset, 1, max)*max - syncoffset;
629 && ((chunked && !((*next_point)->pkt.flags&
CHUNK_START))
630 || !compare(s, &(*next_point)->pkt, pkt)))
631 next_point = &(*next_point)->
next;
643 this_pktl->
next = *next_point;
646 *next_point = this_pktl;
665 comp= (ts>ts2) - (ts<ts2);
677 int stream_count = 0, noninterleaved_count = 0;
678 int64_t delta_dts_max = 0;
691 ++noninterleaved_count;
707 delta_dts_max=
FFMAX(delta_dts_max, delta_dts);
710 if (s->
nb_streams == stream_count+noninterleaved_count &&
716 if (stream_count && flush) {
768 av_dlog(s,
"av_interleaved_write_frame size:%d dts:%s pts:%s\n",
776 av_dlog(s,
"av_interleaved_write_frame FLUSH\n");
843 int64_t *dts, int64_t *wall)