# HG changeset patch # User Cristi Magherusan # Date 1190490657 -10800 # Node ID 24ae9b303a9dc46fb556d88104e9f8960de57839 # Parent 9fd97ab30fdc40c5ab819658c29f079272556144 removed lastfm from the core, rewriting it as a plugin diff -r 9fd97ab30fdc -r 24ae9b303a9d po/POTFILES.in --- a/po/POTFILES.in Sun Sep 23 01:34:10 2007 +0900 +++ b/po/POTFILES.in Sat Sep 22 22:50:57 2007 +0300 @@ -17,7 +17,6 @@ src/audacious/ui_fileinfopopup.c src/audacious/ui_fileopener.c src/audacious/ui_jumptotrack.c -src/audacious/ui_lastfm.c src/audacious/ui_main.c src/audacious/ui_manager.c src/audacious/ui_playlist.c diff -r 9fd97ab30fdc -r 24ae9b303a9d src/audacious/Makefile --- a/src/audacious/Makefile Sun Sep 23 01:34:10 2007 +0900 +++ b/src/audacious/Makefile Sat Sep 22 22:50:57 2007 +0300 @@ -50,7 +50,6 @@ ui_fileinfopopup.c \ ui_fileopener.c \ ui_jumptotrack.c \ - ui_lastfm.c \ ui_main.c \ ui_main_evlisteners.c \ ui_manager.c \ @@ -113,7 +112,6 @@ tuple_formatter.h \ tuple_compiler.h \ ui_fileinfopopup.h \ - ui_lastfm.h \ ui_plugin_menu.h \ ui_preferences.h \ util.h \ diff -r 9fd97ab30fdc -r 24ae9b303a9d src/audacious/actions-mainwin.h --- a/src/audacious/actions-mainwin.h Sun Sep 23 01:34:10 2007 +0900 +++ b/src/audacious/actions-mainwin.h Sat Sep 22 22:50:57 2007 +0300 @@ -73,5 +73,4 @@ void action_preferences(void); void action_quit(void); void action_current_track_info(void); -void action_lastfm(void); #endif diff -r 9fd97ab30fdc -r 24ae9b303a9d src/audacious/ui/mainwin.ui --- a/src/audacious/ui/mainwin.ui Sun Sep 23 01:34:10 2007 +0900 +++ b/src/audacious/ui/mainwin.ui Sat Sep 22 22:50:57 2007 +0300 @@ -14,8 +14,7 @@ - - + diff -r 9fd97ab30fdc -r 24ae9b303a9d src/audacious/ui_lastfm.c --- a/src/audacious/ui_lastfm.c Sun Sep 23 01:34:10 2007 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,377 +0,0 @@ -#include -#include -#include -#include "configdb.h" -#include "playback.h" -#define DEBUG 1 -typedef struct { - gchar *username, - *session; -}last_fm; - -typedef struct -{ - gchar *artist, - *title; -} -track_data; - -last_fm *login_data=NULL; -Playlist *current_playlist=NULL; -GtkWidget *lastfm_url_entry, *lastfm_label,*artist_label,*title_label,*album_label, *gui_window=NULL; - -gpointer open_url(gpointer url) -{ - gchar*s=g_new0(gchar,20); - VFSFile* fd = vfs_fopen((gchar*)url,"r"); - if(fd) - { - vfs_fgets(s,20,fd); - g_print("Got data: '%s'\n",s); - vfs_fclose(fd); - } - g_free(s); - g_free(url); - return NULL; -} -void command(gchar *comm) -{ - /* get the session from mowgli*/ - if(login_data->session) - { - g_free(login_data->session); - login_data->session=NULL; - } - login_data->session = g_strdup(mowgli_global_storage_get("lastfm_session_id")); - gchar *url=g_strdup_printf("http://ws.audioscrobbler.com/radio/control.php?session=%s&command=%s&debug=0",login_data->session,comm); - g_thread_create(open_url,url,FALSE,NULL); - if(!g_str_has_prefix(comm,"love")) - g_thread_create((gpointer)playback_initiate,NULL,FALSE,NULL); - return; - -} -static void change_track_data_cb(gpointer track, gpointer unused) -{ - gchar **inf, - **t, - *alb, - *tr; - tr=g_strdup(((track_data*)track)->title); - - if(tr==NULL) - return ; - if(g_strrstr(tr,"last.fm")==NULL) - { - gtk_entry_set_text(GTK_ENTRY(lastfm_url_entry), _("Not last.fm stream")); - return; - } - -#if DEBUG - g_print("New Track: %s \n",tr); -#endif - if(g_str_has_prefix(tr,"lastfm://")) - return; - if(g_strrstr(tr,"Neighbour")!=NULL) - { - gchar *temp=g_strdup_printf("lastfm://user/%s/neighbours", login_data->username); - gtk_entry_set_text(GTK_ENTRY(lastfm_url_entry),temp); - g_free(temp); - } - if(g_strrstr(tr,"Personal")!=NULL) - { - gchar *temp=g_strdup_printf("lastfm://user/%s/personal", login_data->username); - gtk_entry_set_text(GTK_ENTRY(lastfm_url_entry),temp); - g_free(temp); - } - - inf = g_strsplit(tr," - ",2); - if(inf[0]==NULL || inf[1]==NULL) - return; - gchar* artist_markup=g_strdup_printf(_("Artist: %s") ,inf[0]); - gtk_label_set_markup(GTK_LABEL(artist_label),artist_markup); - g_free(artist_markup); - - t = g_strsplit(inf[1], g_strrstr(inf[1],"("),2); - if(t[0]==NULL) return; - alb = g_strdup(mowgli_global_storage_get("lastfm_album")); - - gchar* title_markup=g_strdup_printf(_("Title: %s") ,t[0]); - gtk_label_set_markup( GTK_LABEL(title_label),title_markup); - g_free(title_markup); - - gchar* album_markup=g_strdup_printf(_("Album: %s") ,alb); - gtk_label_set_markup( GTK_LABEL(album_label),album_markup); - g_free(album_markup); - - g_strfreev(inf); - g_strfreev(t); - g_free(alb); - g_free(tr); - - return ; -} - -static void show_login_error_dialog(void) -{ - const gchar *markup = - _("Couldn't find your lastfm login data.\n\n" - "Check if your Scrobbler's plugin login settings are configured properly.\n"); - - GtkWidget *dialog = - gtk_message_dialog_new_with_markup(NULL, - GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_MESSAGE_ERROR, - GTK_BUTTONS_OK, - _(markup)); - gtk_dialog_run(GTK_DIALOG(dialog)); - gtk_widget_destroy(dialog); -} - - - -void init_last_fm(void) -{ - login_data = g_new0(last_fm,1); - login_data->username = NULL; - login_data->session = NULL; - ConfigDb *cfg = NULL; - - if ((cfg = bmp_cfg_db_open()) != NULL) - { - login_data->username=NULL; - bmp_cfg_db_get_string(cfg, "audioscrobbler","username", - &login_data->username); - if(login_data->username==NULL) - show_login_error_dialog(); - g_free(cfg); - } - - current_playlist = g_new0(Playlist,1); - current_playlist = playlist_get_active(); - track_data * tr=g_new0(track_data,1); - tr->title =NULL; - hook_associate( "playlist set info" , change_track_data_cb ,tr); - -} - -/*event callback functions*/ - -gboolean love_press_callback(GtkWidget *love) -{ - command("love"); - return FALSE; -} - -gboolean skip_press_callback(GtkWidget *skip) -{ - command("skip"); - return FALSE; -} -gboolean ban_press_callback(GtkWidget *ban) -{ - command("ban"); - return FALSE; -} - - -gboolean add_press_callback(GtkWidget *love) -{ - gchar *text=NULL; - gint poz=0; - text = g_strdup(gtk_entry_get_text(GTK_ENTRY(lastfm_url_entry))); - if(playback_get_playing()==TRUE) - playback_stop(); - - poz = playlist_get_length(current_playlist); - playlist_add_url(current_playlist, text); - sleep(1); - playlist_set_position(current_playlist, poz); - playback_initiate(); - g_free(text); - return FALSE; -} - -gboolean neighbours_press_callback(GtkWidget *love) -{ - gchar *temp=g_strdup_printf("lastfm://user/%s/neighbours", login_data->username); - gtk_entry_set_text(GTK_ENTRY(lastfm_url_entry),temp); - g_free(temp); - return FALSE; -} - -gboolean personal_press_callback(GtkWidget *love) -{ - gchar *per=g_strdup_printf("lastfm://user/%s/personal", login_data->username); - gtk_entry_set_text(GTK_ENTRY(lastfm_url_entry),per); - g_free(per); - return FALSE; -} - -gboolean delete_window_callback(GtkWidget *window) -{ - gtk_widget_destroy(window); - window=NULL; - return FALSE; -} -static gboolean keypress_callback(GtkWidget * widget, GdkEventKey * event, gpointer data) -{ - switch (event->keyval) - { - case GDK_Escape: - gtk_widget_hide_all(widget); - break; - default: - return FALSE; - } - return TRUE; -} - - -GtkWidget *ui_lastfm_create(void) -{ - GtkWidget *window; - GtkWidget *box1,*box2,*vboxw,*vbox1,*vbox2,*v_hbox1,*v_hbox2,*labelbox; - GtkWidget *love,*ban,*skip,*add,*neighbours,*personal; - - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_position(GTK_WINDOW(window),GTK_WIN_POS_CENTER); - gtk_window_set_title(GTK_WINDOW(window), _("Audacious last.fm radio tuner")); - lastfm_label = gtk_label_new_with_mnemonic(_("Station:")); - title_label = gtk_label_new(NULL); - artist_label = gtk_label_new(NULL); - album_label = gtk_label_new(NULL); - lastfm_url_entry = gtk_entry_new(); - gtk_editable_set_editable (GTK_EDITABLE(lastfm_url_entry),TRUE); - gchar* artist_markup=g_strdup(_("Artist:")); - gtk_label_set_markup(GTK_LABEL(artist_label),artist_markup); - g_free(artist_markup); - - gchar* title_markup=g_strdup(_("Title:")); - gtk_label_set_markup( GTK_LABEL(title_label),title_markup); - g_free(title_markup); - - gchar* album_markup=g_strdup_printf(_("Album:")); - gtk_label_set_markup( GTK_LABEL(album_label),album_markup); - g_free(album_markup); - - love = gtk_button_new_with_label (_("Love")); - ban = gtk_button_new_with_label (_("Ban")); - skip = gtk_button_new_with_label (_("Skip")); - add = gtk_button_new_with_label (_("Tune in")); - - neighbours = gtk_button_new_with_label(_("Neighbours' radio")); - personal = gtk_button_new_with_label(_("Personal radio")); - - box1 = gtk_hbox_new(FALSE,1); - box2 = gtk_hbox_new(FALSE,1); - - vboxw = gtk_vbox_new(FALSE,1); - - vbox1 = gtk_vbox_new(FALSE,1); - vbox2 = gtk_vbox_new(FALSE,1); - - v_hbox1 = gtk_vbox_new(FALSE,1); - v_hbox2 = gtk_hbox_new(FALSE,1); - labelbox = gtk_vbox_new(FALSE,1); - - gtk_misc_set_alignment(GTK_MISC(artist_label),0,0); - gtk_misc_set_alignment(GTK_MISC(title_label),0,0); - gtk_misc_set_alignment(GTK_MISC(album_label),0,0); - - gtk_box_pack_start(GTK_BOX(vboxw),box1,FALSE,TRUE,1); - gtk_box_pack_end(GTK_BOX(vboxw),box2,TRUE,TRUE,1); - - gtk_box_pack_start(GTK_BOX(box1),lastfm_label,FALSE,TRUE,1); - gtk_box_pack_start(GTK_BOX(box1),lastfm_url_entry,TRUE,TRUE,1); - gtk_box_pack_start(GTK_BOX(box1),add,FALSE,TRUE,1); - - gtk_box_set_spacing(GTK_BOX(box1),2); - gtk_container_set_border_width(GTK_CONTAINER(box1),2); - - gtk_box_pack_start(GTK_BOX(box2),vbox1,FALSE,TRUE,1); - gtk_box_pack_start(GTK_BOX(box2),vbox2,TRUE,TRUE,1); - - gtk_box_pack_start(GTK_BOX(vbox1),neighbours,FALSE,TRUE,3); - gtk_box_pack_start(GTK_BOX(vbox1),personal,FALSE,TRUE,3); - gtk_box_set_spacing(GTK_BOX(vbox1),2); - gtk_container_set_border_width(GTK_CONTAINER(vbox1),2); - - gtk_box_pack_start(GTK_BOX(vbox2),v_hbox1,TRUE,TRUE,1); - gtk_box_pack_start(GTK_BOX(vbox2),v_hbox2,TRUE,TRUE,1); - - gtk_box_pack_start(GTK_BOX(v_hbox1),artist_label,TRUE,TRUE,1); - gtk_box_pack_start(GTK_BOX(v_hbox1),title_label,TRUE,TRUE,1); - gtk_box_pack_start(GTK_BOX(v_hbox1),album_label,TRUE,TRUE,1); - gtk_box_set_spacing(GTK_BOX(v_hbox1),2); - gtk_container_set_border_width(GTK_CONTAINER(v_hbox1),2); - - - gtk_box_pack_start(GTK_BOX(v_hbox2),love,TRUE,TRUE,1); - gtk_box_pack_start(GTK_BOX(v_hbox2),skip,TRUE,TRUE,1); - gtk_box_pack_start(GTK_BOX(v_hbox2),ban,TRUE,TRUE,1); - gtk_box_set_spacing(GTK_BOX(v_hbox1),2); - gtk_container_set_border_width(GTK_CONTAINER(v_hbox1),2); - - - - gtk_container_add (GTK_CONTAINER (window), vboxw); - - g_signal_connect (G_OBJECT (love), "button_press_event",G_CALLBACK (love_press_callback), NULL); - g_signal_connect (G_OBJECT (add), "button_press_event",G_CALLBACK (add_press_callback), NULL); - g_signal_connect (G_OBJECT (ban), "button_press_event",G_CALLBACK (ban_press_callback), NULL); - g_signal_connect (G_OBJECT (skip), "button_press_event",G_CALLBACK (skip_press_callback), NULL); - g_signal_connect (G_OBJECT (neighbours), "button_press_event",G_CALLBACK (neighbours_press_callback), NULL); - g_signal_connect (G_OBJECT (personal), "button_press_event",G_CALLBACK (personal_press_callback), NULL); - g_signal_connect (G_OBJECT (window), "delete_event",G_CALLBACK (gtk_widget_hide_all), window); - g_signal_connect (G_OBJECT (window), "key_press_event",G_CALLBACK(keypress_callback), NULL); - - gtk_widget_set_size_request(GTK_WIDGET(window),400,124); - gtk_window_set_resizable(GTK_WINDOW(window),FALSE); - gtk_widget_show_all(gui_window); - return window; -} -#if 0 -static void no_lastfm_plugin_dialog(void) -{ - const gchar *markup = - N_("The lastfm radio plugin could not be found.\n\n" - "Check if the AudioScrobbler plugin was compiled in\n"); - - GtkWidget *dialog = - gtk_message_dialog_new_with_markup(NULL, - GTK_DIALOG_DESTROY_WITH_PARENT, - GTK_MESSAGE_ERROR, - GTK_BUTTONS_OK, - _(markup)); - gtk_dialog_run(GTK_DIALOG(dialog)); - gtk_widget_destroy(dialog); -} -#endif - - -void ui_lastfm(void) -{ - /*if(!mowgli_global_storage_get("lastfm_loaded")) - { - no_lastfm_plugin_dialog(); - return; - } - */ - init_last_fm(); - if(!gui_window) - { - if((gui_window = ui_lastfm_create())!=NULL); - gtk_widget_show_all(gui_window); - - #if 0 - /*here should be set the artist, title and album labels at the first run, because it isn't captured by the hook*/ - gchar* current_title = playlist_get_songtitle(current_playlist,playlist_get_position(current_playlist)); - if(current_title) - change_track_data_cb(current_title,NULL); -#endif - } - else - gtk_widget_show_all(gui_window); - -} - diff -r 9fd97ab30fdc -r 24ae9b303a9d src/audacious/ui_lastfm.h --- a/src/audacious/ui_lastfm.h Sun Sep 23 01:34:10 2007 +0900 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,1 +0,0 @@ -void ui_lastfm(void); diff -r 9fd97ab30fdc -r 24ae9b303a9d src/audacious/ui_main.c --- a/src/audacious/ui_main.c Sun Sep 23 01:34:10 2007 +0900 +++ b/src/audacious/ui_main.c Sat Sep 22 22:50:57 2007 +0300 @@ -73,7 +73,6 @@ #include "ui_preferences.h" #include "ui_skinselector.h" #include "ui_urlopener.h" -#include "ui_lastfm.h" #include "strings.h" #include "util.h" #include "visualization.h" @@ -1783,9 +1782,6 @@ case MAINWIN_GENERAL_PLAYLOCATION: mainwin_show_add_url_window(); break; - case MAINWIN_GENERAL_LASTFM: - action_lastfm(); - break; case MAINWIN_GENERAL_FILEINFO: playlist_fileinfo_current(playlist); break; @@ -2980,12 +2976,6 @@ } void -action_lastfm( void ) -{ - ui_lastfm(); -} - -void action_jump_to_playlist_start( void ) { Playlist *playlist = playlist_get_active(); diff -r 9fd97ab30fdc -r 24ae9b303a9d src/audacious/ui_main.h --- a/src/audacious/ui_main.h Sun Sep 23 01:34:10 2007 +0900 +++ b/src/audacious/ui_main.h Sat Sep 22 22:50:57 2007 +0300 @@ -53,7 +53,6 @@ MAINWIN_GENERAL_PLAYFILE, MAINWIN_GENERAL_PLAYLOCATION, - MAINWIN_GENERAL_LASTFM, MAINWIN_GENERAL_FILEINFO, MAINWIN_GENERAL_PREFS, diff -r 9fd97ab30fdc -r 24ae9b303a9d src/audacious/ui_manager.c --- a/src/audacious/ui_manager.c Sun Sep 23 01:34:10 2007 +0900 +++ b/src/audacious/ui_manager.c Sat Sep 22 22:50:57 2007 +0300 @@ -397,10 +397,7 @@ { "play location", GTK_STOCK_NETWORK , N_("Play Location"), "L", N_("Play media from the selected location"), G_CALLBACK(action_play_location) }, - { "lastfm", NULL, N_("Last.fm radio"), "L", - N_("Play Last.fm radio"), G_CALLBACK(action_lastfm) }, - - { "plugins", NULL , N_("Plugins") }, + { "plugins", NULL , N_("Plugin services") }, { "preferences", GTK_STOCK_PREFERENCES , N_("Preferences"), "P", N_("Open preferences window"), G_CALLBACK(action_preferences) },