output/httpd: migrate from DeferredMonitor to DeferEvent

This commit is contained in:
Max Kellermann 2017-11-10 21:14:52 +01:00
parent b83fbad6a1
commit 83f8eeec44
2 changed files with 13 additions and 9 deletions

View File

@ -31,7 +31,7 @@
#include "thread/Mutex.hxx"
#include "thread/Cond.hxx"
#include "event/ServerSocket.hxx"
#include "event/DeferredMonitor.hxx"
#include "event/DeferEvent.hxx"
#include "util/Cast.hxx"
#include "Compiler.h"
@ -48,7 +48,7 @@ class PreparedEncoder;
class Encoder;
struct Tag;
class HttpdOutput final : AudioOutput, ServerSocket, DeferredMonitor {
class HttpdOutput final : AudioOutput, ServerSocket {
/**
* True if the audio output is open and accepts client
* connections.
@ -114,6 +114,8 @@ private:
*/
std::queue<PagePtr, std::list<PagePtr>> pages;
DeferEvent defer_broadcast;
public:
/**
* The configured name.
@ -157,7 +159,7 @@ public:
return new HttpdOutput(event_loop, block);
}
using DeferredMonitor::GetEventLoop;
using ServerSocket::GetEventLoop;
void Bind();
void Unbind();
@ -255,7 +257,8 @@ public:
bool Pause() override;
private:
virtual void RunDeferred() override;
/* DeferEvent callback */
void OnDeferredBroadcast() noexcept;
void OnAccept(UniqueSocketDescriptor fd,
SocketAddress address, int uid) override;

View File

@ -51,7 +51,8 @@ const Domain httpd_output_domain("httpd_output");
inline
HttpdOutput::HttpdOutput(EventLoop &_loop, const ConfigBlock &block)
:AudioOutput(FLAG_ENABLE_DISABLE|FLAG_PAUSE),
ServerSocket(_loop), DeferredMonitor(_loop)
ServerSocket(_loop),
defer_broadcast(_loop, BIND_THIS_METHOD(OnDeferredBroadcast))
{
/* read configuration */
name = block.GetBlockValue("name", "Set name in config");
@ -128,7 +129,7 @@ HttpdOutput::AddClient(UniqueSocketDescriptor fd)
}
void
HttpdOutput::RunDeferred()
HttpdOutput::OnDeferredBroadcast() noexcept
{
/* this method runs in the IOThread; it broadcasts pages from
our own queue to all clients */
@ -258,7 +259,7 @@ HttpdOutput::Close() noexcept
delete timer;
BlockingCall(GetEventLoop(), [this](){
DeferredMonitor::Cancel();
defer_broadcast.Cancel();
const std::lock_guard<Mutex> protect(mutex);
open = false;
@ -317,7 +318,7 @@ HttpdOutput::BroadcastPage(PagePtr page)
pages.emplace(std::move(page));
}
DeferredMonitor::Schedule();
defer_broadcast.Schedule();
}
void
@ -340,7 +341,7 @@ HttpdOutput::BroadcastFromEncoder()
}
if (!empty)
DeferredMonitor::Schedule();
defer_broadcast.Schedule();
}
inline void