Mercurial > audlegacy-plugins
view src/neon/neon.h @ 2680:e540e041b34b
add basic configuration gui
author | Tomasz Mon <desowin@gmail.com> |
---|---|
date | Wed, 04 Jun 2008 14:27:05 +0200 |
parents | 45aea2e3592a |
children | f1b6f1b2cdb3 |
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" 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 */ guchar redircount; /* Redirect count for the opened URL */ long pos; /* Current position in the stream (number of last byte delivered to the player) */ gulong 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 */ gulong icy_metaint; /* Interval in which the server will send metadata announcements. 0 if no announcments */ gulong 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