diff tests/src/libirccd/dynlib-plugin/test_plugin.cpp @ 684:8d93e415c3b4

Irccd: load directly native plugin instead of wrapping it, closes #790 @1h The boost::dll::import function support importing variables as boost::shared_ptr, instead of wrapping all individual function, just load the plugin from the shared object and return it as a std::shared_ptr.
author David Demelier <markand@malikania.fr>
date Fri, 13 Apr 2018 07:32:10 +0200
parents 152d20dc0e74
children 48afa8c41f50
line wrap: on
line diff
--- a/tests/src/libirccd/dynlib-plugin/test_plugin.cpp	Thu Apr 12 19:30:43 2018 +0200
+++ b/tests/src/libirccd/dynlib-plugin/test_plugin.cpp	Fri Apr 13 07:32:10 2018 +0200
@@ -23,88 +23,105 @@
 namespace irccd {
 
 class test_plugin : public plugin {
+private:
+    plugin_config config_;
+
 public:
     using plugin::plugin;
 
-    void handle_command(irccd&, const message_event& event) override
+    plugin_config get_config() override
     {
-        event.server->message("test", "handle_command");
+        return config_;
     }
 
-    void handle_connect(irccd&, const connect_event& event) override
+    void handle_command(irccd&, const message_event&) override
     {
-        event.server->message("test", "handle_connect");
+        config_["command"] = "true";
+    }
+
+    void handle_connect(irccd&, const connect_event&) override
+    {
+        config_["connect"] = "true";
     }
 
-    void handle_invite(irccd&, const invite_event& event) override
+    void handle_invite(irccd&, const invite_event&) override
     {
-        event.server->message("test", "handle_invite");
+        config_["invite"] = "true";
+    }
+
+    void handle_join(irccd&, const join_event&) override
+    {
+        config_["join"] = "true";
     }
 
-    void handle_join(irccd&, const join_event& event) override
+    void handle_kick(irccd&, const kick_event&) override
     {
-        event.server->message("test", "handle_join");
+        config_["kick"] = "true";
     }
 
-    void handle_kick(irccd&, const kick_event& event) override
+    void handle_load(irccd&) override
     {
-        event.server->message("test", "handle_kick");
+        config_["load"] = "true";
     }
 
-    void handle_message(irccd&, const message_event& event) override
+    void handle_message(irccd&, const message_event&) override
     {
-        event.server->message("test", "handle_message");
+        config_["message"] = "true";
     }
 
-    void handle_me(irccd&, const me_event& event) override
+    void handle_me(irccd&, const me_event&) override
     {
-        event.server->message("test", "handle_me");
+        config_["me"] = "true";
     }
 
-    void handle_mode(irccd&, const mode_event& event) override
+    void handle_mode(irccd&, const mode_event&) override
     {
-        event.server->message("test", "handle_mode");
+        config_["mode"] = "true";
     }
 
-    void handle_names(irccd&, const names_event& event) override
+    void handle_names(irccd&, const names_event&) override
     {
-        event.server->message("test", "handle_names");
+        config_["names"] = "true";
+    }
+
+    void handle_nick(irccd&, const nick_event&) override
+    {
+        config_["nick"] = "true";
     }
 
-    void handle_nick(irccd&, const nick_event& event) override
+    void handle_notice(irccd&, const notice_event&) override
     {
-        event.server->message("test", "handle_nick");
+        config_["notice"] = "true";
     }
 
-    void handle_notice(irccd&, const notice_event& event) override
+    void handle_part(irccd&, const part_event&) override
     {
-        event.server->message("test", "handle_notice");
+        config_["part"] = "true";
     }
 
-    void handle_part(irccd&, const part_event& event) override
+    void handle_reload(irccd&) override
     {
-        event.server->message("test", "handle_part");
+        config_["reload"] = "true";
     }
 
-    void handle_topic(irccd&, const topic_event& event) override
+    void handle_topic(irccd&, const topic_event&) override
     {
-        event.server->message("test", "handle_topic");
+        config_["topic"] = "true";
     }
 
-    void handle_whois(irccd&, const whois_event& event) override
+    void handle_unload(irccd&) override
     {
-        event.server->message("test", "handle_whois");
+        config_["unload"] = "true";
+    }
+
+    void handle_whois(irccd&, const whois_event&) override
+    {
+        config_["whois"] = "true";
     }
 };
 
-} // !irccd
-
-extern "C" {
+extern "C" BOOST_SYMBOL_EXPORT test_plugin irccd_plugin_test_plugin;
 
-BOOST_SYMBOL_EXPORT
-std::unique_ptr<irccd::plugin> irccd_testplugin_load(std::string name, std::string path)
-{
-    return std::make_unique<irccd::test_plugin>(name, path);
-}
+test_plugin irccd_plugin_test_plugin("test", "");
 
-} // !C
+} // !irccd