diff options
author | 2010-03-21 14:37:47 +0100 | |
---|---|---|
committer | 2010-03-21 14:37:47 +0100 | |
commit | 3b2fe9613863354ed34940688242703e75ca541f (patch) | |
tree | 99473f4da7381a54b167d06bdbe1bda256a61684 /plugins/gtkui | |
parent | 61a055d0155900655897fecce3e1b799056cf90a (diff) |
fixed redraw of playing track after decoder->init failure
Diffstat (limited to 'plugins/gtkui')
-rw-r--r-- | plugins/gtkui/plcommon.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/plugins/gtkui/plcommon.c b/plugins/gtkui/plcommon.c index ca08d8ac..6c1cf8f6 100644 --- a/plugins/gtkui/plcommon.c +++ b/plugins/gtkui/plcommon.c @@ -77,6 +77,7 @@ void draw_column_data (DdbListview *listview, GdkDrawable *drawable, DdbListview if (res == -1) { return; } + DB_playItem_t *playing_track = deadbeef->streamer_get_playing_track (); if (cinf->id == DB_COLUMN_ALBUM_ART) { gtk_paint_flat_box (theme_treeview->style, drawable, GTK_STATE_NORMAL, GTK_SHADOW_NONE, NULL, theme_treeview, "cell_even_ruled", x, y, width, height); int art_width = width - ART_PADDING_HORZ * 2; @@ -115,7 +116,7 @@ void draw_column_data (DdbListview *listview, GdkDrawable *drawable, DdbListview } } } - else if (it && it == deadbeef->streamer_get_playing_track () && cinf->id == DB_COLUMN_PLAYING) { + else if (it && it == playing_track && cinf->id == DB_COLUMN_PLAYING) { int paused = deadbeef->get_output ()->state () == OUTPUT_STATE_PAUSED; int buffering = !deadbeef->streamer_ok_to_read (-1); GdkPixbuf *pixbuf; @@ -150,6 +151,9 @@ void draw_column_data (DdbListview *listview, GdkDrawable *drawable, DdbListview draw_text (x + 5, y + height/2 - draw_get_font_size ()/2 - 2, cwidth-10, 0, text); } } + if (playing_track) { + deadbeef->pl_item_unref (playing_track); + } } void |