Mercurial > audlegacy
view audacious/effect.c @ 1126:537e8cc47060 trunk
[svn] - allow load_file<class Emu> to load files into the parser without reading the tag information
- generate subsong path specifications on demand if we're not loading a specific subsong
author | nenolod |
---|---|
date | Sat, 03 Jun 2006 11:46:48 -0700 |
parents | cb178e5ad177 |
children | f12d7e208b43 |
line wrap: on
line source
/* BMP - Cross-platform multimedia player * Copyright (C) 2003-2004 BMP development team. * * Based on XMMS: * Copyright (C) 1998-2003 XMMS development team. * * 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. */ #include "effect.h" #include <glib.h> #include <string.h> #include "plugin.h" EffectPluginData ep_data = { NULL, NULL, FALSE, FALSE }; static gint effect_do_mod_samples(gpointer * data, gint length, AFormat fmt, gint srate, gint nch) { GList *l = ep_data.enabled_list; while (l) { if (l->data) { EffectPlugin *ep = l->data; if (ep->mod_samples) length = ep->mod_samples(data, length, fmt, srate, nch); } l = g_list_next(l); } return length; } static void effect_do_query_format(AFormat * fmt, gint * rate, gint * nch) { GList *l = ep_data.enabled_list; while (l) { if (l->data) { EffectPlugin *ep = l->data; if (ep->query_format) ep->query_format(fmt, rate, nch); } l = g_list_next(l); } } static EffectPlugin pseudo_effect_plugin = { NULL, NULL, "XMMS Multiple Effects Support", NULL, NULL, NULL, NULL, effect_do_mod_samples, effect_do_query_format }; /* get_current_effect_plugin() and effects_enabled() are still to be used by * output plugins as they were when we only supported one effects plugin at * a time. We now had a pseudo-effects-plugin that chains all the enabled * plugins. -- Jakdaw */ EffectPlugin * get_current_effect_plugin(void) { return &pseudo_effect_plugin; } gboolean effects_enabled(void) { return TRUE; } GList * get_effect_enabled_list(void) { return ep_data.enabled_list; } void effect_about(int i) { EffectPlugin *effect; GList *node = g_list_nth(ep_data.effect_list, i); if (node) { effect = node->data; if (effect && effect->about) effect->about(); } } void effect_configure(int i) { GList *node = g_list_nth(ep_data.effect_list, i); EffectPlugin *effect; if (node) { effect = node->data; if (effect && effect->configure) effect->configure(); } } void enable_effect_plugin(int i, gboolean enable) { GList *node = g_list_nth(ep_data.effect_list, i); EffectPlugin *ep; if (!node || !(node->data)) return; ep = node->data; if (enable && !g_list_find(ep_data.enabled_list, ep)) { ep_data.enabled_list = g_list_append(ep_data.enabled_list, ep); if (ep->init) ep->init(); } else if (!enable && g_list_find(ep_data.enabled_list, ep)) { ep_data.enabled_list = g_list_remove(ep_data.enabled_list, ep); if (ep->cleanup) ep->cleanup(); } } GList * get_effect_list(void) { return ep_data.effect_list; } gboolean effect_enabled(int i) { return (g_list_find (ep_data.enabled_list, (EffectPlugin *) g_list_nth(ep_data.effect_list, i)->data) ? TRUE : FALSE); } gchar * effect_stringify_enabled_list(void) { gchar *enalist = NULL, *temp, *temp2; GList *node = ep_data.enabled_list; if (g_list_length(node)) { enalist = g_strdup(g_basename(((EffectPlugin *) node->data)->filename)); node = node->next; while (node) { temp = enalist; temp2 = g_strdup(g_basename(((EffectPlugin *) node->data)->filename)); enalist = g_strconcat(temp, ",", temp2, NULL); g_free(temp); g_free(temp2); node = node->next; } } return enalist; } void effect_enable_from_stringified_list(const gchar * list) { gchar **plugins, *base; GList *node; gint i; EffectPlugin *ep; if (!list || !strcmp(list, "")) return; plugins = g_strsplit(list, ",", 0); for (i = 0; plugins[i]; i++) { node = ep_data.effect_list; while (node) { base = g_path_get_basename((char *) ((EffectPlugin *) node-> data)->filename); if (!strcmp(plugins[i], base)) { ep = node->data; ep_data.enabled_list = g_list_append(ep_data.enabled_list, ep); if (ep->init) ep->init(); } g_free(base); node = node->next; } } g_strfreev(plugins); }