mirror of
https://github.com/Xaymar/obs-StreamFX
synced 2024-11-10 22:05:06 +00:00
utility-event: Fix compile errors
This commit is contained in:
parent
29ab00633c
commit
f61cdeb582
2 changed files with 71 additions and 28 deletions
|
@ -19,15 +19,30 @@
|
|||
|
||||
#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)
|
||||
{
|
||||
_listeners.push_back(callback);
|
||||
|
||||
{
|
||||
arguments_t args;
|
||||
event_args_t args;
|
||||
args.emplace("event", this);
|
||||
args.emplace("listener", &callback);
|
||||
on.add(args);
|
||||
on.add->call(args);
|
||||
}
|
||||
|
||||
return _listeners.size();
|
||||
|
@ -38,16 +53,16 @@ size_t utility::event::remove(listener_t callback)
|
|||
_listeners.remove(callback);
|
||||
|
||||
{
|
||||
arguments_t args;
|
||||
event_args_t args;
|
||||
args.emplace("event", this);
|
||||
args.emplace("listener", &callback);
|
||||
on.remove(args);
|
||||
on.remove->call(args);
|
||||
}
|
||||
|
||||
if (_listeners.empty()) {
|
||||
arguments_t args;
|
||||
event_args_t args;
|
||||
args.emplace("event", this);
|
||||
on.empty(args);
|
||||
on.empty->call(args);
|
||||
}
|
||||
|
||||
return _listeners.size();
|
||||
|
@ -65,22 +80,26 @@ bool utility::event::empty()
|
|||
|
||||
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;
|
||||
for (auto const& listener : _listeners) {
|
||||
if (listener.second(listener.first, arguments)) {
|
||||
break;
|
||||
}
|
||||
/*if (listener.first.expired()) {
|
||||
// Lifeline has expired, so remove it.
|
||||
_listeners.remove(listener);
|
||||
continue;
|
||||
}*/
|
||||
|
||||
//if (listener.second(listener.first, arguments)) {
|
||||
// break;
|
||||
// }
|
||||
idx++;
|
||||
}
|
||||
return idx;
|
||||
}
|
||||
|
||||
size_t utility::event::operator()(arguments_t& arguments)
|
||||
{
|
||||
return call(arguments);
|
||||
}
|
||||
|
|
|
@ -29,15 +29,38 @@
|
|||
#include <string>
|
||||
|
||||
namespace utility {
|
||||
typedef std::map<std::string, void*> arguments_t;
|
||||
typedef std::shared_ptr<void> lifeline_t;
|
||||
typedef std::function<bool(lifeline_t, arguments_t&)> callback_t;
|
||||
typedef std::pair<lifeline_t, callback_t> listener_t;
|
||||
typedef std::weak_ptr<void> lifeline_t;
|
||||
typedef std::map<std::string, void*> event_args_t;
|
||||
#define D_EVENT_FUNC_T void(std::weak_ptr<void>, event_args_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 {
|
||||
std::list<listener_t> _listeners;
|
||||
|
||||
public:
|
||||
event();
|
||||
virtual ~event();
|
||||
|
||||
size_t add(listener_t listener);
|
||||
|
||||
inline event operator+=(listener_t listener)
|
||||
|
@ -65,28 +88,29 @@ namespace utility {
|
|||
|
||||
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);
|
||||
}
|
||||
|
||||
inline size_t call()
|
||||
{
|
||||
return call(arguments_t{});
|
||||
event_args_t args{};
|
||||
return call(args);
|
||||
}
|
||||
|
||||
inline size_t operator()()
|
||||
{
|
||||
return call(arguments_t{});
|
||||
return call();
|
||||
}
|
||||
|
||||
public:
|
||||
struct {
|
||||
utility::event add;
|
||||
utility::event remove;
|
||||
utility::event empty;
|
||||
std::shared_ptr<utility::event> add;
|
||||
std::shared_ptr<utility::event> remove;
|
||||
std::shared_ptr<utility::event> empty;
|
||||
} on;
|
||||
};
|
||||
} // namespace utility
|
||||
|
|
Loading…
Reference in a new issue