mirror of
https://github.com/gelldur/EventBus.git
synced 2024-12-27 12:21:02 +08:00
Add dummy Listener without assigned bus
Thanks to that we can store Listener without ASAP initialization with bus
This commit is contained in:
parent
48306cfc96
commit
caa2b3e9ff
@ -11,7 +11,9 @@ template <class Bus>
|
||||
class Listener
|
||||
{
|
||||
public:
|
||||
Listener(Bus& bus)
|
||||
explicit Listener() = default; // Dummy listener
|
||||
|
||||
explicit Listener(Bus& bus)
|
||||
: _id{bus.newListenerID()}
|
||||
, _bus{&bus}
|
||||
{}
|
||||
@ -43,8 +45,10 @@ public:
|
||||
return *this;
|
||||
}
|
||||
|
||||
if(_bus != nullptr)
|
||||
{
|
||||
unlistenAll();
|
||||
|
||||
}
|
||||
_id = other._id;
|
||||
other._id = 0;
|
||||
_bus = other._bus;
|
||||
@ -56,6 +60,10 @@ public:
|
||||
template <class Event>
|
||||
void listen(std::function<void(const Event&)>&& callback)
|
||||
{
|
||||
if(_bus == nullptr)
|
||||
{
|
||||
throw std::runtime_error{"bus is null"};
|
||||
}
|
||||
_bus->template listen<Event>(_id,
|
||||
std::forward<std::function<void(const Event&)>>(callback));
|
||||
}
|
||||
@ -63,24 +71,35 @@ public:
|
||||
template <class Event>
|
||||
void listen(const std::function<void(const Event&)>& callback)
|
||||
{
|
||||
if(_bus == nullptr)
|
||||
{
|
||||
throw std::runtime_error{"bus is null"};
|
||||
}
|
||||
_bus->template listen<Event>(_id, callback);
|
||||
}
|
||||
|
||||
void unlistenAll()
|
||||
{
|
||||
|
||||
if(_bus == nullptr)
|
||||
{
|
||||
throw std::runtime_error{"bus is null"};
|
||||
}
|
||||
_bus->unlistenAll(_id);
|
||||
}
|
||||
|
||||
template <typename Event>
|
||||
void unlisten()
|
||||
{
|
||||
if(_bus == nullptr)
|
||||
{
|
||||
throw std::runtime_error{"bus is null"};
|
||||
}
|
||||
_bus->template unlisten<Event>(_id);
|
||||
}
|
||||
|
||||
private:
|
||||
std::uint32_t _id = 0;
|
||||
Bus* _bus;
|
||||
Bus* _bus = nullptr;
|
||||
};
|
||||
|
||||
} // namespace dexode::eventbus
|
||||
|
Loading…
x
Reference in New Issue
Block a user