[FFmpeg-devel] [PATCH] lavfi/vf_ass: ignore subtitles decoding errors.

Clément Bœsch ubitux at gmail.com
Wed Feb 13 17:42:13 CET 2013


On Wed, Feb 13, 2013 at 05:35:51PM +0100, Nicolas George wrote:
> A broken packet with invalid data in the middle of the stream
> should not prevent from decoding the rest of the file.
> 
> Work around trac ticket #2264.
> 
> Signed-off-by: Nicolas George <nicolas.george at normalesup.org>
> ---
>  libavfilter/vf_ass.c |    8 ++++++--
>  1 file changed, 6 insertions(+), 2 deletions(-)
> 
> diff --git a/libavfilter/vf_ass.c b/libavfilter/vf_ass.c
> index ade1b37..85dd5ce 100644
> --- a/libavfilter/vf_ass.c
> +++ b/libavfilter/vf_ass.c
> @@ -318,14 +318,18 @@ static av_cold int init_subtitles(AVFilterContext *ctx, const char *args)
>  
>          if (pkt.stream_index == sid) {
>              ret = avcodec_decode_subtitle2(dec_ctx, &sub, &got_subtitle, &pkt);
> -            if (ret < 0 || !got_subtitle)
> -                break;
> +            if (ret < 0) {
> +                av_log(ctx, AV_LOG_WARNING, "Error decoding: %s (ignored)\n",
> +                       av_err2str(ret));
> +            } else if (got_subtitle) {
> +                /* TODO reindent */
>              for (i = 0; i < sub.num_rects; i++) {
>                  char *ass_line = sub.rects[i]->ass;
>                  if (!ass_line)
>                      break;
>                  ass_process_data(ass->track, ass_line, strlen(ass_line));
>              }
> +            }
>          }
>          av_free_packet(&pkt);
>          avsubtitle_free(&sub);

LGTM, thanks.

-- 
Clément B.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 490 bytes
Desc: not available
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20130213/72cd231b/attachment.asc>


More information about the ffmpeg-devel mailing list