TagFile: add TagBuilder overload with ScanGenericTags() fallback
This commit is contained in:
parent
b1d60b5c85
commit
a9130cb99c
|
@ -96,12 +96,8 @@ Song::UpdateFile(Storage &storage)
|
|||
full_tag_handler, &tag_builder))
|
||||
return false;
|
||||
} else {
|
||||
if (!tag_file_scan(path_fs, full_tag_handler, &tag_builder))
|
||||
if (!tag_file_scan(path_fs, tag_builder))
|
||||
return false;
|
||||
|
||||
if (tag_builder.IsEmpty())
|
||||
ScanGenericTags(path_fs, full_tag_handler,
|
||||
&tag_builder);
|
||||
}
|
||||
|
||||
mtime = info.mtime;
|
||||
|
@ -149,12 +145,9 @@ DetachedSong::LoadFile(Path path)
|
|||
return false;
|
||||
|
||||
TagBuilder tag_builder;
|
||||
if (!tag_file_scan(path, full_tag_handler, &tag_builder))
|
||||
if (!tag_file_scan(path, tag_builder))
|
||||
return false;
|
||||
|
||||
if (tag_builder.IsEmpty())
|
||||
ScanGenericTags(path, full_tag_handler, &tag_builder);
|
||||
|
||||
mtime = fi.GetModificationTime();
|
||||
tag_builder.Commit(tag);
|
||||
return true;
|
||||
|
|
|
@ -19,6 +19,9 @@
|
|||
|
||||
#include "config.h"
|
||||
#include "TagFile.hxx"
|
||||
#include "tag/Generic.hxx"
|
||||
#include "tag/TagHandler.hxx"
|
||||
#include "tag/TagBuilder.hxx"
|
||||
#include "fs/Path.hxx"
|
||||
#include "util/UriUtil.hxx"
|
||||
#include "util/Error.hxx"
|
||||
|
@ -94,3 +97,15 @@ tag_file_scan(Path path_fs, const TagHandler &handler, void *handler_ctx)
|
|||
return tfs.Scan(plugin);
|
||||
});
|
||||
}
|
||||
|
||||
bool
|
||||
tag_file_scan(Path path, TagBuilder &builder)
|
||||
{
|
||||
if (!tag_file_scan(path, full_tag_handler, &builder))
|
||||
return false;
|
||||
|
||||
if (builder.IsEmpty())
|
||||
ScanGenericTags(path, full_tag_handler, &builder);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
|
|
@ -24,6 +24,7 @@
|
|||
|
||||
class Path;
|
||||
struct TagHandler;
|
||||
class TagBuilder;
|
||||
|
||||
/**
|
||||
* Scan the tags of a song file. Invokes matching decoder plugins,
|
||||
|
@ -35,4 +36,15 @@ struct TagHandler;
|
|||
bool
|
||||
tag_file_scan(Path path, const TagHandler &handler, void *handler_ctx);
|
||||
|
||||
/**
|
||||
* Scan the tags of a song file. Invokes matching decoder plugins,
|
||||
* and falls back to generic scanners (APE and ID3) if no tags were
|
||||
* found (but the file was recognized).
|
||||
*
|
||||
* @return true if the file was recognized (even if no metadata was
|
||||
* found)
|
||||
*/
|
||||
bool
|
||||
tag_file_scan(Path path, TagBuilder &builder);
|
||||
|
||||
#endif
|
||||
|
|
Loading…
Reference in New Issue