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
9b6b0df3
Commit
9b6b0df3
authored
Apr 18, 2007
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Uuinline functions and hide stream_t (it's not used in any module anyway)
parent
7812f844
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
137 additions
and
115 deletions
+137
-115
include/vlc_stream.h
include/vlc_stream.h
+16
-108
src/input/demux.c
src/input/demux.c
+1
-1
src/input/input_internal.h
src/input/input_internal.h
+29
-0
src/input/mem_stream.c
src/input/mem_stream.c
+1
-1
src/input/stream.c
src/input/stream.c
+90
-1
src/misc/objects.c
src/misc/objects.c
+0
-4
No files found.
include/vlc_stream.h
View file @
9b6b0df3
...
...
@@ -64,84 +64,13 @@ enum stream_query_e
if access unreachable or access control answer */
};
/**
* stream_t definition
*/
struct
stream_t
{
VLC_COMMON_MEMBERS
block_t
*
(
*
pf_block
)
(
stream_t
*
,
int
i_size
);
int
(
*
pf_read
)
(
stream_t
*
,
void
*
p_read
,
int
i_read
);
int
(
*
pf_peek
)
(
stream_t
*
,
uint8_t
**
pp_peek
,
int
i_peek
);
int
(
*
pf_control
)(
stream_t
*
,
int
i_query
,
va_list
);
void
(
*
pf_destroy
)(
stream_t
*
);
stream_sys_t
*
p_sys
;
/* UTF-16 and UTF-32 file reading */
vlc_iconv_t
conv
;
int
i_char_width
;
vlc_bool_t
b_little_endian
;
};
/**
* Try to read "i_read" bytes into a buffer pointed by "p_read". If
* "p_read" is NULL then data are skipped instead of read. The return
* value is the real numbers of bytes read/skip. If this value is less
* than i_read that means that it's the end of the stream.
*/
static
inline
int
stream_Read
(
stream_t
*
s
,
void
*
p_read
,
int
i_read
)
{
return
s
->
pf_read
(
s
,
p_read
,
i_read
);
}
/**
* Store in pp_peek a pointer to the next "i_peek" bytes in the stream
* \return The real numbers of valid bytes, if it's less
* or equal to 0, *pp_peek is invalid.
* \note pp_peek is a pointer to internal buffer and it will be invalid as
* soons as other stream_* functions are called.
* \note Due to input limitation, it could be less than i_peek without meaning
* the end of the stream (but only when you have i_peek >=
* p_input->i_bufsize)
*/
static
inline
int
stream_Peek
(
stream_t
*
s
,
uint8_t
**
pp_peek
,
int
i_peek
)
{
return
s
->
pf_peek
(
s
,
pp_peek
,
i_peek
);
}
/**
* Use to control the "stream_t *". Look at #stream_query_e for
* possible "i_query" value and format arguments. Return VLC_SUCCESS
* if ... succeed ;) and VLC_EGENERIC if failed or unimplemented
*/
static
inline
int
stream_vaControl
(
stream_t
*
s
,
int
i_query
,
va_list
args
)
{
return
s
->
pf_control
(
s
,
i_query
,
args
);
}
/**
* Destroy a stream
*/
static
inline
void
stream_Delete
(
stream_t
*
s
)
{
s
->
pf_destroy
(
s
);
}
static
inline
int
stream_Control
(
stream_t
*
s
,
int
i_query
,
...
)
{
va_list
args
;
int
i_result
;
if
(
s
==
NULL
)
return
VLC_EGENERIC
;
va_start
(
args
,
i_query
);
i_result
=
s
->
pf_control
(
s
,
i_query
,
args
);
va_end
(
args
);
return
i_result
;
}
VLC_EXPORT
(
int
,
stream_Read
,
(
stream_t
*
s
,
void
*
p_read
,
int
i_read
)
);
VLC_EXPORT
(
int
,
stream_Peek
,
(
stream_t
*
s
,
uint8_t
**
pp_peek
,
int
i_peek
)
);
VLC_EXPORT
(
int
,
stream_vaControl
,
(
stream_t
*
s
,
int
i_query
,
va_list
args
)
);
VLC_EXPORT
(
void
,
stream_Delete
,
(
stream_t
*
s
)
);
VLC_EXPORT
(
int
,
stream_Control
,
(
stream_t
*
s
,
int
i_query
,
...
)
);
VLC_EXPORT
(
block_t
*
,
stream_Block
,
(
stream_t
*
s
,
int
i_size
)
);
VLC_EXPORT
(
char
*
,
stream_ReadLine
,
(
stream_t
*
)
);
/**
* Get the current position in a stream
...
...
@@ -173,36 +102,6 @@ static inline int stream_Seek( stream_t *s, int64_t i_pos )
return
stream_Control
(
s
,
STREAM_SET_POSITION
,
i_pos
);
}
/**
* Read "i_size" bytes and store them in a block_t. If less than "i_size"
* bytes are available then return what is left and if nothing is available,
* return NULL.
*/
static
inline
block_t
*
stream_Block
(
stream_t
*
s
,
int
i_size
)
{
if
(
i_size
<=
0
)
return
NULL
;
if
(
s
->
pf_block
)
{
return
s
->
pf_block
(
s
,
i_size
);
}
else
{
/* emulate block read */
block_t
*
p_bk
=
block_New
(
s
,
i_size
);
if
(
p_bk
)
{
p_bk
->
i_buffer
=
stream_Read
(
s
,
p_bk
->
p_buffer
,
i_size
);
if
(
p_bk
->
i_buffer
>
0
)
{
return
p_bk
;
}
}
if
(
p_bk
)
block_Release
(
p_bk
);
return
NULL
;
}
}
VLC_EXPORT
(
char
*
,
stream_ReadLine
,
(
stream_t
*
)
);
/**
...
...
@@ -227,4 +126,13 @@ VLC_EXPORT( stream_t *,__stream_UrlNew, (vlc_object_t *p_this, const char *psz_u
}
# endif
# if defined (__PLUGIN__) || defined (__BUILTIN__)
/* FIXME UGLY HACK to keep VLC_OBJECT working */
/* Maybe we should make VLC_OBJECT a simple cast noawadays... */
struct
stream_t
{
VLC_COMMON_MEMBERS
};
# endif
#endif
src/input/demux.c
View file @
9b6b0df3
...
...
@@ -310,7 +310,7 @@ stream_t *__stream_DemuxNew( vlc_object_t *p_obj, const char *psz_demux,
if
(
psz_demux
==
NULL
||
*
psz_demux
==
'\0'
)
return
NULL
;
s
=
vlc_
object_create
(
p_obj
,
VLC_OBJECT_STREAM
);
s
=
vlc_
stream_create
(
p_obj
);
s
->
pf_block
=
NULL
;
s
->
pf_read
=
DStreamRead
;
s
->
pf_peek
=
DStreamPeek
;
...
...
src/input/input_internal.h
View file @
9b6b0df3
...
...
@@ -339,4 +339,33 @@ static inline int demux2_Control( demux_t *p_demux, int i_query, ... )
return
i_result
;
}
/* Stream */
/**
* stream_t definition
*/
struct
stream_t
{
VLC_COMMON_MEMBERS
block_t
*
(
*
pf_block
)
(
stream_t
*
,
int
i_size
);
int
(
*
pf_read
)
(
stream_t
*
,
void
*
p_read
,
int
i_read
);
int
(
*
pf_peek
)
(
stream_t
*
,
uint8_t
**
pp_peek
,
int
i_peek
);
int
(
*
pf_control
)(
stream_t
*
,
int
i_query
,
va_list
);
void
(
*
pf_destroy
)(
stream_t
*
);
stream_sys_t
*
p_sys
;
/* UTF-16 and UTF-32 file reading */
vlc_iconv_t
conv
;
int
i_char_width
;
vlc_bool_t
b_little_endian
;
};
#include <libvlc.h>
static
inline
stream_t
*
vlc_stream_create
(
vlc_object_t
*
obj
)
{
return
(
stream_t
*
)
vlc_custom_create
(
obj
,
sizeof
(
stream_t
),
VLC_OBJECT_STREAM
,
"stream"
);
}
#endif
src/input/mem_stream.c
View file @
9b6b0df3
...
...
@@ -52,7 +52,7 @@ static void Delete ( stream_t * );
stream_t
*
__stream_MemoryNew
(
vlc_object_t
*
p_this
,
uint8_t
*
p_buffer
,
int64_t
i_size
,
vlc_bool_t
i_preserve_memory
)
{
stream_t
*
s
=
vlc_
object_create
(
p_this
,
VLC_OBJECT_STREAM
);
stream_t
*
s
=
vlc_
stream_create
(
p_this
);
stream_sys_t
*
p_sys
;
if
(
!
s
)
return
NULL
;
...
...
src/input/stream.c
View file @
9b6b0df3
...
...
@@ -223,7 +223,7 @@ stream_t *__stream_UrlNew( vlc_object_t *p_parent, const char *psz_url )
stream_t
*
stream_AccessNew
(
access_t
*
p_access
,
vlc_bool_t
b_quick
)
{
stream_t
*
s
=
vlc_
object_create
(
p_access
,
VLC_OBJECT_STREAM
);
stream_t
*
s
=
vlc_
stream_create
(
p_access
);
stream_sys_t
*
p_sys
;
char
*
psz_list
;
...
...
@@ -1814,3 +1814,92 @@ static int ASeek( stream_t *s, int64_t i_pos )
return
p_access
->
pf_seek
(
p_access
,
i_pos
);
}
/**
* Try to read "i_read" bytes into a buffer pointed by "p_read". If
* "p_read" is NULL then data are skipped instead of read. The return
* value is the real numbers of bytes read/skip. If this value is less
* than i_read that means that it's the end of the stream.
*/
int
stream_Read
(
stream_t
*
s
,
void
*
p_read
,
int
i_read
)
{
return
s
->
pf_read
(
s
,
p_read
,
i_read
);
}
/**
* Store in pp_peek a pointer to the next "i_peek" bytes in the stream
* \return The real numbers of valid bytes, if it's less
* or equal to 0, *pp_peek is invalid.
* \note pp_peek is a pointer to internal buffer and it will be invalid as
* soons as other stream_* functions are called.
* \note Due to input limitation, it could be less than i_peek without meaning
* the end of the stream (but only when you have i_peek >=
* p_input->i_bufsize)
*/
int
stream_Peek
(
stream_t
*
s
,
uint8_t
**
pp_peek
,
int
i_peek
)
{
return
s
->
pf_peek
(
s
,
pp_peek
,
i_peek
);
}
/**
* Use to control the "stream_t *". Look at #stream_query_e for
* possible "i_query" value and format arguments. Return VLC_SUCCESS
* if ... succeed ;) and VLC_EGENERIC if failed or unimplemented
*/
int
stream_vaControl
(
stream_t
*
s
,
int
i_query
,
va_list
args
)
{
return
s
->
pf_control
(
s
,
i_query
,
args
);
}
/**
* Destroy a stream
*/
void
stream_Delete
(
stream_t
*
s
)
{
s
->
pf_destroy
(
s
);
}
int
stream_Control
(
stream_t
*
s
,
int
i_query
,
...
)
{
va_list
args
;
int
i_result
;
if
(
s
==
NULL
)
return
VLC_EGENERIC
;
va_start
(
args
,
i_query
);
i_result
=
s
->
pf_control
(
s
,
i_query
,
args
);
va_end
(
args
);
return
i_result
;
}
/**
* Read "i_size" bytes and store them in a block_t. If less than "i_size"
* bytes are available then return what is left and if nothing is available,
* return NULL.
*/
block_t
*
stream_Block
(
stream_t
*
s
,
int
i_size
)
{
if
(
i_size
<=
0
)
return
NULL
;
if
(
s
->
pf_block
)
{
return
s
->
pf_block
(
s
,
i_size
);
}
else
{
/* emulate block read */
block_t
*
p_bk
=
block_New
(
s
,
i_size
);
if
(
p_bk
)
{
p_bk
->
i_buffer
=
stream_Read
(
s
,
p_bk
->
p_buffer
,
i_size
);
if
(
p_bk
->
i_buffer
>
0
)
{
return
p_bk
;
}
}
if
(
p_bk
)
block_Release
(
p_bk
);
return
NULL
;
}
}
src/misc/objects.c
View file @
9b6b0df3
...
...
@@ -245,10 +245,6 @@ void * __vlc_object_create( vlc_object_t *p_this, int i_type )
i_size
=
sizeof
(
demux_t
);
psz_type
=
"demux"
;
break
;
case
VLC_OBJECT_STREAM
:
i_size
=
sizeof
(
stream_t
);
psz_type
=
"stream"
;
break
;
case
VLC_OBJECT_ACCESS
:
i_size
=
sizeof
(
access_t
);
psz_type
=
"access"
;
...
...
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