X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Flibrary.c;h=db9ff24d8ebc0eebc00b1452fa6d41f100e85de6;hb=f717f5b0949cf55190ebe9bb41aa07fa7fd545e1;hp=ab6cee7c2d34535ac46b9944d2e0f16df8a1b200;hpb=dbdc240caac90c4a20c3055f39be26b3d0cdf685;p=omnplay diff --git a/src/library.c b/src/library.c index ab6cee7..db9ff24 100644 --- a/src/library.c +++ b/src/library.c @@ -224,45 +224,35 @@ void omnplay_library_save(omnplay_instance_t* app) static void omnplay_get_content_cb(omnplay_instance_t* app, playlist_item_t* item, void* data) { - gdk_threads_enter(); - gtk_label_set_text(GTK_LABEL(data), item->id); - gdk_flush(); - gdk_threads_leave(); + omnplay_set_status(app, item->id); }; static void* omnplay_library_refresh_proc(void* data) { - GtkWidget *refresh_ui[2]; omnplay_instance_t* app = (omnplay_instance_t*)data; int count, i; playlist_item_t* items; -#ifndef _WIN32 gdk_threads_enter(); -#endif /* _WIN32 */ - /* create UI for monitoring update */ - ui_library_refresh(app, &refresh_ui[0], &refresh_ui[1]); - gtk_widget_show_all(refresh_ui[0]); - gtk_window_present(GTK_WINDOW(refresh_ui[0])); -#ifndef _WIN32 + gtk_widget_set_sensitive(app->window, FALSE); gdk_flush(); gdk_threads_leave(); -#endif /* _WIN32 */ + + omnplay_set_status(app, "Updating library..."); items = (playlist_item_t*)malloc(sizeof(playlist_item_t) * MAX_LIBRARY_ITEMS); - count = omnplay_get_content(app, items, MAX_LIBRARY_ITEMS, omnplay_get_content_cb, refresh_ui[1]); + count = omnplay_get_content(app, items, MAX_LIBRARY_ITEMS, omnplay_get_content_cb, NULL); if(count > 0) { - gdk_threads_enter(); - gtk_label_set_text(GTK_LABEL(refresh_ui[1]), "Quering whois..."); - gdk_flush(); - gdk_threads_leave(); + omnplay_set_status(app, "Quering whois..."); if(app->library.whois[0]) omnplay_whois_list(app, items, &count); + omnplay_set_status(app, "Setting library..."); + pthread_mutex_lock(&app->library.lock); for(i = 0; i < count; i++) @@ -280,6 +270,8 @@ static void* omnplay_library_refresh_proc(void* data) gdk_threads_leave(); }; + omnplay_set_status(app, "Normalizing playlist..."); + free(items); gdk_threads_enter(); @@ -287,26 +279,24 @@ static void* omnplay_library_refresh_proc(void* data) gdk_flush(); gdk_threads_leave(); -#ifndef _WIN32 + omnplay_set_status(app, ""); + gdk_threads_enter(); -#endif /* _WIN32 */ - gtk_widget_destroy(refresh_ui[0]); -#ifndef _WIN32 + gtk_widget_set_sensitive(app->window, TRUE); gdk_flush(); gdk_threads_leave(); -#endif /* _WIN32 */ + return NULL; }; void omnplay_library_refresh(omnplay_instance_t* app) { - if(app->library.refresh_thread_r) - pthread_join(app->library.refresh_thread, NULL); - app->library.refresh_thread_r = 1; + if(app->library.refresh_thread) + g_thread_join(app->library.refresh_thread); - pthread_create(&app->library.refresh_thread, NULL, - omnplay_library_refresh_proc, app); + app->library.refresh_thread = g_thread_create( + omnplay_library_refresh_proc, app, TRUE, NULL); }; void omnplay_library_draw(omnplay_instance_t* app)