input/Stream: remove attribute "cond", replace with handler interface
This adds a bit of overhead, but also adds flexibility to the API, because arbitrary triggers may be invoked from that virtual method implementation, not just Cond::signal(). The motivation for this is to make the handlers more dynamic, for the upcoming buffering class utilizing ProxyInputStream.
This commit is contained in:
@@ -22,16 +22,14 @@
|
||||
#include "TagStream.hxx"
|
||||
#include "archive/ArchiveFile.hxx"
|
||||
#include "input/InputStream.hxx"
|
||||
#include "thread/Cond.hxx"
|
||||
|
||||
bool
|
||||
tag_archive_scan(ArchiveFile &archive, const char *path_utf8,
|
||||
const TagHandler &handler, void *handler_ctx) noexcept
|
||||
try {
|
||||
Mutex mutex;
|
||||
Cond cond;
|
||||
|
||||
auto is = archive.OpenStream(path_utf8, mutex, cond);
|
||||
auto is = archive.OpenStream(path_utf8, mutex);
|
||||
if (!is)
|
||||
return false;
|
||||
|
||||
@@ -45,9 +43,8 @@ tag_archive_scan(ArchiveFile &archive, const char *path_utf8,
|
||||
TagBuilder &builder) noexcept
|
||||
try {
|
||||
Mutex mutex;
|
||||
Cond cond;
|
||||
|
||||
auto is = archive.OpenStream(path_utf8, mutex, cond);
|
||||
auto is = archive.OpenStream(path_utf8, mutex);
|
||||
return is && tag_stream_scan(*is, builder);
|
||||
} catch (const std::exception &e) {
|
||||
return false;
|
||||
|
Reference in New Issue
Block a user