Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
21196f47
Commit
21196f47
authored
Jan 23, 2003
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* don't send audio in fast/slow playing speed unless there isn't any video
stream.
parent
e8ce66c2
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
24 additions
and
6 deletions
+24
-6
modules/demux/avi/avi.c
modules/demux/avi/avi.c
+24
-6
No files found.
modules/demux/avi/avi.c
View file @
21196f47
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* avi.c : AVI file Stream input module for vlc
* avi.c : AVI file Stream input module for vlc
*****************************************************************************
*****************************************************************************
* Copyright (C) 2001 VideoLAN
* Copyright (C) 2001 VideoLAN
* $Id: avi.c,v 1.2
7 2003/01/20 13:01:53
fenrir Exp $
* $Id: avi.c,v 1.2
8 2003/01/23 13:44:21
fenrir Exp $
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
*
* This program is free software; you can redistribute it and/or modify
* This program is free software; you can redistribute it and/or modify
...
@@ -683,7 +683,7 @@ static void AVI_StreamStop( input_thread_t *p_input,
...
@@ -683,7 +683,7 @@ static void AVI_StreamStop( input_thread_t *p_input,
static
int
AVI_StreamStopFinishedStreams
(
input_thread_t
*
p_input
,
static
int
AVI_StreamStopFinishedStreams
(
input_thread_t
*
p_input
,
demux_sys_t
*
p_avi
)
demux_sys_t
*
p_avi
)
{
{
int
i_stream
;
int
unsigned
i_stream
;
int
b_end
;
int
b_end
;
for
(
i_stream
=
0
,
b_end
=
VLC_TRUE
;
for
(
i_stream
=
0
,
b_end
=
VLC_TRUE
;
...
@@ -1689,14 +1689,15 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
...
@@ -1689,14 +1689,15 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
unsigned
int
i_stream_count
;
unsigned
int
i_stream_count
;
unsigned
int
i_stream
;
unsigned
int
i_stream
;
vlc_bool_t
b_stream
;
vlc_bool_t
b_stream
;
vlc_bool_t
b_play_audio
;
vlc_bool_t
b_video
;
/* is there some video track selected */
// cannot be more than 100 stream (dcXX or wbXX)
// cannot be more than 100 stream (dcXX or wbXX)
avi_stream_toread_t
toread
[
100
];
avi_stream_toread_t
toread
[
100
];
demux_sys_t
*
p_avi
=
p_input
->
p_demux_data
;
demux_sys_t
*
p_avi
=
p_input
->
p_demux_data
;
/* detect new selected/unselected streams */
/* detect new selected/unselected streams */
for
(
i_stream
=
0
,
i_stream_count
=
0
;
for
(
i_stream
=
0
,
i_stream_count
=
0
,
b_video
=
VLC_FALSE
;
i_stream
<
p_avi
->
i_streams
;
i_stream
++
)
i_stream
<
p_avi
->
i_streams
;
i_stream
++
)
{
{
#define p_stream p_avi->pp_info[i_stream]
#define p_stream p_avi->pp_info[i_stream]
...
@@ -1717,6 +1718,10 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
...
@@ -1717,6 +1718,10 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
if
(
p_stream
->
b_activated
)
if
(
p_stream
->
b_activated
)
{
{
i_stream_count
++
;
i_stream_count
++
;
if
(
p_stream
->
i_cat
==
VIDEO_ES
)
{
b_video
=
VLC_TRUE
;
}
}
}
#undef p_stream
#undef p_stream
}
}
...
@@ -1770,6 +1775,19 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
...
@@ -1770,6 +1775,19 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
subtitle_Demux
(
p_avi
->
p_sub
,
p_avi
->
i_time
);
subtitle_Demux
(
p_avi
->
p_sub
,
p_avi
->
i_time
);
}
}
#endif
#endif
/* *** send audio data to decoder if rate == DEFAULT_RATE or no video *** */
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
if
(
p_input
->
stream
.
control
.
i_rate
==
DEFAULT_RATE
||
!
b_video
)
{
b_play_audio
=
VLC_TRUE
;
}
else
{
b_play_audio
=
VLC_FALSE
;
}
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
/* init toread */
/* init toread */
for
(
i_stream
=
0
;
i_stream
<
p_avi
->
i_streams
;
i_stream
++
)
for
(
i_stream
=
0
;
i_stream
<
p_avi
->
i_streams
;
i_stream
++
)
{
{
...
@@ -1777,7 +1795,6 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
...
@@ -1777,7 +1795,6 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
mtime_t
i_dpts
;
mtime_t
i_dpts
;
toread
[
i_stream
].
b_ok
=
p_stream
->
b_activated
;
toread
[
i_stream
].
b_ok
=
p_stream
->
b_activated
;
if
(
p_stream
->
i_idxposc
<
p_stream
->
i_idxnb
)
if
(
p_stream
->
i_idxposc
<
p_stream
->
i_idxnb
)
{
{
toread
[
i_stream
].
i_posf
=
toread
[
i_stream
].
i_posf
=
...
@@ -2028,7 +2045,8 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
...
@@ -2028,7 +2045,8 @@ static int AVIDemux_Seekable( input_thread_t *p_input )
b_stream
=
VLC_TRUE
;
// at least one read succeed
b_stream
=
VLC_TRUE
;
// at least one read succeed
if
(
p_stream
->
p_es
&&
p_stream
->
p_es
->
p_decoder_fifo
)
if
(
p_stream
->
p_es
&&
p_stream
->
p_es
->
p_decoder_fifo
&&
(
b_play_audio
||
p_stream
->
i_cat
!=
AUDIO_ES
)
)
{
{
p_pes
->
i_dts
=
p_pes
->
i_dts
=
p_pes
->
i_pts
=
p_pes
->
i_pts
=
...
...
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