From: Marth64 <marth64@proxyid.net>
To: ffmpeg-devel@ffmpeg.org
Cc: Marth64 <marth64@proxyid.net>
Subject: [FFmpeg-devel] [PATCH] avformat/dvdvideodec: fix -pgc and -pg options
Date: Sat, 2 Mar 2024 20:29:13 -0600
Message-ID: <20240303022912.2105313-1-marth64@proxyid.net> (raw)
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>
---
libavformat/dvdvideodec.c | 23 +++++++++++++----------
1 file changed, 13 insertions(+), 10 deletions(-)
diff --git a/libavformat/dvdvideodec.c b/libavformat/dvdvideodec.c
index 3355010356..d53aef07ff 100644
--- a/libavformat/dvdvideodec.c
+++ b/libavformat/dvdvideodec.c
@@ -508,11 +508,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;
}
@@ -1266,19 +1267,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 ||
@@ -1288,7 +1291,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 ret;
--
2.34.1
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
next reply other threads:[~2024-03-03 2:29 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-03-03 2:29 Marth64 [this message]
2024-03-04 9:24 ` Stefano Sabatini
2024-03-04 9:43 ` Stefano Sabatini
2024-03-04 16:37 ` Marth64
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20240303022912.2105313-1-marth64@proxyid.net \
--to=marth64@proxyid.net \
--cc=ffmpeg-devel@ffmpeg.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
This inbox may be cloned and mirrored by anyone:
git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
ffmpegdev@gitmailbox.com
public-inbox-index ffmpegdev
Example config snippet for mirrors.
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git