Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
117ba20f
Commit
117ba20f
authored
Jun 23, 2004
by
Gildas Bazin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* modules/demux/dvdnav.c: work-around for libdvdnav cvs + a few coding style changes.
parent
92a32ce7
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
57 additions
and
53 deletions
+57
-53
modules/demux/dvdnav.c
modules/demux/dvdnav.c
+57
-53
No files found.
modules/demux/dvdnav.c
View file @
117ba20f
...
@@ -130,11 +130,6 @@ enum
...
@@ -130,11 +130,6 @@ enum
AR_221_1_PICTURE
=
4
,
/* 2.21:1 picture (movie) */
AR_221_1_PICTURE
=
4
,
/* 2.21:1 picture (movie) */
};
};
#if 0
static int MenusCallback( vlc_object_t *, char const *,
vlc_value_t, vlc_value_t, void * );
#endif
static
void
DemuxTitles
(
demux_t
*
p_demux
);
static
void
DemuxTitles
(
demux_t
*
p_demux
);
static
void
ESSubtitleUpdate
(
demux_t
*
);
static
void
ESSubtitleUpdate
(
demux_t
*
);
static
void
ButtonUpdate
(
demux_t
*
);
static
void
ButtonUpdate
(
demux_t
*
);
...
@@ -189,6 +184,23 @@ static int Open( vlc_object_t *p_this )
...
@@ -189,6 +184,23 @@ static int Open( vlc_object_t *p_this )
}
}
free
(
psz_name
);
free
(
psz_name
);
if
(
1
)
{
// Hack for libdvdnav CVS.
// Without it dvdnav_get_number_of_titles() fails.
// Remove when fixed in libdvdnav CVS.
uint8_t
buffer
[
DVD_VIDEO_LB_LEN
];
int
i_event
,
i_len
;
if
(
dvdnav_get_next_block
(
p_sys
->
dvdnav
,
buffer
,
&
i_event
,
&
i_len
)
==
DVDNAV_STATUS_ERR
)
{
msg_Warn
(
p_demux
,
"dvdnav_get_next_block failed"
);
}
dvdnav_sector_search
(
p_sys
->
dvdnav
,
0
,
SEEK_SET
);
}
/* Configure dvdnav */
/* Configure dvdnav */
if
(
dvdnav_set_readahead_flag
(
p_sys
->
dvdnav
,
DVD_READ_CACHE
)
!=
if
(
dvdnav_set_readahead_flag
(
p_sys
->
dvdnav
,
DVD_READ_CACHE
)
!=
DVDNAV_STATUS_OK
)
DVDNAV_STATUS_OK
)
...
@@ -210,8 +222,6 @@ static int Open( vlc_object_t *p_this )
...
@@ -210,8 +222,6 @@ static int Open( vlc_object_t *p_this )
dvdnav_err_to_string
(
p_sys
->
dvdnav
)
);
dvdnav_err_to_string
(
p_sys
->
dvdnav
)
);
}
}
// FIXME: Doesn't work with libdvdnav CVS!
// Bah don't use CVS ;) --fenrir (anyway it's needed now)
DemuxTitles
(
p_demux
);
DemuxTitles
(
p_demux
);
/* Set forced title/chapter */
/* Set forced title/chapter */
...
@@ -231,7 +241,8 @@ static int Open( vlc_object_t *p_this )
...
@@ -231,7 +241,8 @@ static int Open( vlc_object_t *p_this )
if
(
i_chapter
!=
0
&&
i_title
!=
0
)
if
(
i_chapter
!=
0
&&
i_title
!=
0
)
{
{
if
(
dvdnav_part_play
(
p_sys
->
dvdnav
,
i_title
,
i_chapter
)
!=
DVDNAV_STATUS_OK
)
if
(
dvdnav_part_play
(
p_sys
->
dvdnav
,
i_title
,
i_chapter
)
!=
DVDNAV_STATUS_OK
)
{
{
msg_Warn
(
p_demux
,
"cannot set chapter"
);
msg_Warn
(
p_demux
,
"cannot set chapter"
);
i_chapter
=
0
;
i_chapter
=
0
;
...
@@ -249,7 +260,7 @@ static int Open( vlc_object_t *p_this )
...
@@ -249,7 +260,7 @@ static int Open( vlc_object_t *p_this )
/* For simple mode (no menus), we're done */
/* For simple mode (no menus), we're done */
if
(
p_sys
->
b_simple
)
return
VLC_SUCCESS
;
if
(
p_sys
->
b_simple
)
return
VLC_SUCCESS
;
/* FIXME hack hack hack hac
h
k FIXME */
/* FIXME hack hack hack hack FIXME */
/* Get p_input and create variable */
/* Get p_input and create variable */
p_sys
->
p_input
=
vlc_object_find
(
p_demux
,
VLC_OBJECT_INPUT
,
FIND_PARENT
);
p_sys
->
p_input
=
vlc_object_find
(
p_demux
,
VLC_OBJECT_INPUT
,
FIND_PARENT
);
var_Create
(
p_sys
->
p_input
,
"x-start"
,
VLC_VAR_INTEGER
);
var_Create
(
p_sys
->
p_input
,
"x-start"
,
VLC_VAR_INTEGER
);
...
@@ -345,7 +356,7 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -345,7 +356,7 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
case
DEMUX_SET_POSITION
:
case
DEMUX_SET_POSITION
:
{
{
uint32_t
pos
,
len
;
uint32_t
pos
,
len
;
f
=
(
double
)
va_arg
(
args
,
double
);
f
=
(
double
)
va_arg
(
args
,
double
);
if
(
dvdnav_get_position
(
p_sys
->
dvdnav
,
&
pos
,
&
len
)
==
if
(
dvdnav_get_position
(
p_sys
->
dvdnav
,
&
pos
,
&
len
)
==
DVDNAV_STATUS_OK
&&
len
>
0
)
DVDNAV_STATUS_OK
&&
len
>
0
)
{
{
...
@@ -386,8 +397,10 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -386,8 +397,10 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
case
DEMUX_SET_TITLE
:
case
DEMUX_SET_TITLE
:
i
=
(
int
)
va_arg
(
args
,
int
);
i
=
(
int
)
va_arg
(
args
,
int
);
if
(
(
i
==
0
&&
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Root
)
!=
DVDNAV_STATUS_OK
)
||
if
(
(
i
==
0
&&
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Root
)
(
i
!=
0
&&
dvdnav_title_play
(
p_sys
->
dvdnav
,
i
)
!=
DVDNAV_STATUS_OK
)
)
!=
DVDNAV_STATUS_OK
)
||
(
i
!=
0
&&
dvdnav_title_play
(
p_sys
->
dvdnav
,
i
)
!=
DVDNAV_STATUS_OK
)
)
{
{
msg_Warn
(
p_demux
,
"cannot set title/chapter"
);
msg_Warn
(
p_demux
,
"cannot set title/chapter"
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
...
@@ -405,34 +418,37 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -405,34 +418,37 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
/* Special case */
/* Special case */
switch
(
i
)
switch
(
i
)
{
{
case
0
:
case
0
:
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Escape
);
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Escape
);
break
;
break
;
case
1
:
case
1
:
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Root
);
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Root
);
break
;
break
;
case
2
:
case
2
:
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Title
);
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Title
);
break
;
break
;
case
3
:
case
3
:
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Part
);
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Part
);
break
;
break
;
case
4
:
case
4
:
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Subpicture
);
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
break
;
DVD_MENU_Subpicture
);
case
5
:
break
;
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Audio
);
case
5
:
break
;
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Audio
);
case
6
:
break
;
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Angle
);
case
6
:
break
;
i_ret
=
dvdnav_menu_call
(
p_sys
->
dvdnav
,
DVD_MENU_Angle
);
default:
break
;
return
VLC_EGENERIC
;
default:
return
VLC_EGENERIC
;
}
}
if
(
i_ret
!=
DVDNAV_STATUS_OK
)
if
(
i_ret
!=
DVDNAV_STATUS_OK
)
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
else
if
(
dvdnav_part_play
(
p_sys
->
dvdnav
,
p_demux
->
info
.
i_title
,
i
)
!=
DVDNAV_STATUS_OK
)
else
if
(
dvdnav_part_play
(
p_sys
->
dvdnav
,
p_demux
->
info
.
i_title
,
i
)
!=
DVDNAV_STATUS_OK
)
{
{
msg_Warn
(
p_demux
,
"cannot set title/chapter"
);
msg_Warn
(
p_demux
,
"cannot set title/chapter"
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
...
@@ -443,7 +459,7 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -443,7 +459,7 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
case
DEMUX_GET_PTS_DELAY
:
case
DEMUX_GET_PTS_DELAY
:
pi64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
pi64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
*
pi64
=
(
int64_t
)
var_GetInteger
(
p_demux
,
"dvdnav-caching"
)
*
I64C
(
1000
)
;
*
pi64
=
(
int64_t
)
var_GetInteger
(
p_demux
,
"dvdnav-caching"
)
*
1000
;
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
/* TODO implement others */
/* TODO implement others */
...
@@ -479,9 +495,11 @@ static int Demux( demux_t *p_demux )
...
@@ -479,9 +495,11 @@ static int Demux( demux_t *p_demux )
}
}
#if DVD_READ_CACHE
#if DVD_READ_CACHE
if
(
dvdnav_get_next_cache_block
(
p_sys
->
dvdnav
,
&
packet
,
&
i_event
,
&
i_len
)
==
DVDNAV_STATUS_ERR
)
if
(
dvdnav_get_next_cache_block
(
p_sys
->
dvdnav
,
&
packet
,
&
i_event
,
&
i_len
)
==
DVDNAV_STATUS_ERR
)
#else
#else
if
(
dvdnav_get_next_block
(
p_sys
->
dvdnav
,
packet
,
&
i_event
,
&
i_len
)
==
DVDNAV_STATUS_ERR
)
if
(
dvdnav_get_next_block
(
p_sys
->
dvdnav
,
packet
,
&
i_event
,
&
i_len
)
==
DVDNAV_STATUS_ERR
)
#endif
#endif
{
{
msg_Warn
(
p_demux
,
"cannot get next block (%s)"
,
msg_Warn
(
p_demux
,
"cannot get next block (%s)"
,
...
@@ -935,7 +953,6 @@ static void ESSubtitleUpdate( demux_t *p_demux )
...
@@ -935,7 +953,6 @@ static void ESSubtitleUpdate( demux_t *p_demux )
}
}
}
}
/*****************************************************************************
/*****************************************************************************
* DemuxBlock: demux a given block
* DemuxBlock: demux a given block
*****************************************************************************/
*****************************************************************************/
...
@@ -1293,16 +1310,3 @@ static int EventKey( vlc_object_t *p_this, char const *psz_var,
...
@@ -1293,16 +1310,3 @@ static int EventKey( vlc_object_t *p_this, char const *psz_var,
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
#if 0
static int MenusCallback( vlc_object_t *p_this, char const *psz_name,
vlc_value_t oldval, vlc_value_t newval, void *p_arg )
{
demux_t *p_demux = (demux_t*)p_arg;
/* FIXME, not thread safe */
dvdnav_menu_call( p_demux->p_sys->dvdnav, newval.i_int );
return VLC_SUCCESS;
}
#endif
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