/*********************
* GisViewer methods *
*********************/
-GisViewer *gis_opengl_new(GisPlugins *plugins)
+GisViewer *gis_opengl_new(GisPlugins *plugins, GisPrefs *prefs)
{
g_debug("GisOpenGL: new");
GisViewer *self = g_object_new(GIS_TYPE_OPENGL, NULL);
- self->plugins = plugins;
+ gis_viewer_setup(self, plugins, prefs);
return self;
}
GType gis_opengl_get_type(void);
/* Methods */
-GisViewer *gis_opengl_new(GisPlugins *plugins);
+GisViewer *gis_opengl_new(GisPlugins *plugins, GisPrefs *prefs);
#endif
return type;
}
+const gchar *gis_plugin_get_name(GisPlugin *self)
+{
+ if (!GIS_IS_PLUGIN(self))
+ return NULL;
+ return GIS_PLUGIN_GET_INTERFACE(self)->name;
+}
+
+const gchar *gis_plugin_get_description(GisPlugin *self)
+{
+ if (!GIS_IS_PLUGIN(self))
+ return NULL;
+ return GIS_PLUGIN_GET_INTERFACE(self)->description;
+}
+
GtkWidget *gis_plugin_get_config(GisPlugin *self)
{
if (!GIS_IS_PLUGIN(self))
return NULL;
GisPluginInterface *iface = GIS_PLUGIN_GET_INTERFACE(self);
- return iface->get_config ? iface->get_config (self) : NULL;
+ return iface->get_config ? iface->get_config(self) : NULL;
}
GisPlugin *plugin;
} GisPluginStore;
-GisPlugins *gis_plugins_new(gchar *dir)
+GisPlugins *gis_plugins_new(const gchar *dir, GisPrefs *prefs)
{
g_debug("GisPlugins: new - dir=%s", dir);
- GisPlugins *plugins = g_new0(GisPlugins, 1);
+ GisPlugins *self = g_new0(GisPlugins, 1);
+ self->prefs = prefs;
if (dir)
- plugins->dir = g_strdup(dir);
- return plugins;
+ self->dir = g_strdup(dir);
+ return self;
}
void gis_plugins_free(GisPlugins *self)
gchar *dirs[] = {self->dir, PLUGINSDIR};
g_debug("pluginsdir=%s", PLUGINSDIR);
for (int i = 0; i<2; i++) {
+ if (dirs[i] == NULL)
+ continue;
GDir *dir = g_dir_open(dirs[i], 0, NULL);
if (dir == NULL)
continue;
return store->plugin;
}
+GisPlugin *gis_plugins_enable(GisPlugins *self, const char *name,
+ GisViewer *viewer, GisPrefs *prefs)
+{
+ GisPlugin *plugin = gis_plugins_load(self, name, viewer, prefs);
+ gis_prefs_set_boolean_v(self->prefs, "plugins", name, TRUE);
+ return plugin;
+}
+
+GList *gis_plugins_load_enabled(GisPlugins *self,
+ GisViewer *viewer, GisPrefs *prefs)
+{
+ GList *loaded = NULL;
+ for (GList *cur = gis_plugins_available(self); cur; cur = cur->next) {
+ gchar *name = cur->data;
+ if (gis_prefs_get_boolean_v(self->prefs, "plugins", name, NULL)) {
+ GisPlugin *plugin = gis_plugins_load(self, name, viewer, prefs);
+ loaded = g_list_prepend(loaded, plugin);
+ }
+ }
+ return loaded;
+}
+
gboolean gis_plugins_unload(GisPlugins *self, const char *name)
{
g_debug("GisPlugins: unload %s", name);
}
return FALSE;
}
+
+gboolean gis_plugins_disable(GisPlugins *self, const char *name)
+{
+ gis_prefs_set_boolean_v(self->prefs, "plugins", name, FALSE);
+ gis_plugins_unload(self, name);
+ return FALSE;
+}
+
void gis_plugins_foreach(GisPlugins *self, GCallback _callback, gpointer user_data)
{
g_debug("GisPlugins: foreach");
{
GTypeInterface parent_iface;
+ /* Virtual data */
+ const gchar *name;
+ const gchar *description;
+
/* Virtual functions */
GtkWidget *(*get_config)(GisPlugin *self);
};
GType gis_plugin_get_type();
/* Methods */
-void gis_plugin_expose(GisPlugin *self);
+const gchar *gis_plugin_get_name(GisPlugin *self);
+
+const gchar *gis_plugin_get_description(GisPlugin *self);
+
GtkWidget *gis_plugin_get_config(GisPlugin *self);
/* Plugins API */
#include "gis-prefs.h"
struct _GisPlugins {
- gchar *dir;
- GList *plugins;
+ gchar *dir;
+ GList *plugins;
+ GisPrefs *prefs;
};
typedef GisPlugin *(*GisPluginConstructor)(GisViewer *viewer, GisPrefs *prefs);
-GisPlugins *gis_plugins_new(gchar *dir);
-void gis_plugins_free();
-GList *gis_plugins_available(GisPlugins *plugins);
-GisPlugin *gis_plugins_load(GisPlugins *plugins, const char *name,
+GisPlugins *gis_plugins_new(const gchar *dir, GisPrefs *prefs);
+
+void gis_plugins_free();
+
+GList *gis_plugins_available(GisPlugins *plugins);
+
+GisPlugin *gis_plugins_load(GisPlugins *plugins, const char *name,
GisViewer *viewer, GisPrefs *prefs);
-gboolean gis_plugins_unload(GisPlugins *plugins, const char *name);
-void gis_plugins_foreach(GisPlugins *plugins, GCallback callback, gpointer user_data);
+
+GisPlugin *gis_plugins_enable(GisPlugins *self, const char *name,
+ GisViewer *viewer, GisPrefs *prefs);
+
+GList *gis_plugins_load_enabled(GisPlugins *self,
+ GisViewer *viewer, GisPrefs *prefs);
+
+gboolean gis_plugins_disable(GisPlugins *self, const char *name);
+
+gboolean gis_plugins_unload(GisPlugins *plugins, const char *name);
+
+void gis_plugins_foreach(GisPlugins *plugins, GCallback callback, gpointer user_data);
#endif
g_debug("GisPrefs: new - Unable to load key file `%s': %s",
self->key_path, error->message);
}
+ g_debug("GisPrefs: new - using %s", self->key_path);
return self;
}
/***********
* Methods *
***********/
+void gis_viewer_setup(GisViewer *self, GisPlugins *plugins, GisPrefs *prefs)
+{
+ self->plugins = plugins;
+ self->prefs = prefs;
+ self->offline = gis_prefs_get_boolean(prefs, "gis/offline", NULL);
+}
+
void gis_viewer_set_time(GisViewer *self, const char *time)
{
g_assert(GIS_IS_VIEWER(self));
{
g_assert(GIS_IS_VIEWER(self));
g_debug("GisViewer: set_offline - %d", offline);
+ gis_prefs_set_boolean(self->prefs, "gis/offline", offline);
self->offline = offline;
_gis_viewer_emit_offline(self);
}
#include "gis-tile.h"
#include "gis-plugin.h"
+#include "gis-prefs.h"
#include "gis-object.h"
struct _GisViewer {
/* instance members */
GisPlugins *plugins;
+ GisPrefs *prefs;
gchar *time;
gdouble location[3];
gdouble rotation[3];
GType gis_viewer_get_type(void);
/* Methods */
-GisViewer *gis_viewer_new();
+void gis_viewer_setup(GisViewer *viewer, GisPlugins *plugins, GisPrefs *prefs);
void gis_viewer_set_time(GisViewer *viewer, const gchar *time);
gchar *gis_viewer_get_time(GisViewer *viewer);