Simple event system (observer pattern) for C++ with support for "free" functions, member functions and lambdas.
You can declare an Event with a similar syntax as an std::function. You can also define EVENT_DEBUG_INFO to debug in console when a subscriber is being created, removed, updated, or ignored in case one with the same id and same instance (for member functions) is already subscribed to the event. This information is printed in the format [functionID, <owner>*]. For a version without the bloated code to print debug info use the header file inside the folder "No debug info".
#include <iostream>
#include "Event.hpp"
class Foo {
private:
int x;
public:
Foo() = default;
Foo(Event<void(int)>& e) : x{150} {
e.Subscribe("Capture Lambda", [this](int x) {
std::cout << "Prev x = " << this->x << '\n';
this->x = x;
std::cout << "New x = " << this->x << '\n';
});
}
void MemberFunction(int x) {
std::cout << "This is a member function - " << x << '\n';
}
};
void FreeFunction(int x) {
std::cout << "This is a free function - " << x << '\n';
}
int main() {
// Example of and event for functions that return void and one integer as argument.
Event<void(int)> event;
event.Subscribe("FreeFunction", FreeFunction);
// event.Unsubscribe("FreeFunction");
Foo foo;
event.Subscribe("MemberFunction", Foo::MemberFunction, &foo); // Note that you have to tell the event the class where
// the member function is located, in this case Foo.
// This can be skipped if you're subscribing the function
// within the scope of the class that contains it
// event.Unsubscribe("MemberFunction", &foo);
event.Subscribe("Lambda", [](int x) { std::cout << "This is a lambda with x = " << x << '\n'; });
auto lambda = [](int x) { std::cout << "This is another lambda with x = " << x << '\n'; };
event.Subscribe("Lambda2", lambda);
Foo otherFoo{event}; // Passing the event as parameter is not necessary depending on your design.
// Invoking the event
event.Invoke(7); // You can use the overloaded operator (), as event(7), which will have the same effect.
}
// Output:
// This is a member function - 7
// This is another lambda with x = 7
// Prev x = 150
// New x = 7
// This is a lambda with x = 7
// This is a free function - 7
//
NOTE: This system currently only supports void as return type. This system is also not thread safe since I use it mainly in games with no multi threated events.