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
584da504
Commit
584da504
authored
Dec 08, 2008
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Support for auto and user requested stream_filter.
parent
7a0f1546
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
152 additions
and
23 deletions
+152
-23
include/vlc_stream.h
include/vlc_stream.h
+11
-6
src/Makefile.am
src/Makefile.am
+1
-0
src/input/input.c
src/input/input.c
+42
-8
src/input/stream.c
src/input/stream.c
+17
-6
src/input/stream.h
src/input/stream.h
+4
-3
src/input/stream_filter.c
src/input/stream_filter.c
+73
-0
src/input/var.c
src/input/var.c
+4
-0
No files found.
include/vlc_stream.h
View file @
584da504
...
@@ -53,17 +53,18 @@ struct stream_t
...
@@ -53,17 +53,18 @@ struct stream_t
{
{
VLC_COMMON_MEMBERS
VLC_COMMON_MEMBERS
/* Module properties */
/* Module properties
for stream filter
*/
module_t
*
p_module
;
module_t
*
p_module
;
/* For stream filter they will hold an array of stream sources */
/* Stream source for stream filter */
int
i_source
;
stream_t
*
p_source
;
stream_t
**
pp_source
;
/* */
/* */
int
(
*
pf_read
)
(
stream_t
*
,
void
*
p_read
,
unsigned
int
i_read
);
int
(
*
pf_read
)
(
stream_t
*
,
void
*
p_read
,
unsigned
int
i_read
);
int
(
*
pf_peek
)
(
stream_t
*
,
const
uint8_t
**
pp_peek
,
unsigned
int
i_peek
);
int
(
*
pf_peek
)
(
stream_t
*
,
const
uint8_t
**
pp_peek
,
unsigned
int
i_peek
);
int
(
*
pf_control
)(
stream_t
*
,
int
i_query
,
va_list
);
int
(
*
pf_control
)(
stream_t
*
,
int
i_query
,
va_list
);
/* */
void
(
*
pf_destroy
)(
stream_t
*
);
void
(
*
pf_destroy
)(
stream_t
*
);
/* Private data for module */
/* Private data for module */
...
@@ -95,10 +96,14 @@ enum stream_query_e
...
@@ -95,10 +96,14 @@ enum stream_query_e
STREAM_CONTROL_ACCESS
,
/* arg1= int i_access_query, args res: can fail
STREAM_CONTROL_ACCESS
,
/* arg1= int i_access_query, args res: can fail
if access unreachable or access control answer */
if access unreachable or access control answer */
/* You should update size of source if any and then update size
* FIXME find a way to avoid it */
STREAM_UPDATE_SIZE
,
/* */
STREAM_GET_CONTENT_TYPE
,
/**< arg1= char ** res=can fail */
STREAM_GET_CONTENT_TYPE
,
/**< arg1= char ** res=can fail */
/* SET_RECORD:
/* XXX only data read through stream_Read/Block will be recorded */
* XXX only data read through stream_Read/Block will be recorded */
STREAM_SET_RECORD_STATE
,
/**< arg1=bool, arg2=const char *psz_ext (if arg1 is true) res=can fail */
STREAM_SET_RECORD_STATE
,
/**< arg1=bool, arg2=const char *psz_ext (if arg1 is true) res=can fail */
};
};
...
...
src/Makefile.am
View file @
584da504
...
@@ -327,6 +327,7 @@ SOURCES_libvlc_common = \
...
@@ -327,6 +327,7 @@ SOURCES_libvlc_common = \
input/vlm_internal.h
\
input/vlm_internal.h
\
input/stream.c
\
input/stream.c
\
input/stream_demux.c
\
input/stream_demux.c
\
input/stream_filter.c
\
input/stream_memory.c
\
input/stream_memory.c
\
input/subtitles.c
\
input/subtitles.c
\
input/var.c
\
input/var.c
\
...
...
src/input/input.c
View file @
584da504
...
@@ -1933,8 +1933,8 @@ static bool Control( input_thread_t *p_input, int i_type,
...
@@ -1933,8 +1933,8 @@ static bool Control( input_thread_t *p_input, int i_type,
{
{
es_out_SetTime
(
p_input
->
p
->
p_es_out
,
-
1
);
es_out_SetTime
(
p_input
->
p
->
p_es_out
,
-
1
);
access_Control
(
p_access
,
ACCESS_SET_TITLE
,
i_title
);
stream_Control
(
p_input
->
p
->
input
.
p_stream
,
STREAM_CONTROL_ACCESS
,
stream_AccessReset
(
p_input
->
p
->
input
.
p_stream
);
ACCESS_SET_TITLE
,
i_title
);
}
}
}
}
break
;
break
;
...
@@ -2012,9 +2012,8 @@ static bool Control( input_thread_t *p_input, int i_type,
...
@@ -2012,9 +2012,8 @@ static bool Control( input_thread_t *p_input, int i_type,
{
{
es_out_SetTime
(
p_input
->
p
->
p_es_out
,
-
1
);
es_out_SetTime
(
p_input
->
p
->
p_es_out
,
-
1
);
access_Control
(
p_access
,
ACCESS_SET_SEEKPOINT
,
stream_Control
(
p_input
->
p
->
input
.
p_stream
,
STREAM_CONTROL_ACCESS
,
i_seekpoint
);
ACCESS_SET_SEEKPOINT
,
i_seekpoint
);
stream_AccessReset
(
p_input
->
p
->
input
.
p_stream
);
}
}
}
}
break
;
break
;
...
@@ -2256,7 +2255,7 @@ static int UpdateTitleSeekpointFromAccess( input_thread_t *p_input )
...
@@ -2256,7 +2255,7 @@ static int UpdateTitleSeekpointFromAccess( input_thread_t *p_input )
{
{
input_SendEventTitle
(
p_input
,
p_access
->
info
.
i_title
);
input_SendEventTitle
(
p_input
,
p_access
->
info
.
i_title
);
stream_
AccessUpdate
(
p_input
->
p
->
input
.
p_stream
);
stream_
Control
(
p_input
->
p
->
input
.
p_stream
,
STREAM_UPDATE_SIZE
);
p_access
->
info
.
i_update
&=
~
INPUT_UPDATE_TITLE
;
p_access
->
info
.
i_update
&=
~
INPUT_UPDATE_TITLE
;
}
}
...
@@ -2515,6 +2514,10 @@ static int InputSourceInit( input_thread_t *p_input,
...
@@ -2515,6 +2514,10 @@ static int InputSourceInit( input_thread_t *p_input,
var_Set
(
p_input
,
"can-seek"
,
val
);
var_Set
(
p_input
,
"can-seek"
,
val
);
}
}
/* TODO (maybe)
* do not let stream_AccessNew access input-list
* but give it a list of access ? */
/* Autodetect extra files if none specified */
/* Autodetect extra files if none specified */
char
*
psz_input_list
=
var_CreateGetNonEmptyString
(
p_input
,
"input-list"
);
char
*
psz_input_list
=
var_CreateGetNonEmptyString
(
p_input
,
"input-list"
);
if
(
!
psz_input_list
)
if
(
!
psz_input_list
)
...
@@ -2528,7 +2531,7 @@ static int InputSourceInit( input_thread_t *p_input,
...
@@ -2528,7 +2531,7 @@ static int InputSourceInit( input_thread_t *p_input,
/* Create the stream_t */
/* Create the stream_t */
in
->
p_stream
=
stream_AccessNew
(
in
->
p_access
,
p_input
->
b_preparsing
);
in
->
p_stream
=
stream_AccessNew
(
in
->
p_access
,
p_input
->
b_preparsing
);
/* Restor old value */
/* Restor
e
old value */
if
(
!
psz_input_list
)
if
(
!
psz_input_list
)
var_SetString
(
p_input
,
"input-list"
,
""
);
var_SetString
(
p_input
,
"input-list"
,
""
);
free
(
psz_input_list
);
free
(
psz_input_list
);
...
@@ -2539,6 +2542,37 @@ static int InputSourceInit( input_thread_t *p_input,
...
@@ -2539,6 +2542,37 @@ static int InputSourceInit( input_thread_t *p_input,
goto
error
;
goto
error
;
}
}
/* Add auto stream filter */
for
(
;;
)
{
stream_t
*
p_filter
=
stream_FilterNew
(
in
->
p_stream
,
NULL
);
if
(
!
p_filter
)
break
;
msg_Dbg
(
p_input
,
"Inserted a stream filter"
);
in
->
p_stream
=
p_filter
;
}
/* Add user stream filter */
psz_tmp
=
psz
=
var_GetNonEmptyString
(
p_input
,
"stream-filter"
);
while
(
psz
&&
*
psz
)
{
stream_t
*
p_filter
;
char
*
psz_end
=
strchr
(
psz
,
':'
);
if
(
psz_end
)
*
psz_end
++
=
'\0'
;
p_filter
=
stream_FilterNew
(
in
->
p_stream
,
psz
);
if
(
p_filter
)
in
->
p_stream
=
p_filter
;
else
msg_Warn
(
p_input
,
"failed to insert stream filter %s"
,
psz
);
psz
=
psz_end
;
}
free
(
psz_tmp
);
/* Open a demuxer */
/* Open a demuxer */
if
(
*
psz_demux
==
'\0'
&&
*
in
->
p_access
->
psz_demux
)
if
(
*
psz_demux
==
'\0'
&&
*
in
->
p_access
->
psz_demux
)
{
{
...
@@ -2597,7 +2631,7 @@ static int InputSourceInit( input_thread_t *p_input,
...
@@ -2597,7 +2631,7 @@ static int InputSourceInit( input_thread_t *p_input,
if
(
demux_Control
(
in
->
p_demux
,
DEMUX_CAN_RECORD
,
&
in
->
b_can_stream_record
)
)
if
(
demux_Control
(
in
->
p_demux
,
DEMUX_CAN_RECORD
,
&
in
->
b_can_stream_record
)
)
in
->
b_can_stream_record
=
false
;
in
->
b_can_stream_record
=
false
;
#ifdef ENABLE_SOUT
#ifdef ENABLE_SOUT
if
(
!
var_
Create
GetBool
(
p_input
,
"input-record-native"
)
)
if
(
!
var_GetBool
(
p_input
,
"input-record-native"
)
)
in
->
b_can_stream_record
=
false
;
in
->
b_can_stream_record
=
false
;
var_SetBool
(
p_input
,
"can-record"
,
true
);
var_SetBool
(
p_input
,
"can-record"
,
true
);
#else
#else
...
...
src/input/stream.c
View file @
584da504
...
@@ -531,9 +531,9 @@ static void UStreamDestroy( stream_t *s )
...
@@ -531,9 +531,9 @@ static void UStreamDestroy( stream_t *s )
}
}
/****************************************************************************
/****************************************************************************
*
stream_Access
Reset:
*
AStreamControl
Reset:
****************************************************************************/
****************************************************************************/
void
stream_Access
Reset
(
stream_t
*
s
)
static
void
AStreamControl
Reset
(
stream_t
*
s
)
{
{
stream_sys_t
*
p_sys
=
s
->
p_sys
;
stream_sys_t
*
p_sys
=
s
->
p_sys
;
...
@@ -578,9 +578,9 @@ void stream_AccessReset( stream_t *s )
...
@@ -578,9 +578,9 @@ void stream_AccessReset( stream_t *s )
}
}
/****************************************************************************
/****************************************************************************
*
stream_Access
Update:
*
AStreamControl
Update:
****************************************************************************/
****************************************************************************/
void
stream_Access
Update
(
stream_t
*
s
)
static
void
AStreamControl
Update
(
stream_t
*
s
)
{
{
stream_sys_t
*
p_sys
=
s
->
p_sys
;
stream_sys_t
*
p_sys
=
s
->
p_sys
;
...
@@ -657,16 +657,27 @@ static int AStreamControl( stream_t *s, int i_query, va_list args )
...
@@ -657,16 +657,27 @@ static int AStreamControl( stream_t *s, int i_query, va_list args )
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
case
STREAM_CONTROL_ACCESS
:
case
STREAM_CONTROL_ACCESS
:
{
i_int
=
(
int
)
va_arg
(
args
,
int
);
i_int
=
(
int
)
va_arg
(
args
,
int
);
if
(
i_int
!=
ACCESS_SET_PRIVATE_ID_STATE
&&
if
(
i_int
!=
ACCESS_SET_PRIVATE_ID_STATE
&&
i_int
!=
ACCESS_SET_PRIVATE_ID_CA
&&
i_int
!=
ACCESS_SET_PRIVATE_ID_CA
&&
i_int
!=
ACCESS_GET_PRIVATE_ID_STATE
)
i_int
!=
ACCESS_GET_PRIVATE_ID_STATE
&&
i_int
!=
ACCESS_SET_TITLE
&&
i_int
!=
ACCESS_SET_SEEKPOINT
)
{
{
msg_Err
(
s
,
"Hey, what are you thinking ?"
msg_Err
(
s
,
"Hey, what are you thinking ?"
"DON'T USE STREAM_CONTROL_ACCESS !!!"
);
"DON'T USE STREAM_CONTROL_ACCESS !!!"
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
return
access_vaControl
(
p_access
,
i_int
,
args
);
int
i_ret
=
access_vaControl
(
p_access
,
i_int
,
args
);
if
(
i_int
==
ACCESS_SET_TITLE
||
i_int
==
ACCESS_SET_SEEKPOINT
)
AStreamControlReset
(
s
);
return
i_ret
;
}
case
STREAM_UPDATE_SIZE
:
AStreamControlUpdate
(
s
);
return
VLC_SUCCESS
;
case
STREAM_GET_CONTENT_TYPE
:
case
STREAM_GET_CONTENT_TYPE
:
return
access_Control
(
p_access
,
ACCESS_GET_CONTENT_TYPE
,
return
access_Control
(
p_access
,
ACCESS_GET_CONTENT_TYPE
,
...
...
src/input/stream.h
View file @
584da504
...
@@ -46,9 +46,10 @@ void stream_CommonDelete( stream_t * );
...
@@ -46,9 +46,10 @@ void stream_CommonDelete( stream_t * );
/* */
/* */
stream_t
*
stream_AccessNew
(
access_t
*
p_access
,
bool
);
stream_t
*
stream_AccessNew
(
access_t
*
p_access
,
bool
);
void
stream_AccessDelete
(
stream_t
*
s
);
void
stream_AccessReset
(
stream_t
*
s
);
/* */
void
stream_AccessUpdate
(
stream_t
*
s
);
stream_t
*
stream_FilterNew
(
stream_t
*
p_source
,
const
char
*
psz_stream_filter
);
#endif
#endif
src/input/stream_filter.c
0 → 100644
View file @
584da504
/*****************************************************************************
* stream_filter.c
*****************************************************************************
* Copyright (C) 2008 Laurent Aimar
* $Id$
*
* Author: Laurent Aimar <fenrir _AT_ videolan _DOT_ org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
#include <vlc_common.h>
#include <vlc_stream.h>
#include <libvlc.h>
#include "stream.h"
static
void
StreamDelete
(
stream_t
*
);
stream_t
*
stream_FilterNew
(
stream_t
*
p_source
,
const
char
*
psz_stream_filter
)
{
stream_t
*
s
;
s
=
stream_CommonNew
(
VLC_OBJECT
(
p_source
)
);
if
(
s
==
NULL
)
return
NULL
;
/* */
s
->
p_source
=
p_source
;
/* */
vlc_object_attach
(
s
,
p_source
);
s
->
p_module
=
module_need
(
s
,
"stream_filter"
,
psz_stream_filter
,
true
);
if
(
!
s
->
p_module
)
{
stream_CommonDelete
(
s
);
return
NULL
;
}
s
->
pf_destroy
=
StreamDelete
;
return
s
;
}
static
void
StreamDelete
(
stream_t
*
s
)
{
module_unneed
(
s
,
s
->
p_module
);
if
(
s
->
p_source
)
stream_Delete
(
s
->
p_source
);
stream_CommonDelete
(
s
);
}
src/input/var.c
View file @
584da504
...
@@ -488,10 +488,14 @@ void input_ConfigVarInit ( input_thread_t *p_input )
...
@@ -488,10 +488,14 @@ void input_ConfigVarInit ( input_thread_t *p_input )
var_Create
(
p_input
,
"cache"
,
VLC_VAR_FLOAT
);
var_Create
(
p_input
,
"cache"
,
VLC_VAR_FLOAT
);
var_SetFloat
(
p_input
,
"cache"
,
0
.
0
);
var_SetFloat
(
p_input
,
"cache"
,
0
.
0
);
/* */
var_Create
(
p_input
,
"input-record-native"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
/* */
/* */
var_Create
(
p_input
,
"access-filter"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_input
,
"access-filter"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_input
,
"access"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_input
,
"access"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_input
,
"demux"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_input
,
"demux"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_input
,
"stream-filter"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
/* Meta */
/* Meta */
var_Create
(
p_input
,
"meta-title"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_input
,
"meta-title"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
...
...
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