decoder/flac: add method FLACMetadataChain::Scan()
Merge common code.
This commit is contained in:
parent
343de8b8ab
commit
3c2d73d161
@ -373,15 +373,7 @@ oggflac_scan_file(const char *file,
|
||||
return false;
|
||||
}
|
||||
|
||||
FLACMetadataIterator iterator(chain);
|
||||
do {
|
||||
FLAC__StreamMetadata *block = iterator.GetBlock();
|
||||
if (block == nullptr)
|
||||
break;
|
||||
|
||||
flac_scan_metadata(block, handler, handler_ctx);
|
||||
} while (iterator.Next());
|
||||
|
||||
chain.Scan(handler, handler_ctx);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -250,7 +250,15 @@ flac_scan_file2(const char *file,
|
||||
return false;
|
||||
}
|
||||
|
||||
FLACMetadataIterator iterator(chain);
|
||||
chain.Scan(handler, handler_ctx);
|
||||
return true;
|
||||
}
|
||||
|
||||
void
|
||||
FLACMetadataChain::Scan(const struct tag_handler *handler, void *handler_ctx)
|
||||
{
|
||||
FLACMetadataIterator iterator(*this);
|
||||
|
||||
do {
|
||||
FLAC__StreamMetadata *block = iterator.GetBlock();
|
||||
if (block == nullptr)
|
||||
@ -258,6 +266,4 @@ flac_scan_file2(const char *file,
|
||||
|
||||
flac_scan_metadata(block, handler, handler_ctx);
|
||||
} while (iterator.Next());
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -58,6 +58,8 @@ public:
|
||||
const char *GetStatusString() const {
|
||||
return FLAC__Metadata_ChainStatusString[GetStatus()];
|
||||
}
|
||||
|
||||
void Scan(const struct tag_handler *handler, void *handler_ctx);
|
||||
};
|
||||
|
||||
class FLACMetadataIterator {
|
||||
|
Loading…
Reference in New Issue
Block a user