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
e0791ca6
Commit
e0791ca6
authored
Jun 06, 2008
by
Pierre d'Herbemont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
stream: Support reading to NULL buffer in *Immediate method.
parent
fedb1403
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
19 additions
and
7 deletions
+19
-7
src/input/stream.c
src/input/stream.c
+19
-7
No files found.
src/input/stream.c
View file @
e0791ca6
...
...
@@ -1524,15 +1524,20 @@ static int AStreamReadImmediate( stream_t *s, void *p_read, int i_read )
p_read
,
i_read
);
#endif
if
(
p_read
==
NULL
)
/* No buffer, do as if we were seeking. */
if
(
!
p_read
)
{
/* seek within this stream if possible, else use plain old read and discard */
stream_sys_t
*
p_sys
=
s
->
p_sys
;
access_t
*
p_access
=
p_sys
->
p_access
;
bool
b_aseek
;
access_Control
(
p_access
,
ACCESS_CAN_SEEK
,
&
b_aseek
);
if
(
b_aseek
)
return
AStreamSeekStream
(
s
,
p_sys
->
i_pos
+
i_read
)
?
0
:
i_read
;
/* seeking after EOF is not what we want */
if
(
!
(
p_access
->
info
.
b_eof
)
)
{
bool
b_aseek
;
access_Control
(
p_access
,
ACCESS_CAN_SEEK
,
&
b_aseek
);
if
(
b_aseek
)
return
AStreamSeekImmediate
(
s
,
p_sys
->
i_pos
+
i_read
)
?
0
:
i_read
;
}
}
/* First, check if we already have some data in the buffer,
...
...
@@ -1560,7 +1565,14 @@ static int AStreamReadImmediate( stream_t *s, void *p_read, int i_read )
int
i_to_read
=
i_read
-
i_copy
;
if
(
i_to_read
)
{
i_to_read
=
AReadStream
(
s
,
p_read
,
i_to_read
);
if
(
p_read
)
i_to_read
=
AReadStream
(
s
,
p_read
,
i_to_read
);
else
{
void
*
dummy
=
malloc
(
i_to_read
);
i_to_read
=
AReadStream
(
s
,
dummy
,
i_to_read
);
free
(
dummy
);
}
}
p_sys
->
i_pos
+=
i_to_read
;
...
...
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