aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarth64 <marth64@proxyid.net>2024-03-03 02:45:41 -0600
committerStefano Sabatini <stefasab@gmail.com>2024-03-04 10:47:57 +0100
commit01476f752aa74f23c9226dfa3dc161285184a242 (patch)
tree324ec7766ef5baed684b11eb6ddd41855c5f747e
parente30369bc1c683aeab6ea74bc37b4ae77b03f79b5 (diff)
downloadffmpeg-01476f752aa74f23c9226dfa3dc161285184a242.tar.gz
avformat/dvdvideodec: fix -pgc and -pg options
Rebased on top of recently merged fixes (should apply correctly now). In merged DVD patch, -pgc and -pg options were broken. While these are rather advanced options, they are the only means to get content for some strangely authored discs. Signed-off-by: Marth64 <marth64@proxyid.net>
-rw-r--r--libavformat/dvdvideodec.c23
1 files changed, 13 insertions, 10 deletions
diff --git a/libavformat/dvdvideodec.c b/libavformat/dvdvideodec.c
index 7f4ecf2b61..b83ae0c2a5 100644
--- a/libavformat/dvdvideodec.c
+++ b/libavformat/dvdvideodec.c
@@ -507,11 +507,12 @@ static int dvdvideo_play_next_ps_block(AVFormatContext *s, DVDVideoPlaybackState
state->celln, e_cell->cellN, is_cell_promising);
if (!state->in_ps && !state->in_pgc) {
- if (cur_title == c->opt_title &&
- cur_ptt == c->opt_chapter_start &&
- cur_pgcn == state->pgcn &&
- cur_pgn == state->entry_pgn &&
+ if (cur_title == c->opt_title &&
+ (c->opt_pgc || cur_ptt == c->opt_chapter_start) &&
+ cur_pgcn == state->pgcn &&
+ cur_pgn == state->entry_pgn &&
is_cell_promising) {
+
state->in_pgc = 1;
}
@@ -1254,19 +1255,21 @@ static int dvdvideo_read_header(AVFormatContext *s)
}
if (c->opt_pgc) {
- if (c->opt_pg == 0)
+ if (c->opt_pg == 0) {
av_log(s, AV_LOG_ERROR, "Invalid coordinates. If -pgc is set, -pg must be set too.\n");
- else if (c->opt_chapter_start > 1 || c->opt_chapter_end > 0 || c->opt_preindex)
+
+ return AVERROR(EINVAL);
+ } else if (c->opt_chapter_start > 1 || c->opt_chapter_end > 0 || c->opt_preindex) {
av_log(s, AV_LOG_ERROR, "-pgc is not compatible with the -preindex or "
"-chapter_start/-chapter_end options\n");
-
- return AVERROR(EINVAL);
+ return AVERROR(EINVAL);
+ }
}
if ((ret = dvdvideo_ifo_open(s)) < 0)
return ret;
- if (c->opt_preindex && (ret = dvdvideo_chapters_setup_preindex(s)) < 0)
+ if (!c->opt_pgc && c->opt_preindex && (ret = dvdvideo_chapters_setup_preindex(s)) < 0)
return ret;
if ((ret = dvdvideo_play_open(s, &c->play_state)) < 0 ||
@@ -1276,7 +1279,7 @@ static int dvdvideo_read_header(AVFormatContext *s)
(ret = dvdvideo_subp_stream_add_all(s)) < 0)
return ret;
- if (!c->opt_preindex)
+ if (!c->opt_pgc && !c->opt_preindex)
return dvdvideo_chapters_setup_simple(s);
return 0;