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
f3968d65
Commit
f3968d65
authored
Mar 25, 2007
by
Damien Fouilleul
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
libvlc/control: make sure aout is active before attempting to use channels
parent
a5e5d59b
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
33 additions
and
26 deletions
+33
-26
src/control/audio.c
src/control/audio.c
+33
-26
No files found.
src/control/audio.c
View file @
f3968d65
...
@@ -217,11 +217,15 @@ int libvlc_audio_get_channel( libvlc_instance_t *p_instance,
...
@@ -217,11 +217,15 @@ int libvlc_audio_get_channel( libvlc_instance_t *p_instance,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
vlc_value_t
val
;
if
(
p_aout
)
{
vlc_value_t
val
;
var_Get
(
p_aout
,
"audio-channels"
,
&
val
);
var_Get
(
p_aout
,
"audio-channels"
,
&
val
);
vlc_object_release
(
p_aout
);
vlc_object_release
(
p_aout
);
return
val
.
i_int
;
return
val
.
i_int
;
}
return
-
1
;
}
}
/*****************************************************************************
/*****************************************************************************
...
@@ -231,29 +235,32 @@ void libvlc_audio_set_channel( libvlc_instance_t *p_instance, int i_channel,
...
@@ -231,29 +235,32 @@ void libvlc_audio_set_channel( libvlc_instance_t *p_instance, int i_channel,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
vlc_value_t
val
;
if
(
p_aout
)
int
i_ret
=
-
1
;
val
.
i_int
=
i_channel
;
switch
(
i_channel
)
{
{
case
AOUT_VAR_CHAN_RSTEREO
:
vlc_value_t
val
;
case
AOUT_VAR_CHAN_STEREO
:
int
i_ret
=
-
1
;
case
AOUT_VAR_CHAN_LEFT
:
case
AOUT_VAR_CHAN_RIGHT
:
val
.
i_int
=
i_channel
;
case
AOUT_VAR_CHAN_DOLBYS
:
switch
(
i_channel
)
i_ret
=
var_Set
(
p_aout
,
"audio-channels"
,
val
);
{
if
(
i_ret
<
0
)
case
AOUT_VAR_CHAN_RSTEREO
:
{
case
AOUT_VAR_CHAN_STEREO
:
libvlc_exception_raise
(
p_e
,
"Failed setting audio channel"
);
case
AOUT_VAR_CHAN_LEFT
:
case
AOUT_VAR_CHAN_RIGHT
:
case
AOUT_VAR_CHAN_DOLBYS
:
i_ret
=
var_Set
(
p_aout
,
"audio-channels"
,
val
);
if
(
i_ret
<
0
)
{
libvlc_exception_raise
(
p_e
,
"Failed setting audio channel"
);
vlc_object_release
(
p_aout
);
return
;
}
vlc_object_release
(
p_aout
);
vlc_object_release
(
p_aout
);
return
;
return
;
/* Found */
}
default:
vlc_object_release
(
p_aout
);
libvlc_exception_raise
(
p_e
,
"Audio channel out of range"
);
return
;
/* Found */
break
;
default:
}
libvlc_exception_raise
(
p_e
,
"Audio channel out of range"
);
vlc_object_release
(
p_aout
);
break
;
}
}
vlc_object_release
(
p_aout
);
}
}
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