Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
fcbb8a42
Commit
fcbb8a42
authored
May 19, 2005
by
Steve Lhomme
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mkv.cpp: fix a problem when using successive 0s chapters in ordered editions
parent
6d684f9d
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
18 additions
and
6 deletions
+18
-6
modules/demux/mkv.cpp
modules/demux/mkv.cpp
+18
-6
No files found.
modules/demux/mkv.cpp
View file @
fcbb8a42
...
@@ -922,7 +922,7 @@ public:
...
@@ -922,7 +922,7 @@ public:
int64_t
RefreshChapters
(
bool
b_ordered
,
int64_t
i_prev_user_time
);
int64_t
RefreshChapters
(
bool
b_ordered
,
int64_t
i_prev_user_time
);
int
PublishChapters
(
input_title_t
&
title
,
int
&
i_user_chapters
,
int
i_level
=
0
);
int
PublishChapters
(
input_title_t
&
title
,
int
&
i_user_chapters
,
int
i_level
=
0
);
chapter_item_c
*
FindTimecode
(
mtime_t
i_timecode
);
virtual
chapter_item_c
*
FindTimecode
(
mtime_t
i_timecode
,
const
chapter_item_c
*
p_current
,
bool
&
b_found
);
void
Append
(
const
chapter_item_c
&
edition
);
void
Append
(
const
chapter_item_c
&
edition
);
chapter_item_c
*
FindChapter
(
int64_t
i_find_uid
);
chapter_item_c
*
FindChapter
(
int64_t
i_find_uid
);
virtual
chapter_item_c
*
BrowseCodecPrivate
(
unsigned
int
codec_id
,
virtual
chapter_item_c
*
BrowseCodecPrivate
(
unsigned
int
codec_id
,
...
@@ -966,6 +966,7 @@ public:
...
@@ -966,6 +966,7 @@ public:
void
RefreshChapters
(
);
void
RefreshChapters
(
);
mtime_t
Duration
()
const
;
mtime_t
Duration
()
const
;
std
::
string
GetMainName
()
const
;
std
::
string
GetMainName
()
const
;
chapter_item_c
*
FindTimecode
(
mtime_t
i_timecode
,
const
chapter_item_c
*
p_current
);
bool
b_ordered
;
bool
b_ordered
;
};
};
...
@@ -2760,7 +2761,7 @@ bool virtual_segment_c::UpdateCurrentToChapter( demux_t & demux )
...
@@ -2760,7 +2761,7 @@ bool virtual_segment_c::UpdateCurrentToChapter( demux_t & demux )
if
(
p_editions
->
size
()
)
if
(
p_editions
->
size
()
)
{
{
/* 1st, we need to know in which chapter we are */
/* 1st, we need to know in which chapter we are */
psz_curr_chapter
=
(
*
p_editions
)[
i_current_edition
]
->
FindTimecode
(
sys
.
i_pts
);
psz_curr_chapter
=
(
*
p_editions
)[
i_current_edition
]
->
FindTimecode
(
sys
.
i_pts
,
psz_current_chapter
);
/* we have moved to a new chapter */
/* we have moved to a new chapter */
if
(
psz_curr_chapter
!=
NULL
&&
psz_current_chapter
!=
psz_curr_chapter
)
if
(
psz_curr_chapter
!=
NULL
&&
psz_current_chapter
!=
psz_curr_chapter
)
...
@@ -4764,18 +4765,29 @@ mtime_t chapter_edition_c::Duration() const
...
@@ -4764,18 +4765,29 @@ mtime_t chapter_edition_c::Duration() const
return
i_result
;
return
i_result
;
}
}
chapter_item_c
*
chapter_item_c
::
FindTimecode
(
mtime_t
i_user_timecode
)
chapter_item_c
*
chapter_edition_c
::
FindTimecode
(
mtime_t
i_timecode
,
const
chapter_item_c
*
p_current
)
{
if
(
!
b_ordered
)
p_current
=
NULL
;
bool
b_found_current
=
false
;
return
chapter_item_c
::
FindTimecode
(
i_timecode
,
p_current
,
b_found_current
);
}
chapter_item_c
*
chapter_item_c
::
FindTimecode
(
mtime_t
i_user_timecode
,
const
chapter_item_c
*
p_current
,
bool
&
b_found
)
{
{
chapter_item_c
*
psz_result
=
NULL
;
chapter_item_c
*
psz_result
=
NULL
;
if
(
p_current
==
this
)
b_found
=
true
;
if
(
i_user_timecode
>=
i_user_start_time
&&
if
(
i_user_timecode
>=
i_user_start_time
&&
(
i_user_timecode
<
i_user_end_time
||
(
i_user_timecode
<
i_user_end_time
||
(
i_user_start_time
==
i_user_end_time
&&
i_user_timecode
==
i_user_end_time
)))
(
i_user_start_time
==
i_user_end_time
&&
i_user_timecode
==
i_user_end_time
)))
{
{
std
::
vector
<
chapter_item_c
*>::
iterator
index
=
sub_chapters
.
begin
();
std
::
vector
<
chapter_item_c
*>::
iterator
index
=
sub_chapters
.
begin
();
while
(
index
!=
sub_chapters
.
end
()
&&
psz_result
==
NULL
)
while
(
index
!=
sub_chapters
.
end
()
&&
((
p_current
==
NULL
&&
psz_result
==
NULL
)
||
(
p_current
!=
NULL
&&
(
!
b_found
||
psz_result
==
NULL
)))
)
{
{
psz_result
=
(
*
index
)
->
FindTimecode
(
i_user_timecode
);
psz_result
=
(
*
index
)
->
FindTimecode
(
i_user_timecode
,
p_current
,
b_found
);
index
++
;
index
++
;
}
}
...
@@ -5293,7 +5305,7 @@ void virtual_segment_c::Seek( demux_t & demuxer, mtime_t i_date, mtime_t i_time_
...
@@ -5293,7 +5305,7 @@ void virtual_segment_c::Seek( demux_t & demuxer, mtime_t i_date, mtime_t i_time_
if
(
Edition
()
&&
Edition
()
->
b_ordered
)
if
(
Edition
()
&&
Edition
()
->
b_ordered
)
{
{
/* 1st, we need to know in which chapter we are */
/* 1st, we need to know in which chapter we are */
psz_chapter
=
(
*
p_editions
)[
i_current_edition
]
->
FindTimecode
(
i_date
);
psz_chapter
=
(
*
p_editions
)[
i_current_edition
]
->
FindTimecode
(
i_date
,
psz_current_chapter
);
}
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment