Mercurial > audlegacy-plugins
view src/neon/neon.h @ 2366:f0a895a1e50d
- Add final part for proxy auth handling
author | Ralf Ertzinger <ralf@skytale.net> |
---|---|
date | Fri, 08 Feb 2008 12:11:13 +0100 |
parents | fa9f85cebade |
children | 503ea4219e17 |
line wrap: on
line source
/* * A neon HTTP input plugin for Audacious * Copyright (C) 2007 Ralf Ertzinger * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef _NEON_PLUGIN_H #define _NEON_PLUGIN_H #include "config.h" #include <glib.h> #include <audacious/vfs.h> #include <ne_session.h> #include <ne_request.h> #include <ne_uri.h> #include "rb.h" static void init(void); static void fini(void); VFSFile *neon_aud_vfs_fopen_impl(const gchar* path, const gchar* mode); gint neon_aud_vfs_fclose_impl(VFSFile* file); size_t neon_aud_vfs_fread_impl(gpointer ptr_, size_t size, size_t nmemb, VFSFile* file); size_t neon_aud_vfs_fwrite_impl(gconstpointer ptr, size_t size, size_t nmemb, VFSFile* file); gint neon_aud_vfs_getc_impl(VFSFile* file); gint neon_aud_vfs_ungetc_impl(gint c, VFSFile* file); void neon_aud_vfs_rewind_impl(VFSFile* file); glong neon_aud_vfs_ftell_impl(VFSFile* file); gboolean neon_aud_vfs_feof_impl(VFSFile* file); gint neon_aud_vfs_truncate_impl(VFSFile* file, glong size); gint neon_aud_vfs_fseek_impl(VFSFile* file, glong offset, gint whence); gchar *neon_aud_vfs_metadata_impl(VFSFile* file, const gchar * field); off_t neon_aud_vfs_fsize_impl(VFSFile* file); ne_uri purl; typedef enum { NEON_READER_INIT=0, NEON_READER_RUN=1, NEON_READER_ERROR, NEON_READER_EOF, NEON_READER_TERM } neon_reader_t; struct reader_status { GMutex* mutex; GCond* cond; gboolean reading; neon_reader_t status; }; struct icy_metadata { gchar* stream_name; gchar* stream_title; gchar* stream_url; gchar* stream_contenttype; }; struct neon_handle { gchar* url; /* The URL, as passed to us */ ne_uri* purl; /* The URL, parsed into a structure */ struct ringbuf rb; /* Ringbuffer for our data */ unsigned char redircount; /* Redirect count for the opened URL */ long pos; /* Current position in the stream (number of last byte delivered to the player) */ unsigned long content_start; /* Start position in the stream */ long content_length; /* Total content length, counting from content_start, if known. -1 if unknown */ gboolean can_ranges; /* TRUE if the webserver advertised accept-range: bytes */ unsigned long icy_metaint; /* Interval in which the server will send metadata announcements. 0 if no announcments */ unsigned long icy_metaleft; /* Bytes left until the next metadata block */ struct icy_metadata icy_metadata; /* Current ICY metadata */ ne_session* session; ne_request* request; GThread* reader; struct reader_status reader_status; gboolean eof; }; #endif