summaryrefslogtreecommitdiff
path: root/libavformat/tty.c
diff options
context:
space:
mode:
authorAnton Khirnov <anton@khirnov.net>2011-05-23 19:23:55 +0200
committerAnton Khirnov <anton@khirnov.net>2011-05-25 16:21:25 +0200
commit67540af7baa5c4064753861be217ac8f7c8df997 (patch)
tree67128d947b650d0c33f17a973e0b9d4b3faa2fe9 /libavformat/tty.c
parent656566d7a4fef9680e483f1015d4cc242d825202 (diff)
tty: replace AVFormatParameters.sample_rate abuse with a private option.
Diffstat (limited to 'libavformat/tty.c')
-rw-r--r--libavformat/tty.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/libavformat/tty.c b/libavformat/tty.c
index ea8d0c7ece..bc6058d857 100644
--- a/libavformat/tty.c
+++ b/libavformat/tty.c
@@ -26,12 +26,13 @@
#include "libavutil/intreadwrite.h"
#include "libavutil/avstring.h"
+#include "libavutil/log.h"
+#include "libavutil/opt.h"
#include "avformat.h"
#include "sauce.h"
-#define LINE_RATE 6000 /* characters per second */
-
typedef struct {
+ AVClass *class;
int chars_per_frame;
uint64_t fsize; /**< file size less metadata buffer */
} TtyDemuxContext;
@@ -86,7 +87,11 @@ static int read_header(AVFormatContext *avctx,
}
/* simulate tty display speed */
- s->chars_per_frame = FFMAX(av_q2d(st->time_base) * (ap->sample_rate ? ap->sample_rate : LINE_RATE), 1);
+#if FF_API_FORMAT_PARAMETERS
+ if (ap->sample_rate)
+ s->chars_per_frame = ap->sample_rate;
+#endif
+ s->chars_per_frame = FFMAX(av_q2d(st->time_base)*s->chars_per_frame, 1);
if (avctx->pb->seekable) {
s->fsize = avio_size(avctx->pb);
@@ -124,6 +129,18 @@ static int read_packet(AVFormatContext *avctx, AVPacket *pkt)
return 0;
}
+static const AVOption options[] = {
+ { "chars_per_frame", "", offsetof(TtyDemuxContext, chars_per_frame), FF_OPT_TYPE_INT, {.dbl = 6000}, 1, INT_MAX, AV_OPT_FLAG_DECODING_PARAM},
+ { NULL },
+};
+
+static const AVClass tty_demuxer_class = {
+ .class_name = "TTY demuxer",
+ .item_name = av_default_item_name,
+ .option = options,
+ .version = LIBAVUTIL_VERSION_INT,
+};
+
AVInputFormat ff_tty_demuxer = {
.name = "tty",
.long_name = NULL_IF_CONFIG_SMALL("Tele-typewriter"),
@@ -131,4 +148,5 @@ AVInputFormat ff_tty_demuxer = {
.read_header = read_header,
.read_packet = read_packet,
.extensions = "ans,art,asc,diz,ice,nfo,txt,vt",
+ .priv_class = &tty_demuxer_class,
};