stream.h
上传用户:kjfoods
上传日期:2020-07-06
资源大小:29949k
文件大小:3k
源码类别:

midi

开发平台:

Unix_Linux

  1. /*****************************************************************************
  2.  * stream.h: Input stream functions
  3.  *****************************************************************************
  4.  * Copyright (C) 1998-2008 the VideoLAN team
  5.  * Copyright (C) 2008 Laurent Aimar
  6.  * $Id: 01610a8b3fe3fd0ea2f67fcf4d89250a7fdd607b $
  7.  *
  8.  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
  9.  *
  10.  * This program is free software; you can redistribute it and/or modify
  11.  * it under the terms of the GNU General Public License as published by
  12.  * the Free Software Foundation; either version 2 of the License, or
  13.  * (at your option) any later version.
  14.  *
  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 General Public License for more details.
  19.  *
  20.  * You should have received a copy of the GNU General Public License
  21.  * along with this program; if not, write to the Free Software
  22.  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
  23.  *****************************************************************************/
  24. #if defined(__PLUGIN__) || defined(__BUILTIN__) || !defined(__LIBVLC__)
  25. # error This header file can only be included from LibVLC.
  26. #endif
  27. #ifndef _INPUT_STREAM_H
  28. #define _INPUT_STREAM_H 1
  29. #include <vlc_common.h>
  30. #include <vlc_stream.h>
  31. struct stream_text_t
  32. {
  33.     /* UTF-16 and UTF-32 file reading */
  34.     vlc_iconv_t     conv;
  35.     int             i_char_width;
  36.     bool            b_little_endian;
  37. };
  38. /* */
  39. stream_t *stream_CommonNew( vlc_object_t * );
  40. void stream_CommonDelete( stream_t * );
  41. /**
  42.  * This function creates a stream_t from a provided access_t.
  43.  *
  44.  * An optional NULL terminated list of file may be provided. The content
  45.  * of these extra files will be concatenated after to the main access.
  46.  *
  47.  * XXX ppsz_list is treated as const (I failed to avoid a warning when
  48.  * using const keywords for pointer of pointers)
  49.  */
  50. stream_t *stream_AccessNew( access_t *p_access, char **ppsz_list );
  51. /**
  52.  * This function creates a new stream_t filter.
  53.  *
  54.  * You must release it using stream_Delete unless it is used as a
  55.  * source to another filter.
  56.  */
  57. stream_t *stream_FilterNew( stream_t *p_source,
  58.                             const char *psz_stream_filter );
  59. /**
  60.  * This function creates a chain of filters:
  61.  * - first, automatic probed stream filters are inserted.
  62.  * - then, optional user filters (configured by psz_chain) are inserted.
  63.  * - finaly, an optional record filter is inserted if b_record is true.
  64.  *
  65.  * You must release the returned value using stream_Delete unless it is used as a
  66.  * source to another filter.
  67.  */
  68. stream_t *stream_FilterChainNew( stream_t *p_source,
  69.                                  const char *psz_chain,
  70.                                  bool b_record );
  71. #endif