diff options
author | Clément Bœsch <u@pkh.me> | 2014-09-20 21:58:27 +0200 |
---|---|---|
committer | Clément Bœsch <u@pkh.me> | 2014-09-21 18:41:45 +0200 |
commit | ac95b436db734cd72e637cef40e11bba2bf5da7d (patch) | |
tree | a357002fa3f28e6122d692eba11bf9370d422c93 | |
parent | 4c85073044a6cb4c28210ebece9013947ea84a04 (diff) | |
download | ffmpeg-ac95b436db734cd72e637cef40e11bba2bf5da7d.tar.gz |
avcodec/microdvddec: add some memory checks
-rw-r--r-- | libavcodec/microdvddec.c | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/libavcodec/microdvddec.c b/libavcodec/microdvddec.c index 7df3e485f4..1347510b88 100644 --- a/libavcodec/microdvddec.c +++ b/libavcodec/microdvddec.c @@ -261,7 +261,6 @@ static int microdvd_decode_frame(AVCodecContext *avctx, AVSubtitle *sub = data; AVBPrint new_line; char c; - char *decoded_sub; char *line = avpkt->data; char *end = avpkt->data + avpkt->size; struct microdvd_tag tags[sizeof(MICRODVD_TAGS) - 1] = {{0}}; @@ -301,18 +300,18 @@ static int microdvd_decode_frame(AVCodecContext *avctx, } } if (new_line.len) { - av_bprintf(&new_line, "\r\n"); - - av_bprint_finalize(&new_line, &decoded_sub); - if (*decoded_sub) { + int ret; int64_t start = avpkt->pts; int64_t duration = avpkt->duration; int ts_start = av_rescale_q(start, avctx->time_base, (AVRational){1,100}); int ts_duration = duration != -1 ? av_rescale_q(duration, avctx->time_base, (AVRational){1,100}) : -1; - ff_ass_add_rect(sub, decoded_sub, ts_start, ts_duration, 0); - } - av_free(decoded_sub); + + av_bprintf(&new_line, "\r\n"); + ret = ff_ass_add_rect_bprint(sub, &new_line, ts_start, ts_duration, 0); + av_bprint_finalize(&new_line, NULL); + if (ret < 0) + return ret; } *got_sub_ptr = sub->num_rects > 0; |