1 /*****************************************************************************
2 * stream.h: Input stream functions
3 *****************************************************************************
4 * Copyright (C) 1998-2008 VLC authors and VideoLAN
5 * Copyright (C) 2008 Laurent Aimar
8 * Authors: Laurent Aimar <fenrir@via.ecp.fr>
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU Lesser General Public License as published by
12 * the Free Software Foundation; either version 2.1 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License for more details.
20 * You should have received a copy of the GNU Lesser General Public License
21 * along with this program; if not, write to the Free Software Foundation,
22 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
25 #ifndef LIBVLC_INPUT_STREAM_H
26 #define LIBVLC_INPUT_STREAM_H 1
28 #include <vlc_common.h>
29 #include <vlc_stream.h>
30 #include <vlc_charset.h>
34 /* UTF-16 and UTF-32 file reading */
41 stream_t
*stream_CommonNew( vlc_object_t
* );
42 void stream_CommonDelete( stream_t
* );
45 * This function creates a stream_t from a provided access_t.
47 * An optional NULL terminated list of file may be provided. The content
48 * of these extra files will be concatenated after to the main access.
50 * XXX ppsz_list is treated as const (I failed to avoid a warning when
51 * using const keywords for pointer of pointers)
53 stream_t
*stream_AccessNew( access_t
*p_access
, char **ppsz_list
);
56 * This function creates a new stream_t filter.
58 * You must release it using stream_Delete unless it is used as a
59 * source to another filter.
61 stream_t
*stream_FilterNew( stream_t
*p_source
,
62 const char *psz_stream_filter
);
65 * This function creates a chain of filters:
66 * - first, automatic probed stream filters are inserted.
67 * - then, optional user filters (configured by psz_chain) are inserted.
68 * - finaly, an optional record filter is inserted if b_record is true.
70 * You must release the returned value using stream_Delete unless it is used as a
71 * source to another filter.
73 stream_t
*stream_FilterChainNew( stream_t
*p_source
,
74 const char *psz_chain
,