don't count empty playlists
This commit is contained in:
parent
1533d3b33c
commit
6166b8a6d3
|
@ -130,6 +130,8 @@ int db_init(char *parameters) {
|
||||||
*/
|
*/
|
||||||
int db_deinit(void) {
|
int db_deinit(void) {
|
||||||
MP3RECORD *current;
|
MP3RECORD *current;
|
||||||
|
DB_PLAYLIST *plist;
|
||||||
|
DB_PLAYLISTENTRY *pentry;
|
||||||
|
|
||||||
while(db_root.next) {
|
while(db_root.next) {
|
||||||
current=db_root.next;
|
current=db_root.next;
|
||||||
|
@ -137,6 +139,19 @@ int db_deinit(void) {
|
||||||
db_freerecord(current);
|
db_freerecord(current);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
while(db_playlists.next) {
|
||||||
|
plist=db_playlists.next;
|
||||||
|
db_playlists.next=plist->next;
|
||||||
|
free(plist->name);
|
||||||
|
/* free all the nodes */
|
||||||
|
while(plist->nodes) {
|
||||||
|
pentry=plist->nodes;
|
||||||
|
plist->nodes = pentry->next;
|
||||||
|
free(pentry);
|
||||||
|
}
|
||||||
|
free(plist);
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -214,7 +229,8 @@ int db_add_playlist(unsigned int playlistid, char *name) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
db_playlist_count++;
|
/* we'll update playlist count when we add a song! */
|
||||||
|
// db_playlist_count++;
|
||||||
pnew->next=db_playlists.next;
|
pnew->next=db_playlists.next;
|
||||||
db_playlists.next=pnew;
|
db_playlists.next=pnew;
|
||||||
|
|
||||||
|
@ -264,6 +280,9 @@ int db_add_playlist_song(unsigned int playlistid, unsigned int itemid) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(!current->songs)
|
||||||
|
db_playlist_count++;
|
||||||
|
|
||||||
current->songs++;
|
current->songs++;
|
||||||
pnew->next = current->nodes;
|
pnew->next = current->nodes;
|
||||||
current->nodes = pnew;
|
current->nodes = pnew;
|
||||||
|
@ -390,6 +409,7 @@ MP3RECORD *db_enum_begin(void) {
|
||||||
*/
|
*/
|
||||||
DB_PLAYLIST *db_playlist_enum_begin(void) {
|
DB_PLAYLIST *db_playlist_enum_begin(void) {
|
||||||
int err;
|
int err;
|
||||||
|
DB_PLAYLIST *current;
|
||||||
|
|
||||||
if(err=pthread_rwlock_rdlock(&db_rwlock)) {
|
if(err=pthread_rwlock_rdlock(&db_rwlock)) {
|
||||||
log_err(0,"Cannot lock rwlock\n");
|
log_err(0,"Cannot lock rwlock\n");
|
||||||
|
@ -397,7 +417,12 @@ DB_PLAYLIST *db_playlist_enum_begin(void) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return db_playlists.next;
|
/* find first playlist with a song in it! */
|
||||||
|
current=db_playlists.next;
|
||||||
|
while(current && (!current->songs))
|
||||||
|
current=current->next;
|
||||||
|
|
||||||
|
return current;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -418,7 +443,7 @@ DB_PLAYLISTENTRY *db_playlist_items_enum_begin(int playlistid) {
|
||||||
|
|
||||||
current=db_playlists.next;
|
current=db_playlists.next;
|
||||||
while(current && (current->id != playlistid))
|
while(current && (current->id != playlistid))
|
||||||
current++;
|
current=current->next;
|
||||||
|
|
||||||
if(!current)
|
if(!current)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -450,10 +475,16 @@ MP3FILE *db_enum(MP3RECORD **current) {
|
||||||
*/
|
*/
|
||||||
int db_playlist_enum(DB_PLAYLIST **current) {
|
int db_playlist_enum(DB_PLAYLIST **current) {
|
||||||
int retval;
|
int retval;
|
||||||
|
DB_PLAYLIST *p;
|
||||||
|
|
||||||
if(*current) {
|
if(*current) {
|
||||||
retval = (*current)->id;
|
retval = (*current)->id;
|
||||||
*current=(*current)->next;
|
p=*current;
|
||||||
|
p=p->next;
|
||||||
|
while(p && (!p->songs))
|
||||||
|
p=p->next;
|
||||||
|
|
||||||
|
*current=p;
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
|
|
Loading…
Reference in New Issue