1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130
|
/*
(c) Copyright 2012-2013 DirectFB integrated media GmbH
(c) Copyright 2001-2013 The world wide DirectFB Open Source Community (directfb.org)
(c) Copyright 2000-2004 Convergence (integrated media) GmbH
All rights reserved.
Written by Denis Oliver Kropp <dok@directfb.org>,
Andreas Shimokawa <andi@directfb.org>,
Marek Pikarski <mass@directfb.org>,
Sven Neumann <neo@directfb.org>,
Ville Syrjälä <syrjala@sci.fi> and
Claudio Ciccani <klan@users.sf.net>.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library 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
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the
Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
#ifndef __DIRECT__STREAM_H__
#define __DIRECT__STREAM_H__
#include <direct/types.h>
/*
* Create a stream wrapper.
*
* 'filename' can be a plain file name or one of the following:
* http://<host>[:<port>]/<path>
* unsv://<host>[:<port>]/<path>
* ftp://<host>[:<port>]/<path>
* rtsp://<host>[:<port>]/<path>
* tcp://<host>:<port>
* udp://<host>:<port>
* file:/<path>
* fd:/<fileno>
* stdin:/
*/
DirectResult DIRECT_API direct_stream_create ( const char *filename,
DirectStream **ret_stream );
/*
* Duplicate the stream (never fails).
*/
DirectStream DIRECT_API *direct_stream_dup ( DirectStream *stream );
/*
* Return the file descriptor associated to the stream.
*/
int DIRECT_API direct_stream_fileno ( DirectStream *stream );
/*
* True if stream is seekable.
*/
bool DIRECT_API direct_stream_seekable( DirectStream *stream );
/*
* True if stream originates from a remote host.
*/
bool DIRECT_API direct_stream_remote ( DirectStream *stream );
/*
* Get the mime description of the stream.
* Returns NULL if the information is not available.
*/
const char DIRECT_API *direct_stream_mime ( DirectStream *stream );
/*
* Get stream length.
*/
unsigned int DIRECT_API direct_stream_length ( DirectStream *stream );
/*
* Get stream position.
*/
unsigned int DIRECT_API direct_stream_offset ( DirectStream *stream );
/*
* Wait for data to be available.
* If 'timeout' is NULL, the function blocks indefinitely.
* Set the 'timeout' to 0 to make the function return immediatly.
*/
DirectResult DIRECT_API direct_stream_wait ( DirectStream *stream,
unsigned int length,
struct timeval *timeout );
/*
* Peek 'length' bytes of data at offset 'offset' from the stream.
*/
DirectResult DIRECT_API direct_stream_peek ( DirectStream *stream,
unsigned int length,
int offset,
void *buf,
unsigned int *read_out );
/*
* Fetch 'length' bytes of data from the stream.
*/
DirectResult DIRECT_API direct_stream_read ( DirectStream *stream,
unsigned int length,
void *buf,
unsigned int *read_out );
/*
* Seek to the specified absolute offset within the stream.
*/
DirectResult DIRECT_API direct_stream_seek ( DirectStream *stream,
unsigned int offset );
/*
* Destroy the stream wrapper.
*/
void DIRECT_API direct_stream_destroy ( DirectStream *stream );
#endif /* __DIRECT__STREAM_H__ */
|