SongSave: use class TagBuilder
This commit is contained in:
parent
0b3e1c4706
commit
ae5e0cb02b
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user