+#include "plugins/interface.h"
+#include "parser/parse.h"
+
#include <glib.h>
#include <gmodule.h>
-typedef void (*PluginSetupConfig)();
-typedef void (*PluginStartup)();
-typedef void (*PluginShutdown)();
-typedef void *(*PluginCreate)(/* TODO */);
-typedef void (*PluginDestroy)(void *);
-
typedef struct {
GModule *module;
char *name;
PluginSetupConfig config;
PluginStartup startup;
PluginShutdown shutdown;
- PluginCreate create;
- PluginDestroy destroy;
} Plugin;
static gpointer load_sym(GModule *module, char *name, char *symbol,
FALSE);
p->shutdown = (PluginShutdown)load_sym(p->module, name, "plugin_shutdown",
FALSE);
- p->create = (PluginCreate)load_sym(p->module, name, "plugin_create", TRUE);
- p->destroy = (PluginDestroy)load_sym(p->module, name, "plugin_destroy",
- TRUE);
if (p->config == NULL || p->startup == NULL || p->shutdown == NULL) {
g_module_close(p->module);
g_datalist_clear(&plugins);
}
-gboolean plugin_open_full(char *name, gboolean reopen)
+gboolean plugin_open_full(char *name, gboolean reopen, ObParseInst *i)
{
Plugin *p;
g_warning("failed to load plugin '%s'", name);
return FALSE;
}
- p->config();
+ p->config(i);
g_datalist_set_data_full(&plugins, name, p, (GDestroyNotify) plugin_free);
return TRUE;
}
-gboolean plugin_open(char *name) {
- return plugin_open_full(name, FALSE);
+gboolean plugin_open(char *name, ObParseInst *i) {
+ return plugin_open_full(name, FALSE, i);
}
-gboolean plugin_open_reopen(char *name) {
- return plugin_open_full(name, TRUE);
+gboolean plugin_open_reopen(char *name, ObParseInst *i) {
+ return plugin_open_full(name, TRUE, i);
}
void plugin_close(char *name)
g_datalist_foreach(&plugins, (GDataForeachFunc)foreach_start, NULL);
}
-void plugin_loadall()
+void plugin_loadall(ObParseInst *i)
{
GIOChannel *io;
GError *err;
if (io == NULL) {
/* load the default plugins */
- plugin_open("keyboard");
- plugin_open("mouse");
- plugin_open("placement");
- plugin_open("resistance");
+ plugin_open("placement", i);
+
+ /* XXX rm me when the parser loads me magically */
+ plugin_open("client_menu", i);
+ plugin_open("client_list_menu", i);
} else {
/* load the plugins in the rc file */
while (g_io_channel_read_line(io, &name, NULL, NULL, &err) ==
G_IO_STATUS_NORMAL) {
g_strstrip(name);
if (name[0] != '\0' && name[0] != '#')
- plugin_open(name);
+ plugin_open(name, i);
g_free(name);
}
g_io_channel_unref(io);
}
}
-
-void *plugin_create(char *name /* TODO */)
-{
- Plugin *p = (Plugin *)g_datalist_get_data(&plugins, name);
-
- if (p == NULL) {
- g_warning("Unable to find plugin for create: %s", name);
- return NULL;
- }
-
- if (p->create == NULL || p->destroy == NULL) {
- g_critical("Unsupported create/destroy: %s", name);
- return NULL;
- }
-
- return p->create();
-}
-
-void plugin_destroy(char *name, void *data)
-{
- Plugin *p = (Plugin *)g_datalist_get_data(&plugins, name);
-
- if (p == NULL) {
- g_critical("Unable to find plugin for destroy: %s", name);
- /* really shouldn't happen, but attempt to free something anyway? */
- g_free(data);
- return;
- }
-
- if (p->destroy == NULL || p->create == NULL) {
- g_critical("Unsupported create/destroy: %s", name);
- /* really, really shouldn't happen, but attempt to free anyway? */
- g_free(data);
- return;
- }
-
- p->destroy(data);
-}