diff options
Diffstat (limited to 'harness')
-rw-r--r-- | harness/include/foreign_intf.h | 2 | ||||
-rw-r--r-- | harness/include/plugin.h | 6 | ||||
-rw-r--r-- | harness/src/plugin.c | 25 |
3 files changed, 29 insertions, 4 deletions
diff --git a/harness/include/foreign_intf.h b/harness/include/foreign_intf.h index fc079e2..e0d178c 100644 --- a/harness/include/foreign_intf.h +++ b/harness/include/foreign_intf.h @@ -21,6 +21,8 @@ typedef struct FOREIGN_INTERFACE { /* Requests the harness hot reload the current plugin. */ EXPORT(void (*do_log)(ctx_t ctx, const char* str)); + /* Requestes that the whole system exit. Exits with the given return code. */ + EXPORT(void (*request_exit)(ctx_t ctx, int rc)); } foreign_interface_t; #undef EXPORT diff --git a/harness/include/plugin.h b/harness/include/plugin.h index 1e4a161..145fe52 100644 --- a/harness/include/plugin.h +++ b/harness/include/plugin.h @@ -33,7 +33,11 @@ struct PLUGIN; typedef struct { int (*action)(struct PLUGIN *requester, void* arg); void (*arg_dtor)(void* arg); - void* arg; + union { + void* ptr_arg; + int int_arg; + char* str_arg; + }; } requested_action_t; /* diff --git a/harness/src/plugin.c b/harness/src/plugin.c index f1cc361..1d7c992 100644 --- a/harness/src/plugin.c +++ b/harness/src/plugin.c @@ -86,11 +86,29 @@ void do_request_log(void *plugv, const char* str) size_t n = plugin->n_requested_actions++; if (n < 8) { plugin->requested_actions[n].action = plugin_do_log; - plugin->requested_actions[n].arg = strdup(str); + plugin->requested_actions[n].str_arg = strdup(str); plugin->requested_actions[n].arg_dtor = free; } } +static int plugin_do_exit(void* plugv, int ec) +{ + exit(ec); + return 0; +} + +void do_request_exit(void *plugv, int ec) +{ + plugin_t *plugin = plugv; + + size_t n = plugin->n_requested_actions++; + if (n < 8) { + plugin->requested_actions[n].action = (int(*)(plugin_t*,void*)) plugin_do_exit; + plugin->requested_actions[n].int_arg = ec; + plugin->requested_actions[n].arg_dtor = NULL; + } +} + static int load_plugin_from_file_(int argc, char **argv, const char *filename, plugin_t *plugin) { @@ -117,6 +135,7 @@ static int load_plugin_from_file_(int argc, char **argv, const char *filename, plugin->foreign_intf.ctx = plugin; plugin->foreign_intf.request_hot_reload = do_request_hot_reload; plugin->foreign_intf.do_log = do_request_log; + plugin->foreign_intf.request_exit = do_request_exit; plugin->plugin_load(plugin->argc, plugin->argv, &plugin->foreign_intf); end: @@ -206,9 +225,9 @@ void plugin_run_requested_actions(plugin_t *plugin) size_t i; for (i = 0; i < n_requested_actions; ++i) { - requested_actions[i].action(plugin, requested_actions[i].arg); + requested_actions[i].action(plugin, requested_actions[i].str_arg); if (requested_actions[i].arg_dtor) { - requested_actions[i].arg_dtor(requested_actions[i].arg); + requested_actions[i].arg_dtor(requested_actions[i].ptr_arg); } } } |