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
b82f5755
Commit
b82f5755
authored
Aug 12, 2013
by
Rafaël Carré
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bluray: cosmetics
parent
1cf7e446
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
214 additions
and
216 deletions
+214
-216
modules/access/bluray.c
modules/access/bluray.c
+214
-216
No files found.
modules/access/bluray.c
View file @
b82f5755
...
@@ -235,9 +235,9 @@ static int blurayOpen( vlc_object_t *object )
...
@@ -235,9 +235,9 @@ static int blurayOpen( vlc_object_t *object )
/* */
/* */
p_demux
->
p_sys
=
p_sys
=
calloc
(
1
,
sizeof
(
*
p_sys
));
p_demux
->
p_sys
=
p_sys
=
calloc
(
1
,
sizeof
(
*
p_sys
));
if
(
unlikely
(
!
p_sys
))
{
if
(
unlikely
(
!
p_sys
))
return
VLC_ENOMEM
;
return
VLC_ENOMEM
;
}
p_sys
->
current_overlay
=
-
1
;
p_sys
->
current_overlay
=
-
1
;
p_sys
->
i_audio_stream
=
-
1
;
p_sys
->
i_audio_stream
=
-
1
;
p_sys
->
i_video_stream
=
-
1
;
p_sys
->
i_video_stream
=
-
1
;
...
@@ -363,9 +363,8 @@ static int blurayOpen( vlc_object_t *object )
...
@@ -363,9 +363,8 @@ static int blurayOpen( vlc_object_t *object )
vlc_array_init
(
&
p_sys
->
es
);
vlc_array_init
(
&
p_sys
->
es
);
p_sys
->
p_out
=
esOutNew
(
p_demux
);
p_sys
->
p_out
=
esOutNew
(
p_demux
);
if
(
unlikely
(
p_sys
->
p_out
==
NULL
))
{
if
(
unlikely
(
p_sys
->
p_out
==
NULL
))
goto
error
;
goto
error
;
}
blurayResetParser
(
p_demux
);
blurayResetParser
(
p_demux
);
if
(
!
p_sys
->
p_parser
)
{
if
(
!
p_sys
->
p_parser
)
{
...
@@ -404,8 +403,8 @@ static void blurayClose( vlc_object_t *object )
...
@@ -404,8 +403,8 @@ static void blurayClose( vlc_object_t *object )
bd_close
(
p_sys
->
bluray
);
bd_close
(
p_sys
->
bluray
);
if
(
p_sys
->
p_vout
!=
NULL
)
{
if
(
p_sys
->
p_vout
!=
NULL
)
{
var_DelCallback
(
p_sys
->
p_vout
,
"mouse-moved"
,
&
onMouseEvent
,
p_demux
);
var_DelCallback
(
p_sys
->
p_vout
,
"mouse-moved"
,
onMouseEvent
,
p_demux
);
var_DelCallback
(
p_sys
->
p_vout
,
"mouse-clicked"
,
&
onMouseEvent
,
p_demux
);
var_DelCallback
(
p_sys
->
p_vout
,
"mouse-clicked"
,
onMouseEvent
,
p_demux
);
vlc_object_release
(
p_sys
->
p_vout
);
vlc_object_release
(
p_sys
->
p_vout
);
}
}
if
(
p_sys
->
p_input
!=
NULL
)
if
(
p_sys
->
p_input
!=
NULL
)
...
@@ -532,11 +531,11 @@ static es_out_t *esOutNew( demux_t *p_demux )
...
@@ -532,11 +531,11 @@ static es_out_t *esOutNew( demux_t *p_demux )
if
(
unlikely
(
p_out
==
NULL
)
)
if
(
unlikely
(
p_out
==
NULL
)
)
return
NULL
;
return
NULL
;
p_out
->
pf_add
=
&
esOutAdd
;
p_out
->
pf_add
=
esOutAdd
;
p_out
->
pf_control
=
&
esOutControl
;
p_out
->
pf_control
=
esOutControl
;
p_out
->
pf_del
=
&
esOutDel
;
p_out
->
pf_del
=
esOutDel
;
p_out
->
pf_destroy
=
&
esOutDestroy
;
p_out
->
pf_destroy
=
esOutDestroy
;
p_out
->
pf_send
=
&
esOutSend
;
p_out
->
pf_send
=
esOutSend
;
p_out
->
p_sys
=
malloc
(
sizeof
(
*
p_out
->
p_sys
)
);
p_out
->
p_sys
=
malloc
(
sizeof
(
*
p_out
->
p_sys
)
);
if
(
unlikely
(
p_out
->
p_sys
==
NULL
)
)
{
if
(
unlikely
(
p_out
->
p_sys
==
NULL
)
)
{
...
@@ -624,12 +623,12 @@ static void subpictureUpdaterUpdate(subpicture_t *p_subpic,
...
@@ -624,12 +623,12 @@ static void subpictureUpdaterUpdate(subpicture_t *p_subpic,
return
;
return
;
}
}
subpicture_region_t
**
p_dst
=
&
(
p_subpic
->
p_region
)
;
subpicture_region_t
**
p_dst
=
&
p_subpic
->
p_region
;
while
(
p_src
!=
NULL
)
{
while
(
p_src
!=
NULL
)
{
*
p_dst
=
subpicture_region_Clone
(
p_src
);
*
p_dst
=
subpicture_region_Clone
(
p_src
);
if
(
*
p_dst
==
NULL
)
if
(
*
p_dst
==
NULL
)
break
;
break
;
p_dst
=
&
(
(
*
p_dst
)
->
p_next
)
;
p_dst
=
&
(
*
p_dst
)
->
p_next
;
p_src
=
p_src
->
p_next
;
p_src
=
p_src
->
p_next
;
}
}
if
(
*
p_dst
!=
NULL
)
if
(
*
p_dst
!=
NULL
)
...
@@ -847,7 +846,7 @@ static void blurayDrawOverlay(demux_t *p_demux, const BD_OVERLAY* const ov)
...
@@ -847,7 +846,7 @@ static void blurayDrawOverlay(demux_t *p_demux, const BD_OVERLAY* const ov)
/* Now we can update the region, regardless it's an update or an insert */
/* Now we can update the region, regardless it's an update or an insert */
const
BD_PG_RLE_ELEM
*
img
=
ov
->
img
;
const
BD_PG_RLE_ELEM
*
img
=
ov
->
img
;
for
(
int
y
=
0
;
y
<
ov
->
h
;
y
++
)
{
for
(
int
y
=
0
;
y
<
ov
->
h
;
y
++
)
for
(
int
x
=
0
;
x
<
ov
->
w
;)
{
for
(
int
x
=
0
;
x
<
ov
->
w
;)
{
memset
(
p_reg
->
p_picture
->
p
[
0
].
p_pixels
+
memset
(
p_reg
->
p_picture
->
p
[
0
].
p_pixels
+
y
*
p_reg
->
p_picture
->
p
[
0
].
i_pitch
+
x
,
y
*
p_reg
->
p_picture
->
p
[
0
].
i_pitch
+
x
,
...
@@ -855,7 +854,7 @@ static void blurayDrawOverlay(demux_t *p_demux, const BD_OVERLAY* const ov)
...
@@ -855,7 +854,7 @@ static void blurayDrawOverlay(demux_t *p_demux, const BD_OVERLAY* const ov)
x
+=
img
->
len
;
x
+=
img
->
len
;
img
++
;
img
++
;
}
}
}
if
(
ov
->
palette
)
{
if
(
ov
->
palette
)
{
p_reg
->
fmt
.
p_palette
->
i_entries
=
256
;
p_reg
->
fmt
.
p_palette
->
i_entries
=
256
;
for
(
int
i
=
0
;
i
<
256
;
++
i
)
{
for
(
int
i
=
0
;
i
<
256
;
++
i
)
{
...
@@ -865,6 +864,7 @@ static void blurayDrawOverlay(demux_t *p_demux, const BD_OVERLAY* const ov)
...
@@ -865,6 +864,7 @@ static void blurayDrawOverlay(demux_t *p_demux, const BD_OVERLAY* const ov)
p_reg
->
fmt
.
p_palette
->
palette
[
i
][
3
]
=
ov
->
palette
[
i
].
T
;
p_reg
->
fmt
.
p_palette
->
palette
[
i
][
3
]
=
ov
->
palette
[
i
].
T
;
}
}
}
}
vlc_mutex_unlock
(
&
p_sys
->
p_overlays
[
ov
->
plane
]
->
lock
);
vlc_mutex_unlock
(
&
p_sys
->
p_overlays
[
ov
->
plane
]
->
lock
);
/*
/*
* /!\ The region is now stored in our internal list, but not in the subpicture /!\
* /!\ The region is now stored in our internal list, but not in the subpicture /!\
...
@@ -880,6 +880,7 @@ static void blurayOverlayProc(void *ptr, const BD_OVERLAY *const overlay)
...
@@ -880,6 +880,7 @@ static void blurayOverlayProc(void *ptr, const BD_OVERLAY *const overlay)
blurayCloseAllOverlays
(
p_demux
);
blurayCloseAllOverlays
(
p_demux
);
return
;
return
;
}
}
switch
(
overlay
->
cmd
)
{
switch
(
overlay
->
cmd
)
{
case
BD_OVERLAY_INIT
:
case
BD_OVERLAY_INIT
:
msg_Info
(
p_demux
,
"Initializing overlay"
);
msg_Info
(
p_demux
,
"Initializing overlay"
);
...
@@ -1059,10 +1060,11 @@ static void blurayResetParser( demux_t *p_demux )
...
@@ -1059,10 +1060,11 @@ static void blurayResetParser( demux_t *p_demux )
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
if
(
p_sys
->
p_parser
)
if
(
p_sys
->
p_parser
)
stream_Delete
(
p_sys
->
p_parser
);
stream_Delete
(
p_sys
->
p_parser
);
p_sys
->
p_parser
=
stream_DemuxNew
(
p_demux
,
"ts"
,
p_sys
->
p_out
);
p_sys
->
p_parser
=
stream_DemuxNew
(
p_demux
,
"ts"
,
p_sys
->
p_out
);
if
(
!
p_sys
->
p_parser
)
{
if
(
!
p_sys
->
p_parser
)
msg_Err
(
p_demux
,
"Failed to create TS demuxer"
);
msg_Err
(
p_demux
,
"Failed to create TS demuxer"
);
}
}
}
static
void
blurayUpdateTitle
(
demux_t
*
p_demux
,
unsigned
i_title
)
static
void
blurayUpdateTitle
(
demux_t
*
p_demux
,
unsigned
i_title
)
...
@@ -1092,7 +1094,6 @@ static int bluraySetTitle(demux_t *p_demux, int i_title)
...
@@ -1092,7 +1094,6 @@ static int bluraySetTitle(demux_t *p_demux, int i_title)
msg_Dbg
(
p_demux
,
"Selecting Title %i"
,
i_title
);
msg_Dbg
(
p_demux
,
"Selecting Title %i"
,
i_title
);
/* Select Blu-Ray title */
if
(
bd_select_title
(
p_demux
->
p_sys
->
bluray
,
i_title
)
==
0
)
{
if
(
bd_select_title
(
p_demux
->
p_sys
->
bluray
,
i_title
)
==
0
)
{
msg_Err
(
p_demux
,
"cannot select bd title '%d'"
,
p_demux
->
info
.
i_title
);
msg_Err
(
p_demux
,
"cannot select bd title '%d'"
,
p_demux
->
info
.
i_title
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
...
@@ -1102,7 +1103,6 @@ static int bluraySetTitle(demux_t *p_demux, int i_title)
...
@@ -1102,7 +1103,6 @@ static int bluraySetTitle(demux_t *p_demux, int i_title)
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
/*****************************************************************************
/*****************************************************************************
* blurayControl: handle the controls
* blurayControl: handle the controls
*****************************************************************************/
*****************************************************************************/
...
@@ -1122,8 +1122,7 @@ static int blurayControl(demux_t *p_demux, int query, va_list args)
...
@@ -1122,8 +1122,7 @@ static int blurayControl(demux_t *p_demux, int query, va_list args)
case
DEMUX_GET_PTS_DELAY
:
case
DEMUX_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
*
pi_64
=
*
pi_64
=
INT64_C
(
1000
)
*
var_InheritInteger
(
p_demux
,
"disc-caching"
);
INT64_C
(
1000
)
*
var_InheritInteger
(
p_demux
,
"disc-caching"
);
break
;
break
;
case
DEMUX_SET_PAUSE_STATE
:
case
DEMUX_SET_PAUSE_STATE
:
...
@@ -1158,9 +1157,9 @@ static int blurayControl(demux_t *p_demux, int query, va_list args)
...
@@ -1158,9 +1157,9 @@ static int blurayControl(demux_t *p_demux, int query, va_list args)
/* Duplicate local title infos */
/* Duplicate local title infos */
*
pi_int
=
p_sys
->
i_title
;
*
pi_int
=
p_sys
->
i_title
;
*
ppp_title
=
calloc
(
p_sys
->
i_title
,
sizeof
(
input_title_t
**
)
);
*
ppp_title
=
malloc
(
p_sys
->
i_title
*
sizeof
(
input_title_t
**
)
);
for
(
unsigned
int
i
=
0
;
i
<
p_sys
->
i_title
;
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
p_sys
->
i_title
;
i
++
)
(
*
ppp_title
)[
i
]
=
vlc_input_title_Duplicate
(
p_sys
->
pp_title
[
i
]);
(
*
ppp_title
)[
i
]
=
vlc_input_title_Duplicate
(
p_sys
->
pp_title
[
i
]);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
...
@@ -1289,24 +1288,22 @@ static void blurayHandleEvent( demux_t *p_demux, const BD_EVENT *e )
...
@@ -1289,24 +1288,22 @@ static void blurayHandleEvent( demux_t *p_demux, const BD_EVENT *e )
blurayUpdateCurrentClip
(
p_demux
,
e
->
param
);
blurayUpdateCurrentClip
(
p_demux
,
e
->
param
);
break
;
break
;
case
BD_EVENT_AUDIO_STREAM
:
case
BD_EVENT_AUDIO_STREAM
:
{
if
(
e
->
param
==
0xFF
)
if
(
e
->
param
==
0xFF
)
break
;
break
;
BLURAY_TITLE_INFO
*
info
=
bd_get_title_info
(
p_sys
->
bluray
,
BLURAY_TITLE_INFO
*
info
=
bd_get_title_info
(
p_sys
->
bluray
,
bd_get_current_title
(
p_sys
->
bluray
),
0
);
bd_get_current_title
(
p_sys
->
bluray
),
0
);
if
(
info
==
NULL
)
if
(
info
==
NULL
)
break
;
break
;
/* The param we get is the real stream id, not an index, ie. it starts from 1 */
/* The param we get is the real stream id, not an index, ie. it starts from 1 */
int
pid
=
info
->
clips
[
p_sys
->
i_current_clip
].
audio_streams
[
e
->
param
-
1
].
pid
;
int
pid
=
info
->
clips
[
p_sys
->
i_current_clip
].
audio_streams
[
e
->
param
-
1
].
pid
;
int
idx
=
findEsPairIndex
(
p_sys
,
pid
);
int
idx
=
findEsPairIndex
(
p_sys
,
pid
);
if
(
idx
>=
0
)
{
if
(
idx
>=
0
)
{
es_out_id_t
*
p_es
=
vlc_array_item_at_index
(
&
p_sys
->
es
,
idx
);
es_out_id_t
*
p_es
=
vlc_array_item_at_index
(
&
p_sys
->
es
,
idx
);
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_ES
,
p_es
);
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_ES
,
p_es
);
}
}
bd_free_title_info
(
info
);
bd_free_title_info
(
info
);
p_sys
->
i_audio_stream
=
pid
;
p_sys
->
i_audio_stream
=
pid
;
break
;
break
;
}
case
BD_EVENT_CHAPTER
:
case
BD_EVENT_CHAPTER
:
p_demux
->
info
.
i_update
|=
INPUT_UPDATE_SEEKPOINT
;
p_demux
->
info
.
i_update
|=
INPUT_UPDATE_SEEKPOINT
;
p_demux
->
info
.
i_seekpoint
=
e
->
param
;
p_demux
->
info
.
i_seekpoint
=
e
->
param
;
...
@@ -1314,7 +1311,7 @@ static void blurayHandleEvent( demux_t *p_demux, const BD_EVENT *e )
...
@@ -1314,7 +1311,7 @@ static void blurayHandleEvent( demux_t *p_demux, const BD_EVENT *e )
case
BD_EVENT_ANGLE
:
case
BD_EVENT_ANGLE
:
case
BD_EVENT_IG_STREAM
:
case
BD_EVENT_IG_STREAM
:
default:
default:
msg_Warn
(
p_demux
,
"event: %d param: %d"
,
e
->
event
,
e
->
param
);
msg_Warn
(
p_demux
,
"event: %d param: %d"
,
e
->
event
,
e
->
param
);
break
;
break
;
}
}
}
}
...
@@ -1367,6 +1364,7 @@ static int blurayDemux(demux_t *p_demux)
...
@@ -1367,6 +1364,7 @@ static int blurayDemux(demux_t *p_demux)
block_Release
(
p_block
);
block_Release
(
p_block
);
return
1
;
return
1
;
}
}
if
(
p_sys
->
current_overlay
!=
-
1
)
{
if
(
p_sys
->
current_overlay
!=
-
1
)
{
vlc_mutex_lock
(
&
p_sys
->
p_overlays
[
p_sys
->
current_overlay
]
->
lock
);
vlc_mutex_lock
(
&
p_sys
->
p_overlays
[
p_sys
->
current_overlay
]
->
lock
);
if
(
p_sys
->
p_overlays
[
p_sys
->
current_overlay
]
->
status
==
ToDisplay
)
{
if
(
p_sys
->
p_overlays
[
p_sys
->
current_overlay
]
->
status
==
ToDisplay
)
{
...
@@ -1374,8 +1372,8 @@ static int blurayDemux(demux_t *p_demux)
...
@@ -1374,8 +1372,8 @@ static int blurayDemux(demux_t *p_demux)
if
(
p_sys
->
p_vout
==
NULL
)
if
(
p_sys
->
p_vout
==
NULL
)
p_sys
->
p_vout
=
input_GetVout
(
p_sys
->
p_input
);
p_sys
->
p_vout
=
input_GetVout
(
p_sys
->
p_input
);
if
(
p_sys
->
p_vout
!=
NULL
)
{
if
(
p_sys
->
p_vout
!=
NULL
)
{
var_AddCallback
(
p_sys
->
p_vout
,
"mouse-moved"
,
&
onMouseEvent
,
p_demux
);
var_AddCallback
(
p_sys
->
p_vout
,
"mouse-moved"
,
onMouseEvent
,
p_demux
);
var_AddCallback
(
p_sys
->
p_vout
,
"mouse-clicked"
,
&
onMouseEvent
,
p_demux
);
var_AddCallback
(
p_sys
->
p_vout
,
"mouse-clicked"
,
onMouseEvent
,
p_demux
);
bluraySendOverlayToVout
(
p_demux
);
bluraySendOverlayToVout
(
p_demux
);
}
}
}
else
}
else
...
...
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