summaryrefslogtreecommitdiff
path: root/src/xine-engine/demux.c
diff options
context:
space:
mode:
authorMiguel Freitas <miguelfreitas@users.sourceforge.net>2003-04-17 19:01:23 +0000
committerMiguel Freitas <miguelfreitas@users.sourceforge.net>2003-04-17 19:01:23 +0000
commit8f47c8446881b116b86721abb36af3bcb8159def (patch)
treea3a6977baa5a2bd810f13ba47bca8a9fe54f3167 /src/xine-engine/demux.c
parent05e985d004bc397174a62d6f060b9742e9914087 (diff)
downloadxine-lib-8f47c8446881b116b86721abb36af3bcb8159def.tar.gz
xine-lib-8f47c8446881b116b86721abb36af3bcb8159def.tar.bz2
cleanup patch by Marco Z|hlke <M.Zuehlke@freenet.de>
CVS patchset: 4632 CVS date: 2003/04/17 19:01:23
Diffstat (limited to 'src/xine-engine/demux.c')
-rw-r--r--src/xine-engine/demux.c46
1 files changed, 45 insertions, 1 deletions
diff --git a/src/xine-engine/demux.c b/src/xine-engine/demux.c
index c1b78dcd8..8cafe9f78 100644
--- a/src/xine-engine/demux.c
+++ b/src/xine-engine/demux.c
@@ -149,7 +149,7 @@ void xine_demux_control_headers_done (xine_stream_t *stream) {
void xine_demux_control_start( xine_stream_t *stream ) {
buf_element_t *buf;
-
+
buf = stream->video_fifo->buffer_pool_alloc (stream->video_fifo);
buf->type = BUF_CONTROL_START;
stream->video_fifo->put (stream->video_fifo, buf);
@@ -332,6 +332,50 @@ int xine_demux_stop_thread (xine_stream_t *stream) {
return 0;
}
+int xine_demux_read_header( input_plugin_t *input, unsigned char *buffer, off_t size){
+ int read_size;
+ unsigned char *buf;
+
+ if (!input || !size || size > MAX_PREVIEW_SIZE)
+ return 0;
+
+ if (input->get_capabilities(input) & INPUT_CAP_SEEKABLE) {
+ input->seek(input, 0, SEEK_SET);
+ read_size = input->read(input, buffer, size);
+ if (read_size != size)
+ return 0;
+ input->seek(input, 0, SEEK_SET);
+ } else if (input->get_capabilities(input) & INPUT_CAP_PREVIEW) {
+ buf = xine_xmalloc(MAX_PREVIEW_SIZE);
+ read_size = input->get_optional_data(input, buf, INPUT_OPTIONAL_DATA_PREVIEW);
+ memcpy(buffer, buf, size);
+ free(buf);
+ } else {
+ return 0;
+ }
+ return read_size;
+}
+
+int xine_demux_check_extension (char *mrl, char *extensions){
+ char *last_dot, *e, *ext_copy, *ext_work;
+
+ ext_copy = strdup(extensions);
+ ext_work = ext_copy;
+
+ last_dot = strrchr (mrl, '.');
+ if (last_dot) {
+ last_dot++;
+ while ( ( e = xine_strsep(&ext_work, " ")) != NULL ) {
+ if (strcasecmp (last_dot, e) == 0) {
+ free(ext_copy);
+ return 1;
+ }
+ }
+ }
+ free(ext_copy);
+ return 0;
+}
+
/*
* read from socket/file descriptor checking demux_action_pending