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
459af975
Commit
459af975
authored
Oct 26, 2009
by
Rémi Duraffort
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dshow: use var_Get* when applicable.
parent
85baa887
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
38 additions
and
48 deletions
+38
-48
modules/access/dshow/dshow.cpp
modules/access/dshow/dshow.cpp
+38
-48
No files found.
modules/access/dshow/dshow.cpp
View file @
459af975
...
@@ -344,8 +344,8 @@ static void DeleteDirectShowGraph( access_sys_t *p_sys )
...
@@ -344,8 +344,8 @@ static void DeleteDirectShowGraph( access_sys_t *p_sys )
static
int
CommonOpen
(
vlc_object_t
*
p_this
,
access_sys_t
*
p_sys
,
static
int
CommonOpen
(
vlc_object_t
*
p_this
,
access_sys_t
*
p_sys
,
bool
b_access_demux
)
bool
b_access_demux
)
{
{
vlc_value_t
val
;
int
i
;
int
i
;
char
*
psz_val
;
/* Get/parse options and open device(s) */
/* Get/parse options and open device(s) */
string
vdevname
,
adevname
;
string
vdevname
,
adevname
;
...
@@ -359,31 +359,29 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -359,31 +359,29 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
var_Create
(
p_this
,
"dshow-config"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_this
,
"dshow-config"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_this
,
"dshow-tuner"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_this
,
"dshow-tuner"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_this
,
"dshow-vdev"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
psz_val
=
var_CreateGetString
(
p_this
,
"dshow-vdev"
);
var_Get
(
p_this
,
"dshow-vdev"
,
&
val
);
if
(
psz_val
)
if
(
val
.
psz_string
)
{
{
msg_Dbg
(
p_this
,
"dshow-vdev: %s"
,
val
.
psz_string
)
;
msg_Dbg
(
p_this
,
"dshow-vdev: %s"
,
psz_val
)
;
/* skip none device */
/* skip none device */
if
(
strncasecmp
(
val
.
psz_string
,
"none"
,
4
)
!=
0
)
if
(
strncasecmp
(
psz_val
,
"none"
,
4
)
!=
0
)
vdevname
=
string
(
val
.
psz_string
);
vdevname
=
string
(
psz_val
);
else
else
b_use_video
=
false
;
b_use_video
=
false
;
}
}
free
(
val
.
psz_string
);
free
(
psz_val
);
var_Create
(
p_this
,
"dshow-adev"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
psz_val
=
var_CreateGetString
(
p_this
,
"dshow-adev"
);
var_Get
(
p_this
,
"dshow-adev"
,
&
val
);
if
(
psz_val
)
if
(
val
.
psz_string
)
{
{
msg_Dbg
(
p_this
,
"dshow-adev: %s"
,
val
.
psz_string
)
;
msg_Dbg
(
p_this
,
"dshow-adev: %s"
,
psz_val
)
;
/* skip none device */
/* skip none device */
if
(
strncasecmp
(
val
.
psz_string
,
"none"
,
4
)
!=
0
)
if
(
strncasecmp
(
psz_val
,
"none"
,
4
)
!=
0
)
adevname
=
string
(
val
.
psz_string
);
adevname
=
string
(
psz_val
);
else
else
b_use_audio
=
false
;
b_use_audio
=
false
;
}
}
free
(
val
.
psz_string
);
free
(
psz_val
);
static
struct
{
const
char
*
psz_size
;
int
i_width
;
int
i_height
;}
size_table
[]
=
static
struct
{
const
char
*
psz_size
;
int
i_width
;
int
i_height
;}
size_table
[]
=
{
{
"subqcif"
,
128
,
96
},
{
"qsif"
,
160
,
120
},
{
"qcif"
,
176
,
144
},
{
{
"subqcif"
,
128
,
96
},
{
"qsif"
,
160
,
120
},
{
"qcif"
,
176
,
144
},
...
@@ -391,13 +389,12 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -391,13 +389,12 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
{
0
,
0
,
0
},
{
0
,
0
,
0
},
};
};
var_Create
(
p_this
,
"dshow-size"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
psz_val
=
var_CreateGetString
(
p_this
,
"dshow-size"
);
var_Get
(
p_this
,
"dshow-size"
,
&
val
);
if
(
!
EMPTY_STR
(
psz_val
)
)
if
(
val
.
psz_string
&&
*
val
.
psz_string
)
{
{
for
(
i
=
0
;
size_table
[
i
].
psz_size
;
i
++
)
for
(
i
=
0
;
size_table
[
i
].
psz_size
;
i
++
)
{
{
if
(
!
strcmp
(
val
.
psz_string
,
size_table
[
i
].
psz_size
)
)
if
(
!
strcmp
(
psz_val
,
size_table
[
i
].
psz_size
)
)
{
{
i_width
=
size_table
[
i
].
i_width
;
i_width
=
size_table
[
i
].
i_width
;
i_height
=
size_table
[
i
].
i_height
;
i_height
=
size_table
[
i
].
i_height
;
...
@@ -407,7 +404,7 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -407,7 +404,7 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
if
(
!
size_table
[
i
].
psz_size
)
/* Try to parse "WidthxHeight" */
if
(
!
size_table
[
i
].
psz_size
)
/* Try to parse "WidthxHeight" */
{
{
char
*
psz_parser
;
char
*
psz_parser
;
i_width
=
strtol
(
val
.
psz_string
,
&
psz_parser
,
0
);
i_width
=
strtol
(
psz_val
,
&
psz_parser
,
0
);
if
(
*
psz_parser
==
'x'
||
*
psz_parser
==
'X'
)
if
(
*
psz_parser
==
'x'
||
*
psz_parser
==
'X'
)
{
{
i_height
=
strtol
(
psz_parser
+
1
,
&
psz_parser
,
0
);
i_height
=
strtol
(
psz_parser
+
1
,
&
psz_parser
,
0
);
...
@@ -415,15 +412,12 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -415,15 +412,12 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
msg_Dbg
(
p_this
,
"width x height %dx%d"
,
i_width
,
i_height
);
msg_Dbg
(
p_this
,
"width x height %dx%d"
,
i_width
,
i_height
);
}
}
}
}
free
(
val
.
psz_string
);
free
(
psz_val
);
p_sys
->
b_chroma
=
false
;
psz_val
=
var_CreateGetString
(
p_this
,
"dshow-chroma"
);
var_Create
(
p_this
,
"dshow-chroma"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
i_chroma
=
vlc_fourcc_GetCodecFromString
(
UNKNOWN_ES
,
psz_val
);
var_Get
(
p_this
,
"dshow-chroma"
,
&
val
);
i_chroma
=
vlc_fourcc_GetCodecFromString
(
UNKNOWN_ES
,
val
.
psz_string
);
p_sys
->
b_chroma
=
i_chroma
!=
0
;
p_sys
->
b_chroma
=
i_chroma
!=
0
;
free
(
val
.
psz_string
);
free
(
psz_val
);
var_Create
(
p_this
,
"dshow-fps"
,
VLC_VAR_FLOAT
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_this
,
"dshow-fps"
,
VLC_VAR_FLOAT
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_this
,
"dshow-tuner-channel"
,
var_Create
(
p_this
,
"dshow-tuner-channel"
,
...
@@ -510,8 +504,7 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -510,8 +504,7 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
var_Get
(
p_this
,
"dshow-tuner"
,
&
val
);
if
(
var_GetBool
(
p_this
,
"dshow-tuner"
)
)
if
(
val
.
b_bool
)
{
{
/* FIXME: we do MEDIATYPE_Stream here so we don't do
/* FIXME: we do MEDIATYPE_Stream here so we don't do
* it twice. */
* it twice. */
...
@@ -545,18 +538,18 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -545,18 +538,18 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
for
(
i
=
p_sys
->
i_crossbar_route_depth
-
1
;
i
>=
0
;
--
i
)
for
(
i
=
p_sys
->
i_crossbar_route_depth
-
1
;
i
>=
0
;
--
i
)
{
{
var_Get
(
p_this
,
"dshow-video-input"
,
&
val
);
int
i_val
=
var_GetInteger
(
p_this
,
"dshow-video-input"
);
if
(
val
.
i_int
>=
0
)
if
(
i_val
>=
0
)
p_sys
->
crossbar_routes
[
i
].
VideoInputIndex
=
val
.
i_int
;
p_sys
->
crossbar_routes
[
i
].
VideoInputIndex
=
i_val
;
var_Get
(
p_this
,
"dshow-video-output"
,
&
val
);
i_val
=
var_GetInteger
(
p_this
,
"dshow-video-output"
);
if
(
val
.
i_int
>=
0
)
if
(
i_val
>=
0
)
p_sys
->
crossbar_routes
[
i
].
VideoOutputIndex
=
val
.
i_int
;
p_sys
->
crossbar_routes
[
i
].
VideoOutputIndex
=
i_val
;
var_Get
(
p_this
,
"dshow-audio-input"
,
&
val
);
i_val
=
var_GetInteger
(
p_this
,
"dshow-audio-input"
);
if
(
val
.
i_int
>=
0
)
if
(
i_val
>=
0
)
p_sys
->
crossbar_routes
[
i
].
AudioInputIndex
=
val
.
i_int
;
p_sys
->
crossbar_routes
[
i
].
AudioInputIndex
=
i_val
;
var_Get
(
p_this
,
"dshow-audio-output"
,
&
val
);
i_val
=
var_GetInteger
(
p_this
,
"dshow-audio-output"
);
if
(
val
.
i_int
>=
0
)
if
(
i_val
>=
0
)
p_sys
->
crossbar_routes
[
i
].
AudioOutputIndex
=
val
.
i_int
;
p_sys
->
crossbar_routes
[
i
].
AudioOutputIndex
=
i_val
;
IAMCrossbar
*
pXbar
=
p_sys
->
crossbar_routes
[
i
].
pXbar
;
IAMCrossbar
*
pXbar
=
p_sys
->
crossbar_routes
[
i
].
pXbar
;
LONG
VideoInputIndex
=
p_sys
->
crossbar_routes
[
i
].
VideoInputIndex
;
LONG
VideoInputIndex
=
p_sys
->
crossbar_routes
[
i
].
VideoInputIndex
;
...
@@ -589,8 +582,7 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -589,8 +582,7 @@ static int CommonOpen( vlc_object_t *p_this, access_sys_t *p_sys,
/*
/*
** Show properties pages from other filters in graph
** Show properties pages from other filters in graph
*/
*/
var_Get
(
p_this
,
"dshow-config"
,
&
val
);
if
(
var_GetBool
(
p_this
,
"dshow-config"
)
)
if
(
val
.
b_bool
)
{
{
for
(
i
=
p_sys
->
i_crossbar_route_depth
-
1
;
i
>=
0
;
--
i
)
for
(
i
=
p_sys
->
i_crossbar_route_depth
-
1
;
i
>=
0
;
--
i
)
{
{
...
@@ -1054,9 +1046,7 @@ static int OpenDevice( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -1054,9 +1046,7 @@ static int OpenDevice( vlc_object_t *p_this, access_sys_t *p_sys,
/* Show Device properties. Done here so the VLC stream is setup with
/* Show Device properties. Done here so the VLC stream is setup with
* the proper parameters. */
* the proper parameters. */
vlc_value_t
val
;
if
(
var_GetBool
(
p_this
,
"dshow-config"
)
)
var_Get
(
p_this
,
"dshow-config"
,
&
val
);
if
(
val
.
b_bool
)
{
{
ShowDeviceProperties
(
p_this
,
p_sys
->
p_capture_graph_builder2
,
ShowDeviceProperties
(
p_this
,
p_sys
->
p_capture_graph_builder2
,
p_device_filter
,
b_audio
);
p_device_filter
,
b_audio
);
...
@@ -1065,8 +1055,8 @@ static int OpenDevice( vlc_object_t *p_this, access_sys_t *p_sys,
...
@@ -1065,8 +1055,8 @@ static int OpenDevice( vlc_object_t *p_this, access_sys_t *p_sys,
ConfigTuner
(
p_this
,
p_sys
->
p_capture_graph_builder2
,
ConfigTuner
(
p_this
,
p_sys
->
p_capture_graph_builder2
,
p_device_filter
);
p_device_filter
);
var_Get
(
p_this
,
"dshow-tuner"
,
&
val
);
if
(
var_GetBool
(
p_this
,
"dshow-tuner"
)
&&
if
(
val
.
b_bool
&&
dshow_stream
.
mt
.
majortype
!=
MEDIATYPE_Stream
)
dshow_stream
.
mt
.
majortype
!=
MEDIATYPE_Stream
)
{
{
/* FIXME: we do MEDIATYPE_Stream later so we don't do it twice. */
/* FIXME: we do MEDIATYPE_Stream later so we don't do it twice. */
ShowTunerProperties
(
p_this
,
p_sys
->
p_capture_graph_builder2
,
ShowTunerProperties
(
p_this
,
p_sys
->
p_capture_graph_builder2
,
...
...
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