summaryrefslogtreecommitdiffstats
path: root/libavcodec/textdec.c
diff options
context:
space:
mode:
authorMarton Balint <cus@passwd.hu>2013-10-23 20:03:17 +0200
committerMarton Balint <cus@passwd.hu>2013-11-10 18:57:52 +0100
commitb96325e023cfe9fed5a17009b2ef23797caab906 (patch)
treefab9083fa9d4f6a35f26e63a56eb5c6b45f007db /libavcodec/textdec.c
parent0f0a8d9859c3ac2a05b0a794197b240b00f3501f (diff)
downloadffmpeg-streaming-b96325e023cfe9fed5a17009b2ef23797caab906.zip
ffmpeg-streaming-b96325e023cfe9fed5a17009b2ef23797caab906.tar.gz
ass: move text_event_to_ass from textdec.c to ass.c and export it
Signed-off-by: Marton Balint <cus@passwd.hu>
Diffstat (limited to 'libavcodec/textdec.c')
-rw-r--r--libavcodec/textdec.c45
1 files changed, 3 insertions, 42 deletions
diff --git a/libavcodec/textdec.c b/libavcodec/textdec.c
index a8f9e40..d904023 100644
--- a/libavcodec/textdec.c
+++ b/libavcodec/textdec.c
@@ -41,59 +41,20 @@ static const AVOption options[] = {
{ NULL }
};
-static int text_event_to_ass(const AVCodecContext *avctx, AVBPrint *buf,
- const char *p, const char *p_end)
-{
- const TextContext *text = avctx->priv_data;
-
- for (; p < p_end && *p; p++) {
-
- /* forced custom line breaks, not accounted as "normal" EOL */
- if (text->linebreaks && strchr(text->linebreaks, *p)) {
- av_bprintf(buf, "\\N");
-
- /* standard ASS escaping so random characters don't get mis-interpreted
- * as ASS */
- } else if (!text->keep_ass_markup && strchr("{}\\", *p)) {
- av_bprintf(buf, "\\%c", *p);
-
- /* some packets might end abruptly (no \0 at the end, like for example
- * in some cases of demuxing from a classic video container), some
- * might be terminated with \n or \r\n which we have to remove (for
- * consistency with those who haven't), and we also have to deal with
- * evil cases such as \r at the end of the buffer (and no \0 terminated
- * character) */
- } else if (p[0] == '\n') {
- /* some stuff left so we can insert a line break */
- if (p < p_end - 1)
- av_bprintf(buf, "\\N");
- } else if (p[0] == '\r' && p < p_end - 1 && p[1] == '\n') {
- /* \r followed by a \n, we can skip it. We don't insert the \N yet
- * because we don't know if it is followed by more text */
- continue;
-
- /* finally, a sane character */
- } else {
- av_bprint_chars(buf, *p, 1);
- }
- }
- av_bprintf(buf, "\r\n");
- return 0;
-}
-
static int text_decode_frame(AVCodecContext *avctx, void *data,
int *got_sub_ptr, AVPacket *avpkt)
{
AVBPrint buf;
AVSubtitle *sub = data;
const char *ptr = avpkt->data;
+ const TextContext *text = avctx->priv_data;
const int ts_start = av_rescale_q(avpkt->pts, avctx->time_base, (AVRational){1,100});
const int ts_duration = avpkt->duration != -1 ?
av_rescale_q(avpkt->duration, avctx->time_base, (AVRational){1,100}) : -1;
av_bprint_init(&buf, 0, AV_BPRINT_SIZE_UNLIMITED);
- if (ptr && avpkt->size > 0 && *ptr &&
- !text_event_to_ass(avctx, &buf, ptr, ptr + avpkt->size)) {
+ if (ptr && avpkt->size > 0 && *ptr) {
+ ff_ass_bprint_text_event(&buf, ptr, avpkt->size, text->linebreaks, text->keep_ass_markup);
if (!av_bprint_is_complete(&buf)) {
av_bprint_finalize(&buf, NULL);
return AVERROR(ENOMEM);
OpenPOWER on IntegriCloud