|
|
@@ -2,21 +2,12 @@
|
|
|
|
|
|
#include <cr.h>
|
|
|
#include <gtest/gtest.h>
|
|
|
+#include <entt/core/type_info.hpp>
|
|
|
#include <entt/signal/dispatcher.hpp>
|
|
|
-#include "proxy.h"
|
|
|
#include "types.h"
|
|
|
|
|
|
-proxy::proxy(entt::dispatcher &ref)
|
|
|
- : dispatcher{&ref}
|
|
|
-{}
|
|
|
-
|
|
|
-void proxy::trigger(message msg) {
|
|
|
- dispatcher->trigger(msg);
|
|
|
-}
|
|
|
-
|
|
|
-void proxy::trigger(event ev) {
|
|
|
- dispatcher->trigger(ev);
|
|
|
-}
|
|
|
+template<typename Type>
|
|
|
+struct entt::type_index<Type> {};
|
|
|
|
|
|
struct listener {
|
|
|
void on(message msg) { value = msg.payload; }
|
|
|
@@ -25,7 +16,6 @@ struct listener {
|
|
|
|
|
|
TEST(Lib, Dispatcher) {
|
|
|
entt::dispatcher dispatcher;
|
|
|
- proxy handler{dispatcher};
|
|
|
listener listener;
|
|
|
|
|
|
ASSERT_EQ(listener.value, 0);
|
|
|
@@ -33,11 +23,12 @@ TEST(Lib, Dispatcher) {
|
|
|
dispatcher.sink<message>().connect<&listener::on>(listener);
|
|
|
|
|
|
cr_plugin ctx;
|
|
|
- ctx.userdata = &handler;
|
|
|
+ ctx.userdata = &dispatcher;
|
|
|
cr_plugin_load(ctx, PLUGIN);
|
|
|
cr_plugin_update(ctx);
|
|
|
|
|
|
ASSERT_EQ(listener.value, 42);
|
|
|
|
|
|
+ dispatcher = {};
|
|
|
cr_plugin_close(ctx);
|
|
|
}
|