SongSave: use class TagBuilder

This commit is contained in:
Max Kellermann 2013-09-05 18:59:19 +02:00
parent 0b3e1c4706
commit ae5e0cb02b

View File

@ -24,6 +24,7 @@
#include "Directory.hxx" #include "Directory.hxx"
#include "TextFile.hxx" #include "TextFile.hxx"
#include "tag/Tag.hxx" #include "tag/Tag.hxx"
#include "tag/TagBuilder.hxx"
#include "util/StringUtil.hxx" #include "util/StringUtil.hxx"
#include "util/Error.hxx" #include "util/Error.hxx"
#include "util/Domain.hxx" #include "util/Domain.hxx"
@ -68,12 +69,12 @@ song_load(TextFile &file, Directory *parent, const char *uri,
enum tag_type type; enum tag_type type;
const char *value; const char *value;
TagBuilder tag;
while ((line = file.ReadLine()) != NULL && while ((line = file.ReadLine()) != NULL &&
strcmp(line, SONG_END) != 0) { strcmp(line, SONG_END) != 0) {
colon = strchr(line, ':'); colon = strchr(line, ':');
if (colon == NULL || colon == line) { if (colon == NULL || colon == line) {
if (song->tag != NULL)
song->tag->EndAdd();
song->Free(); song->Free();
error.Format(song_save_domain, error.Format(song_save_domain,
@ -85,26 +86,11 @@ song_load(TextFile &file, Directory *parent, const char *uri,
value = strchug_fast_c(colon); value = strchug_fast_c(colon);
if ((type = tag_name_parse(line)) != TAG_NUM_OF_ITEM_TYPES) { if ((type = tag_name_parse(line)) != TAG_NUM_OF_ITEM_TYPES) {
if (!song->tag) { tag.AddItem(type, value);
song->tag = new Tag();
song->tag->BeginAdd();
}
song->tag->AddItem(type, value);
} else if (strcmp(line, "Time") == 0) { } else if (strcmp(line, "Time") == 0) {
if (!song->tag) { tag.SetTime(atoi(value));
song->tag = new Tag();
song->tag->BeginAdd();
}
song->tag->time = atoi(value);
} else if (strcmp(line, "Playlist") == 0) { } else if (strcmp(line, "Playlist") == 0) {
if (!song->tag) { tag.SetHasPlaylist(strcmp(value, "yes") == 0);
song->tag = new Tag();
song->tag->BeginAdd();
}
song->tag->has_playlist = strcmp(value, "yes") == 0;
} else if (strcmp(line, SONG_MTIME) == 0) { } else if (strcmp(line, SONG_MTIME) == 0) {
song->mtime = atoi(value); song->mtime = atoi(value);
} else if (strcmp(line, "Range") == 0) { } else if (strcmp(line, "Range") == 0) {
@ -114,8 +100,6 @@ song_load(TextFile &file, Directory *parent, const char *uri,
if (*endptr == '-') if (*endptr == '-')
song->end_ms = strtoul(endptr + 1, NULL, 10); song->end_ms = strtoul(endptr + 1, NULL, 10);
} else { } else {
if (song->tag != NULL)
song->tag->EndAdd();
song->Free(); song->Free();
error.Format(song_save_domain, error.Format(song_save_domain,
@ -124,8 +108,8 @@ song_load(TextFile &file, Directory *parent, const char *uri,
} }
} }
if (song->tag != NULL) if (tag.IsDefined())
song->tag->EndAdd(); song->tag = tag.Commit();
return song; return song;
} }