]> git.sesse.net Git - vlc/blob - src/input/stream_filter.c
Added path information in stream_t.
[vlc] / src / input / stream_filter.c
1 /*****************************************************************************
2  * stream_filter.c
3  *****************************************************************************
4  * Copyright (C) 2008 Laurent Aimar
5  * $Id$
6  *
7  * Author: Laurent Aimar <fenrir _AT_ videolan _DOT_ org>
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
22  *****************************************************************************/
23
24 #ifdef HAVE_CONFIG_H
25 # include "config.h"
26 #endif
27
28 #include <vlc_common.h>
29 #include <vlc_stream.h>
30 #include <libvlc.h>
31
32 #include "stream.h"
33
34 static void StreamDelete( stream_t * );
35
36 stream_t *stream_FilterNew( stream_t *p_source,
37                             const char *psz_stream_filter )
38 {
39     stream_t *s;
40
41     s = stream_CommonNew( VLC_OBJECT( p_source ) );
42     if( s == NULL )
43         return NULL;
44
45     /* */
46     s->psz_path = strdup( p_source->psz_path );
47     if( !s->psz_path )
48     {
49         stream_CommonDelete( s );
50         return NULL;
51     }
52     s->p_source = p_source;
53
54     /* */
55     vlc_object_attach( s, p_source );
56
57     s->p_module = module_need( s, "stream_filter", psz_stream_filter, true );
58
59     if( !s->p_module )
60     {
61         stream_CommonDelete( s );
62         return NULL;
63     }
64
65     s->pf_destroy = StreamDelete;
66
67     return s;
68 }
69
70 stream_t *stream_FilterChainNew( stream_t *p_source,
71                                  const char *psz_chain,
72                                  bool b_record )
73 {
74     /* Add auto stream filter */
75     for( ;; )
76     {
77         stream_t *p_filter = stream_FilterNew( p_source, NULL );
78         if( !p_filter )
79             break;
80
81         msg_Dbg( p_filter, "Inserted a stream filter" );
82         p_source = p_filter;
83     }
84
85     /* Add user stream filter */
86     char *psz_tmp = psz_chain ? strdup( psz_chain ) : NULL;
87     char *psz = psz_tmp;
88     while( psz && *psz )
89     {
90         stream_t *p_filter;
91         char *psz_end = strchr( psz, ':' );
92
93         if( psz_end )
94             *psz_end++ = '\0';
95
96         p_filter = stream_FilterNew( p_source, psz );
97         if( p_filter )
98             p_source = p_filter;
99         else
100             msg_Warn( p_source, "failed to insert stream filter %s", psz );
101
102         psz = psz_end;
103     }
104     free( psz_tmp );
105
106     /* Add record filter if usefull */
107     if( b_record )
108     {
109         stream_t *p_filter = stream_FilterNew( p_source,
110                                                "stream_filter_record" );
111         if( p_filter )
112             p_source = p_filter;
113     }
114     return p_source;
115 }
116
117 static void StreamDelete( stream_t *s )
118 {
119     module_unneed( s, s->p_module );
120
121     if( s->p_source )
122         stream_Delete( s->p_source );
123
124     stream_CommonDelete( s );
125 }
126