don't count empty playlists

This commit is contained in:
Ron Pedde 2003-12-02 06:20:41 +00:00
parent 1533d3b33c
commit 6166b8a6d3
1 changed files with 35 additions and 4 deletions

View File

@ -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;