# HG changeset patch # User nenolod # Date 1134577245 28800 # Node ID 72dcd30156cac8b50eccdacf4adb10a7413115a3 # Parent ef5798bfbae2b88fc8bcf7cda1a196f7d52f615d [svn] Very initial start on libaudcore. diff -r ef5798bfbae2 -r 72dcd30156ca Makefile.am --- a/Makefile.am Tue Dec 13 19:03:19 2005 -0800 +++ b/Makefile.am Wed Dec 14 08:20:45 2005 -0800 @@ -1,6 +1,6 @@ ACLOCAL_AMFLAGS = -I m4 -SUBDIRS = intl libaudacious audacious Plugins po icons skin +SUBDIRS = intl libaudacious libaudcore audacious Plugins po icons skin man_MANS = audacious.1 diff -r ef5798bfbae2 -r 72dcd30156ca audacious/Makefile.am --- a/audacious/Makefile.am Tue Dec 13 19:03:19 2005 -0800 +++ b/audacious/Makefile.am Wed Dec 14 08:20:45 2005 -0800 @@ -10,7 +10,8 @@ $(GTK_LIBS) \ $(LIBGLADE_LIBS) \ $(LTLIBINTL) \ - $(top_builddir)/libaudacious/libaudacious.la + $(top_builddir)/libaudacious/libaudacious.la \ + $(top_builddir)/libaudcore/libaudcore.la audacious_CFLAGS = \ $(X_CFLAGS) \ @@ -47,7 +48,6 @@ vis.c vis.h \ svis.c svis.h \ number.c number.h \ - playback.c playback.h \ playstatus.c playstatus.h \ playlist_list.c playlist_list.h \ playlist_slider.c playlist_slider.h \ diff -r ef5798bfbae2 -r 72dcd30156ca audacious/playback.c --- a/audacious/playback.c Tue Dec 13 19:03:19 2005 -0800 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,311 +0,0 @@ -/* 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 Licensse 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. - */ - -#ifdef HAVE_CONFIG_H -# include "config.h" -#endif - -#include -#include -#include -#include -#include -#include - -#include -#include -#include -#include - -#include "libaudacious/util.h" -#include "libaudacious/configdb.h" - -#include "input.h" -#include "main.h" -#include "mainwin.h" -#include "equalizer.h" -#include "output.h" -#include "playlist.h" -#include "playlistwin.h" -#include "playlist_list.h" -#include "skin.h" -#include "skinwin.h" -#include "urldecode.h" -#include "util.h" - - -#include "playback.h" - - -/* FIXME: yuck!! this shouldn't be here... */ -void -bmp_playback_set_random_skin(void) -{ - SkinNode *node; - guint32 randval; - - /* Get a random value to select the skin to use */ - randval = g_random_int_range(0, g_list_length(skinlist)); - node = g_list_nth(skinlist, randval)->data; - bmp_active_skin_load(node->path); -} - -gint -bmp_playback_get_time(void) -{ - if (!bmp_playback_get_playing()) - return -1; - - if (!get_current_input_plugin()) - return -1; - - return get_current_input_plugin()->get_time(); -} - -void -bmp_playback_initiate(void) -{ - const gchar *filename = NULL; - - if (playlist_get_length() == 0) - return; - - if (bmp_playback_get_playing()) - bmp_playback_stop(); - - vis_clear_data(mainwin_vis); - vis_clear_data(playlistwin_vis); - svis_clear_data(mainwin_svis); - mainwin_disable_seekbar(); - - filename = playlist_get_filename_to_play(); - - if (!filename) - return; - - if (!bmp_playback_play_file(filename)) - return; - - if (bmp_playback_get_time() != -1) { - equalizerwin_load_auto_preset(filename); - input_set_eq(cfg.equalizer_active, cfg.equalizer_preamp, - cfg.equalizer_bands); - output_set_eq(cfg.equalizer_active, cfg.equalizer_preamp, - cfg.equalizer_bands); - } - - playlist_check_pos_current(); - mainwin_set_info_text(); -} - -void -bmp_playback_pause(void) -{ - if (!bmp_playback_get_playing()) - return; - - if (!get_current_input_plugin()) - return; - - ip_data.paused = !ip_data.paused; - - if (ip_data.paused) - playstatus_set_status(mainwin_playstatus, STATUS_PAUSE); - else - playstatus_set_status(mainwin_playstatus, STATUS_PLAY); - - if (get_current_input_plugin()->pause) - get_current_input_plugin()->pause(ip_data.paused); -} - -void -bmp_playback_stop(void) -{ - if (ip_data.playing && get_current_input_plugin()) { - ip_data.playing = FALSE; - - if (bmp_playback_get_paused()) - bmp_playback_pause(); - - if (get_current_input_plugin()->stop) - get_current_input_plugin()->stop(); - - free_vis_data(); - ip_data.paused = FALSE; - - if (input_info_text) { - g_free(input_info_text); - input_info_text = NULL; - mainwin_set_info_text(); - } - } - - ip_data.playing = FALSE; -} - -void -bmp_playback_stop_reentrant(void) -{ - if (ip_data.playing && get_current_input_plugin()) { - ip_data.playing = FALSE; - - if (bmp_playback_get_paused()) - bmp_playback_pause(); - - free_vis_data(); - ip_data.paused = FALSE; - - if (input_info_text) { - g_free(input_info_text); - input_info_text = NULL; - mainwin_set_info_text(); - } - } - - ip_data.playing = FALSE; -} - -static void -run_no_output_plugin_dialog(void) -{ - const gchar *markup = - N_("No output plugin selected.\n" - "You have not selected an output plugin."); - - GtkWidget *dialog = - gtk_message_dialog_new_with_markup(GTK_WINDOW(mainwin), - GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_MESSAGE_ERROR, - GTK_BUTTONS_OK, - _(markup)); - gtk_dialog_run(GTK_DIALOG(dialog)); - gtk_widget_destroy(dialog); -} - -gboolean -bmp_playback_play_file(const gchar * filename) -{ - GList *node; - InputPlugin *ip; - gchar *filename_proxy; - - g_return_val_if_fail(filename != NULL, FALSE); - - if (!get_current_output_plugin()) { - run_no_output_plugin_dialog(); - mainwin_stop_pushed(); - return FALSE; - } - - if (cfg.random_skin_on_play) - bmp_playback_set_random_skin(); - - filename_proxy = g_strdup(filename); - - node = get_input_list(); - node = g_list_first(node); - - while (node) { - - ip = node->data; - - if (!ip) - break; - - if (ip && input_is_enabled(ip->filename) && - ip->is_our_file(filename_proxy)) { - - - set_current_input_plugin(ip); - ip->output = get_current_output_plugin(); - ip->play_file(filename_proxy); - - /* FIXME: Why the hell (yes,hell!) doesn't the input - plugin set this itself???? -mderezynski */ - ip_data.playing = TRUE; - - g_free(filename_proxy); - return TRUE; - } - node = g_list_next(node); - } - - input_file_not_playable(filename); - set_current_input_plugin(NULL); - mainwin_set_info_text(); - - g_free(filename_proxy); - - return FALSE; -} - -gboolean -bmp_playback_get_playing(void) -{ - return ip_data.playing; -} - -gboolean -bmp_playback_get_paused(void) -{ - return ip_data.paused; -} - -void -bmp_playback_seek(gint time) -{ - gboolean restore_pause = FALSE; - gint l=0, r=0; - - if (!ip_data.playing) - return; - - if (!get_current_input_plugin()) - return; - - /* FIXME WORKAROUND...that should work with all plugins - * mute the volume, start playback again, do the seek, then pause again - * -Patrick Sudowe */ - if(ip_data.paused) - { - restore_pause = TRUE; - output_get_volume(&l, &r); - output_set_volume(0,0); - bmp_playback_pause(); - } - - free_vis_data(); - get_current_input_plugin()->seek(time); - - if(restore_pause) - { - bmp_playback_pause(); - output_set_volume(l, r); - } -} - -void -bmp_playback_seek_relative(gint offset) -{ - gint time = CLAMP(bmp_playback_get_time() / 1000 + offset, - 0, playlist_get_current_length() / 1000 - 1); - bmp_playback_seek(time); -} diff -r ef5798bfbae2 -r 72dcd30156ca audacious/playback.h --- a/audacious/playback.h Tue Dec 13 19:03:19 2005 -0800 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,36 +0,0 @@ -/* BMP - Cross-platform multimedia player - * Copyright (C) 2003-2004 BMP 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. - */ - -#ifndef PLAYBACK_H -#define PLAYBACK_H - -#include - -void bmp_playback_set_random_skin(void); -gint bmp_playback_get_time(void); -void bmp_playback_initiate(void); -void bmp_playback_pause(void); -void bmp_playback_stop(void); -void bmp_playback_stop_reentrant(void); -gboolean bmp_playback_play_file(const gchar * filename); -gboolean bmp_playback_get_playing(void); -gboolean bmp_playback_get_paused(void); -void bmp_playback_seek(gint time); -void bmp_playback_seek_relative(gint offset); - -#endif diff -r ef5798bfbae2 -r 72dcd30156ca configure.ac --- a/configure.ac Tue Dec 13 19:03:19 2005 -0800 +++ b/configure.ac Wed Dec 14 08:20:45 2005 -0800 @@ -719,6 +719,7 @@ audacious/glade/Makefile audacious/images/Makefile libaudacious/Makefile + libaudcore/Makefile Plugins/Makefile Plugins/Output/Makefile Plugins/Output/OSS/Makefile diff -r ef5798bfbae2 -r 72dcd30156ca libaudcore/Makefile.am --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libaudcore/Makefile.am Wed Dec 14 08:20:45 2005 -0800 @@ -0,0 +1,23 @@ +ACLOCAL_AMFLAGS = -I ../m4 +AUTOMAKE_OPTIONS = foreign + +beepincludedir = $(includedir)/audacious + +lib_LTLIBRARIES = libaudacore.la + +libaudcore_la_LDFLAGS = -export-dynamic -version-info $(LIBBEEP_MAJOR_VERSION):$(LIBBEEP_MINOR_VERSION):$(LIBBEEP_MICRO_VERSION) + +libaudcore_la_LIBADD = \ + $(GTK_LIBS) \ + $(GCONF_LIBS) \ + $(GNOMEVFS_LIBS) + +INCLUDES = \ + $(GTK_CFLAGS) \ + $(GCONF_CFLAGS) \ + $(GNOMEVFS_CFLAGS) \ + -I$(top_srcdir) \ + -I$(top_srcdir)/intl + +libaudcore_la_SOURCES = \ + playback.c playback.h diff -r ef5798bfbae2 -r 72dcd30156ca libaudcore/playback.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libaudcore/playback.c Wed Dec 14 08:20:45 2005 -0800 @@ -0,0 +1,311 @@ +/* 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 Licensse 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. + */ + +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include + +#include "libaudacious/util.h" +#include "libaudacious/configdb.h" + +#include "input.h" +#include "main.h" +#include "mainwin.h" +#include "equalizer.h" +#include "output.h" +#include "playlist.h" +#include "playlistwin.h" +#include "playlist_list.h" +#include "skin.h" +#include "skinwin.h" +#include "urldecode.h" +#include "util.h" + + +#include "playback.h" + + +/* FIXME: yuck!! this shouldn't be here... */ +void +bmp_playback_set_random_skin(void) +{ + SkinNode *node; + guint32 randval; + + /* Get a random value to select the skin to use */ + randval = g_random_int_range(0, g_list_length(skinlist)); + node = g_list_nth(skinlist, randval)->data; + bmp_active_skin_load(node->path); +} + +gint +bmp_playback_get_time(void) +{ + if (!bmp_playback_get_playing()) + return -1; + + if (!get_current_input_plugin()) + return -1; + + return get_current_input_plugin()->get_time(); +} + +void +bmp_playback_initiate(void) +{ + const gchar *filename = NULL; + + if (playlist_get_length() == 0) + return; + + if (bmp_playback_get_playing()) + bmp_playback_stop(); + + vis_clear_data(mainwin_vis); + vis_clear_data(playlistwin_vis); + svis_clear_data(mainwin_svis); + mainwin_disable_seekbar(); + + filename = playlist_get_filename_to_play(); + + if (!filename) + return; + + if (!bmp_playback_play_file(filename)) + return; + + if (bmp_playback_get_time() != -1) { + equalizerwin_load_auto_preset(filename); + input_set_eq(cfg.equalizer_active, cfg.equalizer_preamp, + cfg.equalizer_bands); + output_set_eq(cfg.equalizer_active, cfg.equalizer_preamp, + cfg.equalizer_bands); + } + + playlist_check_pos_current(); + mainwin_set_info_text(); +} + +void +bmp_playback_pause(void) +{ + if (!bmp_playback_get_playing()) + return; + + if (!get_current_input_plugin()) + return; + + ip_data.paused = !ip_data.paused; + + if (ip_data.paused) + playstatus_set_status(mainwin_playstatus, STATUS_PAUSE); + else + playstatus_set_status(mainwin_playstatus, STATUS_PLAY); + + if (get_current_input_plugin()->pause) + get_current_input_plugin()->pause(ip_data.paused); +} + +void +bmp_playback_stop(void) +{ + if (ip_data.playing && get_current_input_plugin()) { + ip_data.playing = FALSE; + + if (bmp_playback_get_paused()) + bmp_playback_pause(); + + if (get_current_input_plugin()->stop) + get_current_input_plugin()->stop(); + + free_vis_data(); + ip_data.paused = FALSE; + + if (input_info_text) { + g_free(input_info_text); + input_info_text = NULL; + mainwin_set_info_text(); + } + } + + ip_data.playing = FALSE; +} + +void +bmp_playback_stop_reentrant(void) +{ + if (ip_data.playing && get_current_input_plugin()) { + ip_data.playing = FALSE; + + if (bmp_playback_get_paused()) + bmp_playback_pause(); + + free_vis_data(); + ip_data.paused = FALSE; + + if (input_info_text) { + g_free(input_info_text); + input_info_text = NULL; + mainwin_set_info_text(); + } + } + + ip_data.playing = FALSE; +} + +static void +run_no_output_plugin_dialog(void) +{ + const gchar *markup = + N_("No output plugin selected.\n" + "You have not selected an output plugin."); + + GtkWidget *dialog = + gtk_message_dialog_new_with_markup(GTK_WINDOW(mainwin), + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_ERROR, + GTK_BUTTONS_OK, + _(markup)); + gtk_dialog_run(GTK_DIALOG(dialog)); + gtk_widget_destroy(dialog); +} + +gboolean +bmp_playback_play_file(const gchar * filename) +{ + GList *node; + InputPlugin *ip; + gchar *filename_proxy; + + g_return_val_if_fail(filename != NULL, FALSE); + + if (!get_current_output_plugin()) { + run_no_output_plugin_dialog(); + mainwin_stop_pushed(); + return FALSE; + } + + if (cfg.random_skin_on_play) + bmp_playback_set_random_skin(); + + filename_proxy = g_strdup(filename); + + node = get_input_list(); + node = g_list_first(node); + + while (node) { + + ip = node->data; + + if (!ip) + break; + + if (ip && input_is_enabled(ip->filename) && + ip->is_our_file(filename_proxy)) { + + + set_current_input_plugin(ip); + ip->output = get_current_output_plugin(); + ip->play_file(filename_proxy); + + /* FIXME: Why the hell (yes,hell!) doesn't the input + plugin set this itself???? -mderezynski */ + ip_data.playing = TRUE; + + g_free(filename_proxy); + return TRUE; + } + node = g_list_next(node); + } + + input_file_not_playable(filename); + set_current_input_plugin(NULL); + mainwin_set_info_text(); + + g_free(filename_proxy); + + return FALSE; +} + +gboolean +bmp_playback_get_playing(void) +{ + return ip_data.playing; +} + +gboolean +bmp_playback_get_paused(void) +{ + return ip_data.paused; +} + +void +bmp_playback_seek(gint time) +{ + gboolean restore_pause = FALSE; + gint l=0, r=0; + + if (!ip_data.playing) + return; + + if (!get_current_input_plugin()) + return; + + /* FIXME WORKAROUND...that should work with all plugins + * mute the volume, start playback again, do the seek, then pause again + * -Patrick Sudowe */ + if(ip_data.paused) + { + restore_pause = TRUE; + output_get_volume(&l, &r); + output_set_volume(0,0); + bmp_playback_pause(); + } + + free_vis_data(); + get_current_input_plugin()->seek(time); + + if(restore_pause) + { + bmp_playback_pause(); + output_set_volume(l, r); + } +} + +void +bmp_playback_seek_relative(gint offset) +{ + gint time = CLAMP(bmp_playback_get_time() / 1000 + offset, + 0, playlist_get_current_length() / 1000 - 1); + bmp_playback_seek(time); +} diff -r ef5798bfbae2 -r 72dcd30156ca libaudcore/playback.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libaudcore/playback.h Wed Dec 14 08:20:45 2005 -0800 @@ -0,0 +1,36 @@ +/* BMP - Cross-platform multimedia player + * Copyright (C) 2003-2004 BMP 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. + */ + +#ifndef PLAYBACK_H +#define PLAYBACK_H + +#include + +void bmp_playback_set_random_skin(void); +gint bmp_playback_get_time(void); +void bmp_playback_initiate(void); +void bmp_playback_pause(void); +void bmp_playback_stop(void); +void bmp_playback_stop_reentrant(void); +gboolean bmp_playback_play_file(const gchar * filename); +gboolean bmp_playback_get_playing(void); +gboolean bmp_playback_get_paused(void); +void bmp_playback_seek(gint time); +void bmp_playback_seek_relative(gint offset); + +#endif