avformat/img2enc: use unmatched filename for an invalid or missing sequence pattern

Also warn the user that for single images -update should be used, for sequences
a proper pattern should be specified.

Fixes ticket #9748.

Signed-off-by: Marton Balint <cus@passwd.hu>
release/5.1
Marton Balint 3 years ago
parent 3f2de562c3
commit b54f3e32fa
  1. 18
      libavformat/img2enc.c

@ -163,13 +163,17 @@ static int write_packet(AVFormatContext *s, AVPacket *pkt)
} }
} else if (av_get_frame_filename2(filename, sizeof(filename), s->url, } else if (av_get_frame_filename2(filename, sizeof(filename), s->url,
img->img_number, img->img_number,
AV_FRAME_FILENAME_FLAGS_MULTIPLE) < 0 && AV_FRAME_FILENAME_FLAGS_MULTIPLE) < 0) {
img->img_number > img->start_img_number) { if (img->img_number == img->start_img_number) {
av_log(s, AV_LOG_ERROR, av_log(s, AV_LOG_WARNING, "The specified filename '%s' does not contain an image sequence pattern or a pattern is invalid.\n", s->url);
"Could not get frame filename number %d from pattern '%s'. " av_log(s, AV_LOG_WARNING,
"Use '-frames:v 1' for a single image, or '-update' option, or use a pattern such as %%03d within the filename.\n", "Use a pattern such as %%03d for an image sequence or "
img->img_number, s->url); "use the -update option (with -frames:v 1 if needed) to write a single image.\n");
return AVERROR(EINVAL); av_strlcpy(filename, s->url, sizeof(filename));
} else {
av_log(s, AV_LOG_ERROR, "Cannot write more than one file with the same name. Are you missing the -update option or a sequence pattern?\n");
return AVERROR(EINVAL);
}
} }
for (i = 0; i < 4; i++) { for (i = 0; i < 4; i++) {
av_dict_copy(&options, img->protocol_opts, 0); av_dict_copy(&options, img->protocol_opts, 0);

Loading…
Cancel
Save