Mercurial > irccd
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