utility-event: Fix compile errors

This commit is contained in:
Michael Fabian 'Xaymar' Dirks 2019-09-04 20:30:16 +02:00
parent 29ab00633c
commit f61cdeb582
2 changed files with 71 additions and 28 deletions

View file

@ -19,15 +19,30 @@
#include "utility-event.hpp" #include "utility-event.hpp"
utility::event::event()
{
on.add = std::make_shared<utility::event>();
on.remove = std::make_shared<utility::event>();
on.empty = std::make_shared<utility::event>();
}
utility::event::~event()
{
clear();
on.add.reset();
on.remove.reset();
on.empty.reset();
}
size_t utility::event::add(listener_t callback) size_t utility::event::add(listener_t callback)
{ {
_listeners.push_back(callback); _listeners.push_back(callback);
{ {
arguments_t args; event_args_t args;
args.emplace("event", this); args.emplace("event", this);
args.emplace("listener", &callback); args.emplace("listener", &callback);
on.add(args); on.add->call(args);
} }
return _listeners.size(); return _listeners.size();
@ -38,16 +53,16 @@ size_t utility::event::remove(listener_t callback)
_listeners.remove(callback); _listeners.remove(callback);
{ {
arguments_t args; event_args_t args;
args.emplace("event", this); args.emplace("event", this);
args.emplace("listener", &callback); args.emplace("listener", &callback);
on.remove(args); on.remove->call(args);
} }
if (_listeners.empty()) { if (_listeners.empty()) {
arguments_t args; event_args_t args;
args.emplace("event", this); args.emplace("event", this);
on.empty(args); on.empty->call(args);
} }
return _listeners.size(); return _listeners.size();
@ -65,22 +80,26 @@ bool utility::event::empty()
void utility::event::clear() void utility::event::clear()
{ {
return _listeners.clear(); _listeners.clear();
event_args_t args;
args.emplace("event", this);
on.empty->call(args);
} }
size_t utility::event::call(arguments_t& arguments) size_t utility::event::call(event_args_t& arguments)
{ {
size_t idx = 0; size_t idx = 0;
for (auto const& listener : _listeners) { for (auto const& listener : _listeners) {
if (listener.second(listener.first, arguments)) { /*if (listener.first.expired()) {
break; // Lifeline has expired, so remove it.
} _listeners.remove(listener);
continue;
}*/
//if (listener.second(listener.first, arguments)) {
// break;
// }
idx++; idx++;
} }
return idx; return idx;
} }
size_t utility::event::operator()(arguments_t& arguments)
{
return call(arguments);
}

View file

@ -29,15 +29,38 @@
#include <string> #include <string>
namespace utility { namespace utility {
typedef std::map<std::string, void*> arguments_t; typedef std::weak_ptr<void> lifeline_t;
typedef std::shared_ptr<void> lifeline_t; typedef std::map<std::string, void*> event_args_t;
typedef std::function<bool(lifeline_t, arguments_t&)> callback_t; #define D_EVENT_FUNC_T void(std::weak_ptr<void>, event_args_t)
typedef std::pair<lifeline_t, callback_t> listener_t; typedef std::function<D_EVENT_FUNC_T> event_cb_t;
struct event_pair {
lifeline_t lifeline;
event_cb_t callback;
event_pair(lifeline_t _lifeline, event_cb_t _callback)
{
lifeline = _lifeline;
callback = _callback;
}
bool operator==(const event_pair& rhs)
{
return (!lifeline.owner_before(rhs.lifeline) && !rhs.lifeline.owner_before(lifeline))
&& (lifeline.lock() == rhs.lifeline.lock())
&& (callback.target<D_EVENT_FUNC_T>() == rhs.callback.target<D_EVENT_FUNC_T>());
}
};
typedef event_pair listener_t;
class event { class event {
std::list<listener_t> _listeners; std::list<listener_t> _listeners;
public: public:
event();
virtual ~event();
size_t add(listener_t listener); size_t add(listener_t listener);
inline event operator+=(listener_t listener) inline event operator+=(listener_t listener)
@ -65,28 +88,29 @@ namespace utility {
void clear(); void clear();
size_t call(arguments_t& arguments); size_t call(event_args_t& arguments);
inline size_t operator()(arguments_t& arguments) inline size_t operator()(event_args_t& arguments)
{ {
return call(arguments); return call(arguments);
} }
inline size_t call() inline size_t call()
{ {
return call(arguments_t{}); event_args_t args{};
return call(args);
} }
inline size_t operator()() inline size_t operator()()
{ {
return call(arguments_t{}); return call();
} }
public: public:
struct { struct {
utility::event add; std::shared_ptr<utility::event> add;
utility::event remove; std::shared_ptr<utility::event> remove;
utility::event empty; std::shared_ptr<utility::event> empty;
} on; } on;
}; };
} // namespace utility } // namespace utility