else if (event->keyval == GDK_r && event->state & GDK_CONTROL_MASK)
gis_world_refresh(self->world);
else if (event->keyval == GDK_Tab || event->keyval == GDK_ISO_Left_Tab) {
- GtkNotebook *tabs = GTK_NOTEBOOK(aweather_gui_get_widget(self, "tabs"));
+ GtkNotebook *tabs = GTK_NOTEBOOK(aweather_gui_get_widget(self, "main_tabs"));
gint num_tabs = gtk_notebook_get_n_pages(tabs);
gint cur_tab = gtk_notebook_get_current_page(tabs);
if (event->state & GDK_SHIFT_MASK)
gtk_notebook_set_current_page(tabs, (cur_tab-1)%num_tabs);
- else
+ else
gtk_notebook_set_current_page(tabs, (cur_tab+1)%num_tabs);
};
return FALSE;
void on_plugin_toggled(GtkCellRendererToggle *cell, gchar *path_str, AWeatherGui *self)
{
- GtkWidget *tview = aweather_gui_get_widget(self, "plugins_view");
+ GtkWidget *tview = aweather_gui_get_widget(self, "prefs_plugins_view");
GtkTreeModel *model = gtk_tree_view_get_model(GTK_TREE_VIEW(tview));
gboolean state;
gchar *name;
static void update_time_widget(GisView *view, const char *time, AWeatherGui *self)
{
g_debug("AWeatherGui: update_time_widget - time=%s", time);
- GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "time"));
+ GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "main_time"));
GtkTreeModel *model = GTK_TREE_MODEL(gtk_tree_view_get_model(tview));
GtkTreeIter iter;
if (gtk_tree_model_find_string(model, &iter, NULL, 0, time)) {
static void update_site_widget(GisView *view, char *site, AWeatherGui *self)
{
g_debug("AWeatherGui: update_site_widget - site=%s", site);
- GtkComboBox *combo = GTK_COMBO_BOX(aweather_gui_get_widget(self, "site"));
+ GtkComboBox *combo = GTK_COMBO_BOX(aweather_gui_get_widget(self, "main_site"));
GtkTreeModel *model = GTK_TREE_MODEL(gtk_combo_box_get_model(combo));
GtkTreeIter iter;
if (gtk_tree_model_find_string(model, &iter, NULL, 1, site)) {
static void prefs_setup(AWeatherGui *self)
{
/* Set values */
- gchar *nu = gis_prefs_get_string (self->prefs, "aweather/nexrad_url");
- gint ll = gis_prefs_get_integer(self->prefs, "aweather/log_level");
- gchar *is = gis_prefs_get_string (self->prefs, "aweather/initial_site");
- GtkWidget *nuw = aweather_gui_get_widget(self, "nexrad_url");
- GtkWidget *llw = aweather_gui_get_widget(self, "log_level");
- GtkWidget *isw = aweather_gui_get_widget(self, "initial_site");
+ gchar *nu = gis_prefs_get_string (self->prefs, "aweather/nexrad_url", NULL);
+ gint ll = gis_prefs_get_integer(self->prefs, "aweather/log_level", NULL);
+ gchar *is = gis_prefs_get_string (self->prefs, "aweather/initial_site", NULL);
+ GtkWidget *nuw = aweather_gui_get_widget(self, "prefs_general_url");
+ GtkWidget *llw = aweather_gui_get_widget(self, "prefs_general_log");
+ GtkWidget *isw = aweather_gui_get_widget(self, "prefs_general_site");
if (nu) gtk_entry_set_text(GTK_ENTRY(nuw), nu), g_free(nu);
if (ll) gtk_spin_button_set_value(GTK_SPIN_BUTTON(llw), ll);
if (is) {
}
/* Load Plugins */
- GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "plugins_view"));
+ GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "prefs_plugins_view"));
GtkCellRenderer *rend1 = gtk_cell_renderer_text_new();
GtkCellRenderer *rend2 = gtk_cell_renderer_toggle_new();
GtkTreeViewColumn *col1 = gtk_tree_view_column_new_with_attributes(
}
}
- GtkWidget *combo = aweather_gui_get_widget(self, "site");
- GObject *renderer = aweather_gui_get_object(self, "site_rend");
+ GtkWidget *combo = aweather_gui_get_widget(self, "main_site");
+ GObject *renderer = aweather_gui_get_object(self, "main_site_rend");
gtk_cell_layout_set_cell_data_func(GTK_CELL_LAYOUT(combo),
GTK_CELL_RENDERER(renderer), combo_sensitive, NULL, NULL);
static void time_setup(AWeatherGui *self)
{
- GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "time"));
+ GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "main_time"));
GtkCellRenderer *rend = gtk_cell_renderer_text_new();
GtkTreeViewColumn *col = gtk_tree_view_column_new_with_attributes(
"Time", rend, "text", 0, NULL);
GRegex *regex = g_regex_new("^[A-Z]{4}_([0-9]{8}_[0-9]{4})$", 0, 0, NULL); // KLSX_20090622_2113
GMatchInfo *info;
- GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "time"));
+ GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "main_time"));
GtkListStore *lstore = GTK_LIST_STORE(gtk_tree_view_get_model(tview));
gtk_list_store_clear(lstore);
GtkTreeIter iter;
g_debug("AWeatherGui: update_times - site=%s", site);
if (gis_world_get_offline(self->world)) {
GList *times = NULL;
- gchar *path = g_build_filename(g_get_user_cache_dir(), PACKAGE, "nexrd2", "raw", site, NULL);
+ gchar *path = g_build_filename(g_get_user_cache_dir(),
+ "libgis", "nexrd2", "raw", site, NULL);
GDir *dir = g_dir_open(path, 0, NULL);
if (dir) {
const gchar *name;
update_times_gtk(self, times);
} else {
gchar *path = g_strdup_printf("nexrd2/raw/%s/dir.list", site);
- char *base = gis_prefs_get_string(self->prefs, "aweather/nexrad_url");
+ char *base = gis_prefs_get_string(self->prefs, "aweather/nexrad_url", NULL);
cache_file(base, path, GIS_REFRESH, NULL, update_times_online_cb, self);
/* update_times_gtk from update_times_online_cb */
}
{
GisPlugin *plugin = gis_plugins_load(self->plugins, name,
self->world, self->view, self->opengl, self->prefs);
- GtkWidget *config = aweather_gui_get_widget(self, "tabs");
- GtkWidget *tab = gtk_label_new(name);
- GtkWidget *body = gis_plugin_get_config(plugin);
- gtk_notebook_append_page(GTK_NOTEBOOK(config), body, tab);
- gtk_widget_show_all(config);
+ GtkWidget *body = gis_plugin_get_config(plugin);
+ if (body) {
+ GtkWidget *config = aweather_gui_get_widget(self, "main_tabs");
+ GtkWidget *tab = gtk_label_new(name);
+ gtk_notebook_append_page(GTK_NOTEBOOK(config), body, tab);
+ gtk_widget_show_all(config);
+ }
gis_opengl_redraw(self->opengl);
}
void aweather_gui_deattach_plugin(AWeatherGui *self, const gchar *name)
{
- GtkWidget *config = aweather_gui_get_widget(self, "tabs");
+ GtkWidget *config = aweather_gui_get_widget(self, "main_tabs");
guint n_pages = gtk_notebook_get_n_pages(GTK_NOTEBOOK(config));
for (int i = 0; i < n_pages; i++) {
g_debug("testing tab %d", i);
g_debug("AWeatherGui: init");
/* Simple things */
- self->prefs = gis_prefs_new("aweather");
- self->plugins = gis_plugins_new();
+ gchar *config = g_build_filename(g_get_user_config_dir(), PACKAGE, "config.ini", NULL);
+ gchar *defaults = g_build_filename(PKGDATADIR, "defaults.ini", NULL);
+ self->prefs = gis_prefs_new(config, defaults);
+ self->plugins = gis_plugins_new(PLUGINSDIR);
self->world = gis_world_new();
self->view = gis_view_new();
self->opengl = gis_opengl_new(self->world, self->view, self->plugins);
+ g_free(config);
+ g_free(defaults);
/* Setup window */
self->builder = gtk_builder_new();
GError *error = NULL;
- if (!gtk_builder_add_from_file(self->builder, DATADIR "/aweather/main.ui", &error))
+ if (!gtk_builder_add_from_file(self->builder, PKGDATADIR "/main.ui", &error))
g_error("Failed to create gtk builder: %s", error->message);
- gtk_widget_reparent(aweather_gui_get_widget(self, "body"), GTK_WIDGET(self));
- GtkWidget *hpaned = aweather_gui_get_widget(self, "hpaned");
- gtk_widget_destroy(gtk_paned_get_child1(GTK_PANED(hpaned)));
- gtk_paned_pack1(GTK_PANED(hpaned), GTK_WIDGET(self->opengl), TRUE, FALSE);
+ gtk_widget_reparent(aweather_gui_get_widget(self, "main_body"), GTK_WIDGET(self));
+ GtkWidget *paned = aweather_gui_get_widget(self, "main_paned");
+ gtk_widget_destroy(gtk_paned_get_child1(GTK_PANED(paned)));
+ gtk_paned_pack1(GTK_PANED(paned), GTK_WIDGET(self->opengl), TRUE, FALSE);
/* Plugins */
GtkTreeIter iter;
self->gtk_plugins = GTK_LIST_STORE(aweather_gui_get_object(self, "plugins"));
- for (GList *cur = gis_plugins_available(); cur; cur = cur->next) {
+ for (GList *cur = gis_plugins_available(self->plugins); cur; cur = cur->next) {
gchar *name = cur->data;
- gboolean enabled = gis_prefs_get_boolean_v(self->prefs, cur->data, "enabled");
+ GError *error = NULL;
+ gboolean enabled = gis_prefs_get_boolean_v(self->prefs, cur->data, "enabled", &error);
+ if (error && error->code == G_KEY_FILE_ERROR_GROUP_NOT_FOUND)
+ enabled = TRUE;
gtk_list_store_append(self->gtk_plugins, &iter);
gtk_list_store_set(self->gtk_plugins, &iter, 0, name, 1, enabled, -1);
if (enabled)
AWeatherGui *self = AWEATHER_GUI(_self);
if (self->builder) {
/* Reparent to avoid double unrefs */
- GtkWidget *body = aweather_gui_get_widget(self, "body");
+ GtkWidget *body = aweather_gui_get_widget(self, "main_body");
GtkWidget *window = aweather_gui_get_widget(self, "main_window");
gtk_widget_reparent(body, window);
g_object_unref(self->builder);