mirror of
https://github.com/badaix/snapcast.git
synced 2025-06-23 13:07:08 +02:00
Use callback function instead of class
This commit is contained in:
parent
efd050a716
commit
f0985cbce4
4 changed files with 40 additions and 33 deletions
|
@ -114,8 +114,8 @@ void ProcessStream::connect()
|
|||
on_connect();
|
||||
if (wd_timeout_sec_ > 0)
|
||||
{
|
||||
watchdog_ = make_unique<Watchdog>(strand_, this);
|
||||
watchdog_->start(std::chrono::seconds(wd_timeout_sec_));
|
||||
watchdog_ = make_unique<Watchdog>(strand_);
|
||||
watchdog_->start(std::chrono::seconds(wd_timeout_sec_), [this](std::chrono::milliseconds ms) { onTimeout(ms); });
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -171,7 +171,7 @@ void ProcessStream::stderrReadLine()
|
|||
}
|
||||
|
||||
|
||||
void ProcessStream::onTimeout(const Watchdog& /*watchdog*/, std::chrono::milliseconds ms)
|
||||
void ProcessStream::onTimeout(std::chrono::milliseconds ms)
|
||||
{
|
||||
LOG(ERROR, LOG_TAG) << "Watchdog timeout: " << ms.count() / 1000 << "s\n";
|
||||
if (process_)
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
/***
|
||||
This file is part of snapcast
|
||||
Copyright (C) 2014-2024 Johannes Pohl
|
||||
Copyright (C) 2014-2025 Johannes Pohl
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
|
@ -42,38 +42,43 @@ using boost::asio::posix::stream_descriptor;
|
|||
* Implements EncoderListener to get the encoded data.
|
||||
* Data is passed to the PcmStream::Listener
|
||||
*/
|
||||
class ProcessStream : public AsioStream<stream_descriptor>, public WatchdogListener
|
||||
class ProcessStream : public AsioStream<stream_descriptor>
|
||||
{
|
||||
public:
|
||||
/// ctor. Encoded PCM data is passed to the PipeListener
|
||||
/// c'tor. Encoded PCM data is passed to the PipeListener
|
||||
ProcessStream(PcmStream::Listener* pcmListener, boost::asio::io_context& ioc, const ServerSettings& server_settings, const StreamUri& uri);
|
||||
/// d'tor
|
||||
~ProcessStream() override = default;
|
||||
|
||||
protected:
|
||||
void connect() override;
|
||||
void disconnect() override;
|
||||
|
||||
std::string exe_;
|
||||
std::string path_;
|
||||
std::string params_;
|
||||
bp::pipe pipe_stdout_;
|
||||
bp::pipe pipe_stderr_;
|
||||
bp::child process_;
|
||||
std::string exe_; ///< filename of the process
|
||||
std::string path_; ///< base path of the provess
|
||||
std::string params_; ///< parameters for the process
|
||||
bp::pipe pipe_stdout_; ///< stdout of the process
|
||||
bp::pipe pipe_stderr_; ///< stderr of the process
|
||||
bp::child process_; ///< the process
|
||||
|
||||
bool logStderr_;
|
||||
boost::asio::streambuf streambuf_stderr_;
|
||||
std::unique_ptr<stream_descriptor> stream_stderr_;
|
||||
bool logStderr_; ///< log stderr to log?
|
||||
boost::asio::streambuf streambuf_stderr_; ///< stderr read buffer
|
||||
std::unique_ptr<stream_descriptor> stream_stderr_; ///< stderr stream
|
||||
|
||||
// void worker() override;
|
||||
/// Read async from stderr
|
||||
virtual void stderrReadLine();
|
||||
/// Called for a line read from stderr
|
||||
virtual void onStderrMsg(const std::string& line);
|
||||
/// Try to find exe and base path, throw on error
|
||||
virtual void initExeAndPath(const std::string& filename);
|
||||
|
||||
/// @return the executables complete path to @p filename
|
||||
std::string findExe(const std::string& filename) const;
|
||||
|
||||
size_t wd_timeout_sec_;
|
||||
std::unique_ptr<Watchdog> watchdog_;
|
||||
void onTimeout(const Watchdog& watchdog, std::chrono::milliseconds ms) override;
|
||||
size_t wd_timeout_sec_; ///< Watchdog timeout for arrival of new log lines
|
||||
std::unique_ptr<Watchdog> watchdog_; ///< the watchdog
|
||||
/// called on wd timeout, kills the process
|
||||
void onTimeout(std::chrono::milliseconds ms);
|
||||
};
|
||||
|
||||
} // namespace streamreader
|
||||
|
|
|
@ -36,7 +36,7 @@ using namespace std;
|
|||
namespace streamreader
|
||||
{
|
||||
|
||||
Watchdog::Watchdog(const boost::asio::any_io_executor& executor, WatchdogListener* listener) : timer_(executor), listener_(listener)
|
||||
Watchdog::Watchdog(const boost::asio::any_io_executor& executor) : timer_(executor)
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -47,9 +47,10 @@ Watchdog::~Watchdog()
|
|||
}
|
||||
|
||||
|
||||
void Watchdog::start(const std::chrono::milliseconds& timeout)
|
||||
void Watchdog::start(const std::chrono::milliseconds& timeout, TimeoutHandler&& handler)
|
||||
{
|
||||
LOG(INFO, LOG_TAG) << "Starting watchdog, timeout: " << std::chrono::duration_cast<std::chrono::seconds>(timeout).count() << "s\n";
|
||||
handler_ = std::move(handler);
|
||||
timeout_ms_ = timeout;
|
||||
trigger();
|
||||
}
|
||||
|
@ -70,7 +71,8 @@ void Watchdog::trigger()
|
|||
if (!ec)
|
||||
{
|
||||
LOG(INFO, LOG_TAG) << "Timed out: " << std::chrono::duration_cast<std::chrono::seconds>(timeout_ms_).count() << "s\n";
|
||||
listener_->onTimeout(*this, timeout_ms_);
|
||||
if (handler_)
|
||||
handler_(timeout_ms_);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
/***
|
||||
This file is part of snapcast
|
||||
Copyright (C) 2014-2024 Johannes Pohl
|
||||
Copyright (C) 2014-2025 Johannes Pohl
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
|
@ -32,27 +32,27 @@ namespace streamreader
|
|||
class Watchdog;
|
||||
|
||||
|
||||
class WatchdogListener
|
||||
{
|
||||
public:
|
||||
virtual void onTimeout(const Watchdog& watchdog, std::chrono::milliseconds ms) = 0;
|
||||
};
|
||||
|
||||
|
||||
/// Watchdog
|
||||
class Watchdog
|
||||
{
|
||||
public:
|
||||
Watchdog(const boost::asio::any_io_executor& executor, WatchdogListener* listener = nullptr);
|
||||
using TimeoutHandler = std::function<void(std::chrono::milliseconds ms)>;
|
||||
|
||||
/// c'tor
|
||||
explicit Watchdog(const boost::asio::any_io_executor& executor);//, WatchdogListener* listener = nullptr);
|
||||
/// d'tor
|
||||
virtual ~Watchdog();
|
||||
|
||||
void start(const std::chrono::milliseconds& timeout);
|
||||
/// start the watchdog, call @p handler on @p timeout
|
||||
void start(const std::chrono::milliseconds& timeout, TimeoutHandler&& handler);
|
||||
/// stop the watchdog
|
||||
void stop();
|
||||
/// trigger the watchdog (reset timeout)
|
||||
void trigger();
|
||||
|
||||
private:
|
||||
boost::asio::steady_timer timer_;
|
||||
WatchdogListener* listener_;
|
||||
TimeoutHandler handler_;
|
||||
std::chrono::milliseconds timeout_ms_;
|
||||
};
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue