Merge pull request #217 from chme/spotifycleanupafterupdate

[spotify/artwork] Remove spotify songs after playlist update and delete
This commit is contained in:
ejurgensen 2016-01-17 12:57:39 +01:00
commit e08b91d6ca
4 changed files with 65 additions and 2 deletions

View File

@ -1050,6 +1050,8 @@ cache_artwork_delete_by_path_impl(struct cache_command *cmd)
return -1; return -1;
} }
DPRINTF(E_DBG, L_CACHE, "Deleted %d rows\n", sqlite3_changes(g_db_hdl));
return 0; return 0;
#undef Q_TMPL_DEL #undef Q_TMPL_DEL

View File

@ -1557,6 +1557,10 @@ db_query_start(struct query_params *qp)
ret = db_build_query_browse(qp, "virtual_path", "virtual_path", &query); ret = db_build_query_browse(qp, "virtual_path", "virtual_path", &query);
break; break;
case Q_BROWSE_PATH:
ret = db_build_query_browse(qp, "path", "path", &query);
break;
case Q_COUNT_ITEMS: case Q_COUNT_ITEMS:
ret = db_build_query_count_items(qp, &query); ret = db_build_query_count_items(qp, &query);
break; break;
@ -3674,11 +3678,10 @@ db_spotify_purge(void)
void void
db_spotify_pl_delete(int id) db_spotify_pl_delete(int id)
{ {
char *queries_tmpl[3] = char *queries_tmpl[2] =
{ {
"DELETE FROM playlists WHERE id = %d;", "DELETE FROM playlists WHERE id = %d;",
"DELETE FROM playlistitems WHERE playlistid = %d;", "DELETE FROM playlistitems WHERE playlistid = %d;",
"DELETE FROM files WHERE path LIKE 'spotify:%%' AND NOT path IN (SELECT filepath FROM playlistitems);",
}; };
char *query; char *query;
int i; int i;
@ -3694,6 +3697,23 @@ db_spotify_pl_delete(int id)
DPRINTF(E_DBG, L_DB, "Deleted %d rows\n", sqlite3_changes(hdl)); DPRINTF(E_DBG, L_DB, "Deleted %d rows\n", sqlite3_changes(hdl));
} }
} }
/* Spotify */
void
db_spotify_files_delete()
{
#define Q_TMPL "DELETE FROM files WHERE path LIKE 'spotify:%%' AND NOT path IN (SELECT filepath FROM playlistitems);"
char *query;
int ret;
query = sqlite3_mprintf(Q_TMPL);
ret = db_query_run(query, 1, 1);
if (ret == 0)
DPRINTF(E_DBG, L_DB, "Deleted %d rows\n", sqlite3_changes(hdl));
#undef Q_TMPL
}
#endif #endif
/* Admin */ /* Admin */

View File

@ -49,6 +49,7 @@ enum query_type {
Q_BROWSE_DISCS = Q_F_BROWSE | 14, Q_BROWSE_DISCS = Q_F_BROWSE | 14,
Q_BROWSE_TRACKS = Q_F_BROWSE | 15, Q_BROWSE_TRACKS = Q_F_BROWSE | 15,
Q_BROWSE_VPATH = Q_F_BROWSE | 16, Q_BROWSE_VPATH = Q_F_BROWSE | 16,
Q_BROWSE_PATH = Q_F_BROWSE | 17,
}; };
#define ARTWORK_UNKNOWN 0 #define ARTWORK_UNKNOWN 0
@ -571,6 +572,9 @@ db_spotify_purge(void);
void void
db_spotify_pl_delete(int id); db_spotify_pl_delete(int id);
void
db_spotify_files_delete();
#endif #endif
/* Admin */ /* Admin */

View File

@ -44,6 +44,7 @@
#include "logger.h" #include "logger.h"
#include "conffile.h" #include "conffile.h"
#include "filescanner.h" #include "filescanner.h"
#include "cache.h"
/* How long to wait for audio (in sec) before giving up */ /* How long to wait for audio (in sec) before giving up */
@ -624,6 +625,39 @@ spotify_track_save(int plid, sp_track *track, const char *pltitle, int time_adde
return 0; return 0;
} }
static int
spotify_playlist_cleanupfiles()
{
struct query_params qp;
char *path;
int ret;
memset(&qp, 0, sizeof(struct query_params));
qp.type = Q_BROWSE_PATH;
qp.sort = S_NONE;
qp.filter = "f.path LIKE 'spotify:%%' AND NOT f.path IN (SELECT filepath FROM playlistitems)";
ret = db_query_start(&qp);
if (ret < 0)
{
db_query_end(&qp);
return -1;
}
while (((ret = db_query_fetch_string(&qp, &path)) == 0) && (path))
{
cache_artwork_delete_by_path(path);
}
db_query_end(&qp);
db_spotify_files_delete();
return 0;
}
static int static int
spotify_playlist_save(sp_playlist *pl) spotify_playlist_save(sp_playlist *pl)
{ {
@ -758,6 +792,8 @@ spotify_playlist_save(sp_playlist *pl)
continue; continue;
} }
} }
spotify_playlist_cleanupfiles();
db_transaction_end(); db_transaction_end();
return plid; return plid;
@ -873,6 +909,7 @@ playlist_removed(sp_playlistcontainer *pc, sp_playlist *pl, int position, void *
free_pli(pli, 0); free_pli(pli, 0);
db_spotify_pl_delete(plid); db_spotify_pl_delete(plid);
spotify_playlist_cleanupfiles();
} }
/** /**