Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
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-1.1
Commits
1f51e300
Commit
1f51e300
authored
Mar 23, 2004
by
Gildas Bazin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* modules/demux/dvdnav.c: cosmetic changes + fixed small mem-leaks.
parent
e72c13db
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
20 deletions
+23
-20
modules/demux/dvdnav.c
modules/demux/dvdnav.c
+23
-20
No files found.
modules/demux/dvdnav.c
View file @
1f51e300
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* dvdnav.c: DVD module using the dvdnav library.
* dvdnav.c: DVD module using the dvdnav library.
*****************************************************************************
*****************************************************************************
* Copyright (C) 2004 VideoLAN
* Copyright (C) 2004 VideoLAN
* $Id
: dvdnav.c,v 1.11 2004/01/30 14:45:27 fenrir Exp
$
* $Id$
*
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
*
...
@@ -41,7 +41,7 @@
...
@@ -41,7 +41,7 @@
*****************************************************************************/
*****************************************************************************/
#define CACHING_TEXT N_("caching value in ms")
#define CACHING_TEXT N_("caching value in ms")
#define CACHING_LONGTEXT N_( \
#define CACHING_LONGTEXT N_( \
"Allows you to modify the default caching value for dvdnav streams. This "
\
"Allows you to modify the default caching value for dvdnav streams. This "\
"value should be set in miliseconds units." )
"value should be set in miliseconds units." )
static
int
AccessOpen
(
vlc_object_t
*
);
static
int
AccessOpen
(
vlc_object_t
*
);
...
@@ -164,8 +164,8 @@ static int AccessOpen( vlc_object_t *p_this )
...
@@ -164,8 +164,8 @@ static int AccessOpen( vlc_object_t *p_this )
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
b_force
=
(
p_input
->
psz_access
&&
!
strncmp
(
p_input
->
psz_access
,
"dvdnav"
,
6
))
?
b_force
=
p_input
->
psz_access
&&
VLC_TRUE
:
VLC_FALSE
;
!
strncmp
(
p_input
->
psz_access
,
"dvdnav"
,
6
)
;
psz_name
=
ParseCL
(
VLC_OBJECT
(
p_input
),
p_input
->
psz_name
,
b_force
,
psz_name
=
ParseCL
(
VLC_OBJECT
(
p_input
),
p_input
->
psz_name
,
b_force
,
&
i_title
,
&
i_chapter
,
&
i_angle
);
&
i_title
,
&
i_chapter
,
&
i_angle
);
...
@@ -178,6 +178,7 @@ static int AccessOpen( vlc_object_t *p_this )
...
@@ -178,6 +178,7 @@ static int AccessOpen( vlc_object_t *p_this )
if
(
dvdnav_open
(
&
dvdnav
,
psz_name
)
!=
DVDNAV_STATUS_OK
)
if
(
dvdnav_open
(
&
dvdnav
,
psz_name
)
!=
DVDNAV_STATUS_OK
)
{
{
msg_Warn
(
p_input
,
"cannot open dvdnav"
);
msg_Warn
(
p_input
,
"cannot open dvdnav"
);
free
(
psz_name
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
dvdnav_close
(
dvdnav
);
dvdnav_close
(
dvdnav
);
...
@@ -193,20 +194,16 @@ static int AccessOpen( vlc_object_t *p_this )
...
@@ -193,20 +194,16 @@ static int AccessOpen( vlc_object_t *p_this )
p_input
->
stream
.
b_pace_control
=
VLC_TRUE
;
p_input
->
stream
.
b_pace_control
=
VLC_TRUE
;
p_input
->
stream
.
b_seekable
=
VLC_TRUE
;
p_input
->
stream
.
b_seekable
=
VLC_TRUE
;
p_input
->
stream
.
p_selected_area
->
i_tell
=
0
;
p_input
->
stream
.
p_selected_area
->
i_tell
=
0
;
p_input
->
stream
.
p_selected_area
->
i_size
=
100
0
;
p_input
->
stream
.
p_selected_area
->
i_size
=
0
;
p_input
->
stream
.
i_method
=
INPUT_METHOD_
NETWORK
;
p_input
->
stream
.
i_method
=
INPUT_METHOD_
DVD
;
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
p_input
->
i_mtu
=
0
;
p_input
->
i_mtu
=
0
;
/*
force dvdnav plugin
*/
/*
Force dvdnav demux
*/
if
(
p_input
->
psz_access
&&
!
strncmp
(
p_input
->
psz_access
,
"dvdnav"
,
6
)
)
if
(
p_input
->
psz_access
&&
!
strncmp
(
p_input
->
psz_access
,
"dvdnav"
,
6
)
)
{
p_input
->
psz_demux
=
strdup
(
p_input
->
psz_access
);
p_input
->
psz_demux
=
strdup
(
p_input
->
psz_access
);
}
else
else
{
p_input
->
psz_demux
=
strdup
(
"dvdnav"
);
p_input
->
psz_demux
=
strdup
(
"dvdnav"
);
}
/* Update default_pts to a suitable value for udp access */
/* Update default_pts to a suitable value for udp access */
var_Create
(
p_input
,
"dvdnav-caching"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_input
,
"dvdnav-caching"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
...
@@ -323,23 +320,23 @@ static int DemuxOpen( vlc_object_t *p_this )
...
@@ -323,23 +320,23 @@ static int DemuxOpen( vlc_object_t *p_this )
p_demux
->
p_sys
=
p_sys
=
malloc
(
sizeof
(
demux_sys_t
)
);
p_demux
->
p_sys
=
p_sys
=
malloc
(
sizeof
(
demux_sys_t
)
);
memset
(
p_sys
,
0
,
sizeof
(
demux_sys_t
)
);
memset
(
p_sys
,
0
,
sizeof
(
demux_sys_t
)
);
p_sys
->
b_simple
=
strcmp
(
p_demux
->
psz_access
,
"dvdnavsimple"
)
?
VLC_FALSE
:
VLC_TRUE
;
p_sys
->
b_simple
=
strcmp
(
p_demux
->
psz_access
,
"dvdnavsimple"
)
?
VLC_FALSE
:
VLC_TRUE
;
if
(
p_sys
->
b_simple
&&
i_title
<
1
)
if
(
p_sys
->
b_simple
&&
i_title
<
1
)
{
{
/*
s
kip menu part */
/*
S
kip menu part */
i_title
=
1
;
i_title
=
1
;
}
}
ps_track_init
(
p_sys
->
tk
);
ps_track_init
(
p_sys
->
tk
);
p_sys
->
i_aspect
=
-
1
;
p_sys
->
i_aspect
=
-
1
;
p_sys
->
b_es_out_ok
=
VLC_FALSE
;
p_sys
->
b_es_out_ok
=
VLC_FALSE
;
/* Open dvdnav */
/* Open dvdnav */
if
(
dvdnav_open
(
&
p_sys
->
dvdnav
,
psz_name
)
!=
DVDNAV_STATUS_OK
)
if
(
dvdnav_open
(
&
p_sys
->
dvdnav
,
psz_name
)
!=
DVDNAV_STATUS_OK
)
{
{
msg_Warn
(
p_demux
,
"cannot open dvdnav"
);
msg_Warn
(
p_demux
,
"cannot open dvdnav"
);
free
(
psz_name
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
free
(
psz_name
);
free
(
psz_name
);
...
@@ -431,7 +428,6 @@ static int DemuxOpen( vlc_object_t *p_this )
...
@@ -431,7 +428,6 @@ static int DemuxOpen( vlc_object_t *p_this )
*****************************************************************************/
*****************************************************************************/
static
void
DemuxClose
(
vlc_object_t
*
p_this
)
static
void
DemuxClose
(
vlc_object_t
*
p_this
)
{
{
demux_t
*
p_demux
=
(
demux_t
*
)
p_this
;
demux_t
*
p_demux
=
(
demux_t
*
)
p_this
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
...
@@ -800,7 +796,8 @@ static void ESSubtitleUpdate( demux_t *p_demux )
...
@@ -800,7 +796,8 @@ static void ESSubtitleUpdate( demux_t *p_demux )
ESNew
(
p_demux
,
0xbd20
+
i_spu
);
ESNew
(
p_demux
,
0xbd20
+
i_spu
);
}
}
/* be sure to unselect it (reset) */
/* be sure to unselect it (reset) */
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_ES_STATE
,
tk
->
es
,
(
vlc_bool_t
)
VLC_FALSE
);
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_ES_STATE
,
tk
->
es
,
(
vlc_bool_t
)
VLC_FALSE
);
/* now select it */
/* now select it */
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_ES
,
tk
->
es
);
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_ES
,
tk
->
es
);
...
@@ -812,7 +809,8 @@ static void ESSubtitleUpdate( demux_t *p_demux )
...
@@ -812,7 +809,8 @@ static void ESSubtitleUpdate( demux_t *p_demux )
ps_track_t
*
tk
=
&
p_sys
->
tk
[
PS_ID_TO_TK
(
0xbd20
+
i_spu
)];
ps_track_t
*
tk
=
&
p_sys
->
tk
[
PS_ID_TO_TK
(
0xbd20
+
i_spu
)];
if
(
tk
->
b_seen
)
if
(
tk
->
b_seen
)
{
{
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_ES_STATE
,
tk
->
es
,
(
vlc_bool_t
)
VLC_FALSE
);
es_out_Control
(
p_demux
->
out
,
ES_OUT_SET_ES_STATE
,
tk
->
es
,
(
vlc_bool_t
)
VLC_FALSE
);
}
}
}
}
}
}
...
@@ -903,6 +901,9 @@ static int DemuxBlock( demux_t *p_demux, uint8_t *pkt, int i_pkt )
...
@@ -903,6 +901,9 @@ static int DemuxBlock( demux_t *p_demux, uint8_t *pkt, int i_pkt )
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
/*****************************************************************************
* ESNew: register a new elementary stream
*****************************************************************************/
static
void
ESNew
(
demux_t
*
p_demux
,
int
i_id
)
static
void
ESNew
(
demux_t
*
p_demux
,
int
i_id
)
{
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
...
@@ -976,9 +977,11 @@ static void ESNew( demux_t *p_demux, int i_id )
...
@@ -976,9 +977,11 @@ static void ESNew( demux_t *p_demux, int i_id )
tk
->
fmt
.
psz_language
[
1
]
=
(
i_lang
)
&
0xff
;
tk
->
fmt
.
psz_language
[
1
]
=
(
i_lang
)
&
0xff
;
tk
->
fmt
.
psz_language
[
2
]
=
0
;
tk
->
fmt
.
psz_language
[
2
]
=
0
;
}
}
/* palette */
/* Palette */
tk
->
fmt
.
subs
.
spu
.
palette
[
0
]
=
0xBeef
;
tk
->
fmt
.
subs
.
spu
.
palette
[
0
]
=
0xBeef
;
memcpy
(
&
tk
->
fmt
.
subs
.
spu
.
palette
[
1
],
p_sys
->
clut
,
16
*
sizeof
(
uint32_t
)
);
memcpy
(
&
tk
->
fmt
.
subs
.
spu
.
palette
[
1
],
p_sys
->
clut
,
16
*
sizeof
(
uint32_t
)
);
/* We select only when we are not in the menu */
/* We select only when we are not in the menu */
dvdnav_current_title_info
(
p_sys
->
dvdnav
,
&
i_title
,
&
i_part
);
dvdnav_current_title_info
(
p_sys
->
dvdnav
,
&
i_title
,
&
i_part
);
...
...
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