db/update/Container: move SupportsContainerSuffix() to struct DecoderPlugin

This commit is contained in:
Max Kellermann 2019-09-03 19:36:56 +02:00
parent d5681b678c
commit fd1826cb91
2 changed files with 5 additions and 9 deletions

View File

@ -55,21 +55,13 @@ UpdateWalk::MakeDirectoryIfModified(Directory &parent, const char *name,
return directory; return directory;
} }
static bool
SupportsContainerSuffix(const DecoderPlugin &plugin,
const char *suffix) noexcept
{
return plugin.container_scan != nullptr &&
plugin.SupportsSuffix(suffix);
}
bool bool
UpdateWalk::UpdateContainerFile(Directory &directory, UpdateWalk::UpdateContainerFile(Directory &directory,
const char *name, const char *suffix, const char *name, const char *suffix,
const StorageFileInfo &info) noexcept const StorageFileInfo &info) noexcept
{ {
const DecoderPlugin *_plugin = decoder_plugins_find([suffix](const DecoderPlugin &plugin){ const DecoderPlugin *_plugin = decoder_plugins_find([suffix](const DecoderPlugin &plugin){
return SupportsContainerSuffix(plugin, suffix); return plugin.SupportsContainerSuffix(suffix);
}); });
if (_plugin == nullptr) if (_plugin == nullptr)
return false; return false;

View File

@ -225,6 +225,10 @@ struct DecoderPlugin {
*/ */
gcc_pure gcc_nonnull_all gcc_pure gcc_nonnull_all
bool SupportsMimeType(const char *mime_type) const noexcept; bool SupportsMimeType(const char *mime_type) const noexcept;
bool SupportsContainerSuffix(const char *suffix) const noexcept {
return container_scan != nullptr && SupportsSuffix(suffix);
}
}; };
#endif #endif