aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/screen_artist.c15
-rw-r--r--src/screen_browser.c31
-rw-r--r--src/screen_browser.h10
-rw-r--r--src/screen_file.c18
-rw-r--r--src/screen_search.c14
5 files changed, 39 insertions, 49 deletions
diff --git a/src/screen_artist.c b/src/screen_artist.c
index a83900395..c5d5a268b 100644
--- a/src/screen_artist.c
+++ b/src/screen_artist.c
@@ -84,20 +84,9 @@ artist_lw_callback(unsigned idx, mpd_unused int *highlight, mpd_unused void *dat
/* the playlist have been updated -> fix highlights */
static void
-playlist_changed_callback(mpdclient_t *c, int event, mpd_unused gpointer data)
+playlist_changed_callback(mpdclient_t *c, int event, gpointer data)
{
- if (browser.filelist == NULL)
- return;
-
- D("screen_artist.c> playlist_callback() [%d]\n", event);
- switch(event) {
- case PLAYLIST_EVENT_CLEAR:
- clear_highlights(browser.filelist);
- break;
- default:
- sync_highlights(c, browser.filelist);
- break;
- }
+ browser_playlist_changed(&browser, c, event, data);
}
/* fetch artists/albums/songs from mpd */
diff --git a/src/screen_browser.c b/src/screen_browser.c
index 737b13875..406d205cd 100644
--- a/src/screen_browser.c
+++ b/src/screen_browser.c
@@ -37,7 +37,7 @@
#define HIGHLIGHT (0x01)
/* clear the highlight flag for all items in the filelist */
-void
+static void
clear_highlights(mpdclient_filelist_t *fl)
{
GList *list = g_list_first(fl->list);
@@ -51,7 +51,7 @@ clear_highlights(mpdclient_filelist_t *fl)
}
/* change the highlight flag for a song */
-void
+static void
set_highlight(mpdclient_filelist_t *fl, mpd_Song *song, int highlight)
{
GList *list = g_list_first(fl->list);
@@ -99,6 +99,33 @@ sync_highlights(mpdclient_t *c, mpdclient_filelist_t *fl)
}
}
+/* the playlist have been updated -> fix highlights */
+void
+browser_playlist_changed(struct screen_browser *browser, mpdclient_t *c,
+ int event, gpointer data)
+{
+ if (browser->filelist == NULL)
+ return;
+
+ D("screen_file.c> playlist_callback() [%d]\n", event);
+ switch(event) {
+ case PLAYLIST_EVENT_CLEAR:
+ clear_highlights(browser->filelist);
+ break;
+ case PLAYLIST_EVENT_ADD:
+ set_highlight(browser->filelist, (mpd_Song *) data, 1);
+ break;
+ case PLAYLIST_EVENT_DELETE:
+ set_highlight(browser->filelist, (mpd_Song *) data, 0);
+ break;
+ case PLAYLIST_EVENT_MOVE:
+ break;
+ default:
+ sync_highlights(c, browser->filelist);
+ break;
+ }
+}
+
/* list_window callback */
const char *
browser_lw_callback(unsigned idx, int *highlight, void *data)
diff --git a/src/screen_browser.h b/src/screen_browser.h
index fbe131c58..a867eda0a 100644
--- a/src/screen_browser.h
+++ b/src/screen_browser.h
@@ -36,12 +36,12 @@ struct screen_browser {
mpdclient_filelist_t *filelist;
};
-void clear_highlights(mpdclient_filelist_t *filelist);
-void sync_highlights(mpdclient_t *c, mpdclient_filelist_t *filelist);
-void set_highlight(mpdclient_filelist_t *filelist,
- mpd_Song *song,
- int highlight);
+void
+sync_highlights(mpdclient_t *c, mpdclient_filelist_t *fl);
+void
+browser_playlist_changed(struct screen_browser *browser, mpdclient_t *c,
+ int event, gpointer data);
const char *browser_lw_callback(unsigned index, int *highlight, void *filelist);
diff --git a/src/screen_file.c b/src/screen_file.c
index 801c61f9f..ea20f9506 100644
--- a/src/screen_file.c
+++ b/src/screen_file.c
@@ -53,23 +53,7 @@ file_changed_callback(mpdclient_t *c, mpd_unused int event,
static void
playlist_changed_callback(mpdclient_t *c, int event, gpointer data)
{
- D("screen_file.c> playlist_callback() [%d]\n", event);
- switch(event) {
- case PLAYLIST_EVENT_CLEAR:
- clear_highlights(browser.filelist);
- break;
- case PLAYLIST_EVENT_ADD:
- set_highlight(browser.filelist, (mpd_Song *) data, 1);
- break;
- case PLAYLIST_EVENT_DELETE:
- set_highlight(browser.filelist, (mpd_Song *) data, 0);
- break;
- case PLAYLIST_EVENT_MOVE:
- break;
- default:
- sync_highlights(c, browser.filelist);
- break;
- }
+ browser_playlist_changed(&browser, c, event, data);
}
static int
diff --git a/src/screen_search.c b/src/screen_search.c
index 365a23c6f..549221e74 100644
--- a/src/screen_search.c
+++ b/src/screen_search.c
@@ -142,19 +142,9 @@ lw_search_help_callback(unsigned idx, mpd_unused int *highlight,
/* the playlist have been updated -> fix highlights */
static void
-playlist_changed_callback(mpdclient_t *c, int event, mpd_unused gpointer data)
+playlist_changed_callback(mpdclient_t *c, int event, gpointer data)
{
- if (browser.filelist == NULL)
- return;
- D("screen_search.c> playlist_callback() [%d]\n", event);
- switch(event) {
- case PLAYLIST_EVENT_CLEAR:
- clear_highlights(browser.filelist);
- break;
- default:
- sync_highlights(c, browser.filelist);
- break;
- }
+ browser_playlist_changed(&browser, c, event, data);
}
/* sanity check search mode value */