Mercurial > audlegacy
diff src/audacious/effect.c @ 2313:3149d4b1a9a9 trunk
[svn] - objective-make autodepend fixes
- move all sourcecode into src/ and adjust Makefiles accordingly
author | nenolod |
---|---|
date | Fri, 12 Jan 2007 11:43:40 -0800 |
parents | |
children | cfc8431aceb5 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/audacious/effect.c Fri Jan 12 11:43:40 2007 -0800 @@ -0,0 +1,220 @@ +/* + * Audacious - Cross-platform multimedia player + * Copyright (C) 2005-2007 Audacious dvelopment team. + * + * Based on BMP: + * 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; under version 2 of the License. + * + * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, 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); +}