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
26b8ba09
Commit
26b8ba09
authored
Feb 21, 2005
by
Steve Lhomme
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mkv.cpp: prepare code for multiple editions and ordered editions
parent
0b609fa4
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
79 additions
and
11 deletions
+79
-11
modules/demux/mkv.cpp
modules/demux/mkv.cpp
+79
-11
No files found.
modules/demux/mkv.cpp
View file @
26b8ba09
...
@@ -315,6 +315,29 @@ typedef struct
...
@@ -315,6 +315,29 @@ typedef struct
vlc_bool_t
b_key
;
vlc_bool_t
b_key
;
}
mkv_index_t
;
}
mkv_index_t
;
class
chapter_item_t
{
public:
int64_t
i_start_time
,
i_end_time
;
int64_t
i_absolute_start_time
;
/* the time in the stream when an edition is ordered */
std
::
vector
<
chapter_item_t
>
sub_chapters
;
int
i_current_sub_chapter
;
int
i_seekpoint_num
;
};
class
chapter_edition_t
{
public:
chapter_edition_t
()
:
i_uid
(
-
1
)
,
b_ordered
(
false
)
{}
std
::
vector
<
chapter_item_t
>
chapters
;
int64_t
i_uid
;
bool
b_ordered
;
};
class
demux_sys_t
class
demux_sys_t
{
{
public:
public:
...
@@ -344,6 +367,7 @@ public:
...
@@ -344,6 +367,7 @@ public:
,
psz_date_utc
(
NULL
)
,
psz_date_utc
(
NULL
)
,
meta
(
NULL
)
,
meta
(
NULL
)
,
title
(
NULL
)
,
title
(
NULL
)
,
i_current_edition
(
0
)
{}
{}
vlc_stream_io_callback
*
in
;
vlc_stream_io_callback
*
in
;
...
@@ -392,8 +416,8 @@ public:
...
@@ -392,8 +416,8 @@ public:
std
::
vector
<
KaxSegmentFamily
>
families
;
std
::
vector
<
KaxSegmentFamily
>
families
;
std
::
vector
<
KaxSegment
*>
family_members
;
std
::
vector
<
KaxSegment
*>
family_members
;
int64_t
edition_uid
;
std
::
vector
<
chapter_edition_t
>
editions
;
bool
edition_ordered
;
int
i_current_edition
;
};
};
#define MKVD_TIMECODESCALE 1000000
#define MKVD_TIMECODESCALE 1000000
...
@@ -1145,6 +1169,7 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -1145,6 +1169,7 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
Seek
(
p_demux
,
(
int64_t
)
p_sys
->
title
->
seekpoint
[
i_skp
]
->
i_time_offset
,
-
1
);
Seek
(
p_demux
,
(
int64_t
)
p_sys
->
title
->
seekpoint
[
i_skp
]
->
i_time_offset
,
-
1
);
p_demux
->
info
.
i_seekpoint
|=
INPUT_UPDATE_SEEKPOINT
;
p_demux
->
info
.
i_seekpoint
|=
INPUT_UPDATE_SEEKPOINT
;
p_demux
->
info
.
i_seekpoint
=
i_skp
;
p_demux
->
info
.
i_seekpoint
=
i_skp
;
/* p_sys->i_current_chapter = i_skp;*/
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
...
@@ -1392,6 +1417,19 @@ static void BlockDecode( demux_t *p_demux, KaxBlock *block, mtime_t i_pts,
...
@@ -1392,6 +1417,19 @@ static void BlockDecode( demux_t *p_demux, KaxBlock *block, mtime_t i_pts,
#undef tk
#undef tk
}
}
static
void
UpdateCurrentChapter
()
{
/* update current chapter/seekpoint */
#ifdef TODO
i_chapter
if
(
p_sys
->
title
->
seekpoint
[
i_skp
]
->
i_time_offset
)
{
p_demux
->
info
.
i_update
|=
INPUT_UPDATE_SEEKPOINT
;
p_demux
->
info
.
i_seekpoint
=
i_chapter
;
}
#endif
}
static
void
Seek
(
demux_t
*
p_demux
,
mtime_t
i_date
,
double
f_percent
)
static
void
Seek
(
demux_t
*
p_demux
,
mtime_t
i_date
,
double
f_percent
)
{
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
...
@@ -1565,6 +1603,7 @@ static int Demux( demux_t *p_demux)
...
@@ -1565,6 +1603,7 @@ static int Demux( demux_t *p_demux)
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
mtime_t
i_start_pts
;
mtime_t
i_start_pts
;
int
i_block_count
=
0
;
int
i_block_count
=
0
;
int
i_chapter
;
KaxBlock
*
block
;
KaxBlock
*
block
;
int64_t
i_block_duration
;
int64_t
i_block_duration
;
...
@@ -1575,6 +1614,15 @@ static int Demux( demux_t *p_demux)
...
@@ -1575,6 +1614,15 @@ static int Demux( demux_t *p_demux)
for
(
;;
)
for
(
;;
)
{
{
if
(
p_sys
->
editions
[
p_sys
->
i_current_edition
].
b_ordered
)
{
/* 1st, we need to know in which chapter we are */
/* check if we need to silently seek to a new location in the stream */
/* count the last duration time found for each track in a table (-1 not found, -2 silent) */
/* only seek after each duration >= end timecode of the current chapter */
}
if
(
BlockGet
(
p_demux
,
&
block
,
&
i_block_ref1
,
&
i_block_ref2
,
&
i_block_duration
)
)
if
(
BlockGet
(
p_demux
,
&
block
,
&
i_block_ref1
,
&
i_block_ref2
,
&
i_block_duration
)
)
{
{
msg_Warn
(
p_demux
,
"cannot get block EOF?"
);
msg_Warn
(
p_demux
,
"cannot get block EOF?"
);
...
@@ -1591,6 +1639,8 @@ static int Demux( demux_t *p_demux)
...
@@ -1591,6 +1639,8 @@ static int Demux( demux_t *p_demux)
BlockDecode
(
p_demux
,
block
,
p_sys
->
i_pts
,
i_block_duration
);
BlockDecode
(
p_demux
,
block
,
p_sys
->
i_pts
,
i_block_duration
);
UpdateCurrentChapter
();
delete
block
;
delete
block
;
i_block_count
++
;
i_block_count
++
;
...
@@ -2653,7 +2703,7 @@ static void ParseInfo( demux_t *p_demux, EbmlElement *info )
...
@@ -2653,7 +2703,7 @@ static void ParseInfo( demux_t *p_demux, EbmlElement *info )
/*****************************************************************************
/*****************************************************************************
* ParseChapterAtom
* ParseChapterAtom
*****************************************************************************/
*****************************************************************************/
static
void
ParseChapterAtom
(
demux_t
*
p_demux
,
int
i_level
,
EbmlMaster
*
ca
)
static
void
ParseChapterAtom
(
demux_t
*
p_demux
,
int
i_level
,
EbmlMaster
*
ca
,
chapter_item_t
&
chapters
)
{
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
unsigned
int
i
;
unsigned
int
i
;
...
@@ -2741,7 +2791,9 @@ static void ParseChapterAtom( demux_t *p_demux, int i_level, EbmlMaster *ca )
...
@@ -2741,7 +2791,9 @@ static void ParseChapterAtom( demux_t *p_demux, int i_level, EbmlMaster *ca )
}
}
else
if
(
MKV_IS_ID
(
l
,
KaxChapterAtom
)
)
else
if
(
MKV_IS_ID
(
l
,
KaxChapterAtom
)
)
{
{
ParseChapterAtom
(
p_demux
,
i_level
+
1
,
static_cast
<
EbmlMaster
*>
(
l
)
);
chapter_item_t
new_sub_chapter
;
ParseChapterAtom
(
p_demux
,
i_level
+
1
,
static_cast
<
EbmlMaster
*>
(
l
),
new_sub_chapter
);
chapters
.
sub_chapters
.
push_back
(
new_sub_chapter
);
}
}
}
}
...
@@ -2768,7 +2820,7 @@ static void ParseChapters( demux_t *p_demux, EbmlElement *chapters )
...
@@ -2768,7 +2820,7 @@ static void ParseChapters( demux_t *p_demux, EbmlElement *chapters )
EbmlMaster
*
m
;
EbmlMaster
*
m
;
unsigned
int
i
;
unsigned
int
i
;
int
i_upper_level
=
0
;
int
i_upper_level
=
0
;
int
i_default_edition
=
0
;
/* Master elements */
/* Master elements */
m
=
static_cast
<
EbmlMaster
*>
(
chapters
);
m
=
static_cast
<
EbmlMaster
*>
(
chapters
);
...
@@ -2780,37 +2832,53 @@ static void ParseChapters( demux_t *p_demux, EbmlElement *chapters )
...
@@ -2780,37 +2832,53 @@ static void ParseChapters( demux_t *p_demux, EbmlElement *chapters )
if
(
MKV_IS_ID
(
l
,
KaxEditionEntry
)
)
if
(
MKV_IS_ID
(
l
,
KaxEditionEntry
)
)
{
{
chapter_edition_t
edition
;
EbmlMaster
*
E
=
static_cast
<
EbmlMaster
*>
(
l
);
EbmlMaster
*
E
=
static_cast
<
EbmlMaster
*>
(
l
);
unsigned
int
j
;
unsigned
int
j
;
msg_Dbg
(
p_demux
,
"| | + EditionEntry"
);
msg_Dbg
(
p_demux
,
"| | + EditionEntry"
);
p_sys
->
edition_ordered
=
false
;
for
(
j
=
0
;
j
<
E
->
ListSize
();
j
++
)
for
(
j
=
0
;
j
<
E
->
ListSize
();
j
++
)
{
{
EbmlElement
*
l
=
(
*
E
)[
j
];
EbmlElement
*
l
=
(
*
E
)[
j
];
if
(
MKV_IS_ID
(
l
,
KaxChapterAtom
)
)
if
(
MKV_IS_ID
(
l
,
KaxChapterAtom
)
)
{
{
ParseChapterAtom
(
p_demux
,
0
,
static_cast
<
EbmlMaster
*>
(
l
)
);
chapter_item_t
new_sub_chapter
;
ParseChapterAtom
(
p_demux
,
0
,
static_cast
<
EbmlMaster
*>
(
l
),
new_sub_chapter
);
edition
.
chapters
.
push_back
(
new_sub_chapter
);
}
}
else
if
(
MKV_IS_ID
(
l
,
KaxEditionUID
)
)
else
if
(
MKV_IS_ID
(
l
,
KaxEditionUID
)
)
{
{
p_sys
->
edition
_uid
=
uint64
(
*
static_cast
<
KaxEditionUID
*>
(
l
));
edition
.
i
_uid
=
uint64
(
*
static_cast
<
KaxEditionUID
*>
(
l
));
}
}
else
if
(
MKV_IS_ID
(
l
,
KaxEditionFlagOrdered
)
)
else
if
(
MKV_IS_ID
(
l
,
KaxEditionFlagOrdered
)
)
{
{
p_sys
->
edition_ordered
=
uint8
(
*
static_cast
<
KaxEditionFlagOrdered
*>
(
l
))
!=
0
;
edition
.
b_ordered
=
uint8
(
*
static_cast
<
KaxEditionFlagOrdered
*>
(
l
))
!=
0
;
}
else
if
(
MKV_IS_ID
(
l
,
KaxEditionFlagDefault
)
)
{
if
(
uint8
(
*
static_cast
<
KaxEditionFlagDefault
*>
(
l
))
!=
0
)
p_sys
->
i_current_edition
=
p_sys
->
editions
.
size
();
}
}
else
else
{
{
msg_Dbg
(
p_demux
,
"| | | + Unknown (%s)"
,
typeid
(
*
l
).
name
()
);
msg_Dbg
(
p_demux
,
"| | | + Unknown (%s)"
,
typeid
(
*
l
).
name
()
);
}
}
}
}
p_sys
->
editions
.
push_back
(
edition
);
}
}
else
else
{
{
msg_Dbg
(
p_demux
,
"| | + Unknown (%s)"
,
typeid
(
*
l
).
name
()
);
msg_Dbg
(
p_demux
,
"| | + Unknown (%s)"
,
typeid
(
*
l
).
name
()
);
}
}
}
}
p_sys
->
i_current_edition
=
i_default_edition
;
if
(
p_sys
->
editions
[
i_default_edition
].
b_ordered
)
{
/* update the duration of the segment according to the sum of all sub chapters */
}
}
}
/*****************************************************************************
/*****************************************************************************
...
...
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