[spotify] Split into smaller db transactions (do not keep an open

transaction between requests)
This commit is contained in:
chme 2017-01-08 07:56:41 +01:00
parent f632789f8b
commit 03c5ecd690

View File

@ -2248,6 +2248,8 @@ scan_playlisttracks(struct spotify_playlist *playlist, int plid)
while (0 == spotifywebapi_request_next(&request, playlist->tracks_href)) while (0 == spotifywebapi_request_next(&request, playlist->tracks_href))
{ {
db_transaction_begin();
// DPRINTF(E_DBG, L_SPOTIFY, "Playlist tracks\n%s\n", request.response_body); // DPRINTF(E_DBG, L_SPOTIFY, "Playlist tracks\n%s\n", request.response_body);
while (0 == spotifywebapi_playlisttracks_fetch(&request, &track)) while (0 == spotifywebapi_playlisttracks_fetch(&request, &track))
{ {
@ -2270,6 +2272,8 @@ scan_playlisttracks(struct spotify_playlist *playlist, int plid)
db_pl_add_item_bypath(plid, track.uri); db_pl_add_item_bypath(plid, track.uri);
} }
} }
db_transaction_end();
} }
spotifywebapi_request_end(&request); spotifywebapi_request_end(&request);
@ -2286,8 +2290,10 @@ scan_playlists()
char virtual_path[PATH_MAX]; char virtual_path[PATH_MAX];
int plid; int plid;
int count; int count;
int trackcount;
count = 0; count = 0;
trackcount = 0;
memset(&request, 0, sizeof(struct spotify_request)); memset(&request, 0, sizeof(struct spotify_request));
while (0 == spotifywebapi_request_next(&request, SPOTIFY_WEBAPI_SAVED_PLAYLISTS)) while (0 == spotifywebapi_request_next(&request, SPOTIFY_WEBAPI_SAVED_PLAYLISTS))
@ -2296,8 +2302,6 @@ scan_playlists()
{ {
DPRINTF(E_DBG, L_SPOTIFY, "Got playlist: '%s' with %d tracks (%s) \n", playlist.name, playlist.tracks_count, playlist.uri); DPRINTF(E_DBG, L_SPOTIFY, "Got playlist: '%s' with %d tracks (%s) \n", playlist.name, playlist.tracks_count, playlist.uri);
db_transaction_begin();
if (playlist.owner) if (playlist.owner)
{ {
snprintf(virtual_path, PATH_MAX, "/spotify:/%s (%s)", playlist.name, playlist.owner); snprintf(virtual_path, PATH_MAX, "/spotify:/%s (%s)", playlist.name, playlist.owner);
@ -2307,18 +2311,18 @@ scan_playlists()
snprintf(virtual_path, PATH_MAX, "/spotify:/%s", playlist.name); snprintf(virtual_path, PATH_MAX, "/spotify:/%s", playlist.name);
} }
db_transaction_begin();
plid = library_add_playlist_info(playlist.uri, playlist.name, virtual_path, PL_PLAIN, spotify_base_plid, DIR_SPOTIFY); plid = library_add_playlist_info(playlist.uri, playlist.name, virtual_path, PL_PLAIN, spotify_base_plid, DIR_SPOTIFY);
db_transaction_end();
if (plid > 0) if (plid > 0)
scan_playlisttracks(&playlist, plid); scan_playlisttracks(&playlist, plid);
else else
DPRINTF(E_LOG, L_SPOTIFY, "Error adding playlist: '%s' (%s) \n", playlist.name, playlist.uri); DPRINTF(E_LOG, L_SPOTIFY, "Error adding playlist: '%s' (%s) \n", playlist.name, playlist.uri);
db_transaction_end();
count++; count++;
if (count >= request.total || (count % 10 == 0)) trackcount += playlist.tracks_count;
DPRINTF(E_LOG, L_SPOTIFY, "Scanned %d of %d saved playlists\n", count, request.total); DPRINTF(E_LOG, L_SPOTIFY, "Scanned %d of %d saved playlists (%d tracks)\n", count, request.total, trackcount);
} }
} }
@ -2348,8 +2352,6 @@ scan_playlist(const char *uri)
{ {
DPRINTF(E_DBG, L_SPOTIFY, "Got playlist: '%s' with %d tracks (%s) \n", playlist.name, playlist.tracks_count, playlist.uri); DPRINTF(E_DBG, L_SPOTIFY, "Got playlist: '%s' with %d tracks (%s) \n", playlist.name, playlist.tracks_count, playlist.uri);
db_transaction_begin();
if (playlist.owner) if (playlist.owner)
{ {
snprintf(virtual_path, PATH_MAX, "/spotify:/%s (%s)", playlist.name, playlist.owner); snprintf(virtual_path, PATH_MAX, "/spotify:/%s (%s)", playlist.name, playlist.owner);
@ -2359,14 +2361,14 @@ scan_playlist(const char *uri)
snprintf(virtual_path, PATH_MAX, "/spotify:/%s", playlist.name); snprintf(virtual_path, PATH_MAX, "/spotify:/%s", playlist.name);
} }
db_transaction_begin();
plid = library_add_playlist_info(playlist.uri, playlist.name, virtual_path, PL_PLAIN, spotify_base_plid, DIR_SPOTIFY); plid = library_add_playlist_info(playlist.uri, playlist.name, virtual_path, PL_PLAIN, spotify_base_plid, DIR_SPOTIFY);
db_transaction_end();
if (plid > 0) if (plid > 0)
scan_playlisttracks(&playlist, plid); scan_playlisttracks(&playlist, plid);
else else
DPRINTF(E_LOG, L_SPOTIFY, "Error adding playlist: '%s' (%s) \n", playlist.name, playlist.uri); DPRINTF(E_LOG, L_SPOTIFY, "Error adding playlist: '%s' (%s) \n", playlist.name, playlist.uri);
db_transaction_end();
} }
} }