diff options
-rw-r--r-- | configure.ac | 7 | ||||
-rw-r--r-- | modules/cal-config-weather/evolution-cal-config-weather.c | 85 |
2 files changed, 22 insertions, 70 deletions
diff --git a/configure.ac b/configure.ac index c1982f633a..dfa3806954 100644 --- a/configure.ac +++ b/configure.ac @@ -52,7 +52,7 @@ m4_define([clutter_gtk_minimum_version], [0.90]) m4_define([geoclue_minimum_version], [0.12.0]) m4_define([gladeui_minimum_version], [3.10.0]) m4_define([goa_minimum_version], [3.2]) -m4_define([gweather_minimum_version], [2.90.0]) +m4_define([gweather_minimum_version], [3.5.0]) m4_define([libcanberra_gtk_minimum_version], [0.25]) m4_define([libnotify_minimum_version], [0.7]) m4_define([nm_minimum_version], [0.7]) @@ -1280,11 +1280,6 @@ if test "x$enable_weather" != "xno"; then if test "x$have_weather" = "xno"; then AC_MSG_ERROR([gweather-3.0 >= gweather_minimum_version is required for configuring weather calendars. Use --disable-weather to disable this feature.]) fi - - dnl gweather-3.5 introduces API changes we do not yet support. - if `$PKG_CONFIG --atleast-version=3.5 gweather-3.0`; then - AC_MSG_ERROR([gweather-3.5 is not yet supported. Install gweather-3.4 or specify --disable-weather as a configure option to exclude the calendar-weather plugin.]) - fi fi AM_CONDITIONAL(ENABLE_WEATHER, [test "x$enable_weather" != "xno"]) diff --git a/modules/cal-config-weather/evolution-cal-config-weather.c b/modules/cal-config-weather/evolution-cal-config-weather.c index 587be55f15..5387fe16c4 100644 --- a/modules/cal-config-weather/evolution-cal-config-weather.c +++ b/modules/cal-config-weather/evolution-cal-config-weather.c @@ -41,7 +41,6 @@ typedef struct _Context Context; struct _Context { GtkWidget *location_entry; - GtkWidget *units_combo; }; /* Forward Declarations */ @@ -56,7 +55,6 @@ static void cal_config_weather_context_free (Context *context) { g_object_unref (context->location_entry); - g_object_unref (context->units_combo); g_slice_free (Context, context); } @@ -70,7 +68,7 @@ cal_config_weather_location_to_string (GBinding *binding, GWeatherLocation *location; gchar *string = NULL; - location = g_value_get_pointer (source_value); + location = g_value_get_boxed (source_value); if (location != NULL) { const gchar *code; @@ -87,29 +85,20 @@ cal_config_weather_location_to_string (GBinding *binding, return TRUE; } -/* XXX This is a private libgweather constant. - * The value may change at any time. */ -#define GWEATHER_LOCATION_ENTRY_COL_LOCATION 1 - static gboolean cal_config_weather_string_to_location (GBinding *binding, const GValue *source_value, GValue *target_value, gpointer user_data) { - GObject *target; - GWeatherLocation *match = NULL; - GtkEntryCompletion *completion; - GtkTreeModel *model; - GtkTreeIter iter; + GWeatherLocation *world; + GWeatherLocation *match, *start; const gchar *string; const gchar *city_name; const gchar *code; gchar **tokens; - /* XXX This is a bit convoluted because libgweather lacks a - * GWeatherLocation lookup function. The algorithm is - * copied from gweather_location_entry_set_city(). */ + world = user_data; string = g_value_get_string (source_value); @@ -127,42 +116,28 @@ cal_config_weather_string_to_location (GBinding *binding, code = tokens[0]; city_name = tokens[1]; - target = g_binding_get_target (binding); - completion = gtk_entry_get_completion (GTK_ENTRY (target)); - model = gtk_entry_completion_get_model (completion); - - gtk_tree_model_get_iter_first (model, &iter); - - do { - GWeatherLocation *location; - const gchar *cmp_code; - gchar *cmp_city_name; - - gtk_tree_model_get ( - model, &iter, - GWEATHER_LOCATION_ENTRY_COL_LOCATION, - &location, -1); - - /* Does the station code match? */ - cmp_code = gweather_location_get_code (location); - if (g_strcmp0 (code, cmp_code) != 0) - continue; + match = start = gweather_location_find_by_station_code (world, code); + while (match) { + char *cmp_city_name; /* Does the city name match? */ - cmp_city_name = gweather_location_get_city_name (location); - if (g_strcmp0 (city_name, cmp_city_name) != 0) { + cmp_city_name = gweather_location_get_city_name (match); + if (g_strcmp0 (city_name, cmp_city_name) == 0) { g_free (cmp_city_name); - continue; + break; } g_free (cmp_city_name); - /* We found a match! */ - match = location; - break; + /* No match, try parent */ + match = gweather_location_get_parent (match); + } - } while (gtk_tree_model_iter_next (model, &iter)); + if (match == NULL) { + /* No exact match, use start instead */ + match = start; + } - g_value_set_pointer (target_value, match); + g_value_set_boxed (target_value, match); g_strfreev (tokens); @@ -217,23 +192,8 @@ cal_config_weather_insert_widgets (ESourceConfigBackend *backend, context->location_entry = g_object_ref (widget); gtk_widget_show (widget); - /* This must follow the order of ESourceWeatherUnits. */ - widget = gtk_combo_box_text_new (); - gtk_combo_box_text_append_text ( - GTK_COMBO_BOX_TEXT (widget), - _("Metric (Celsius, cm, etc)")); - gtk_combo_box_text_append_text ( - GTK_COMBO_BOX_TEXT (widget), - _("Imperial (Fahrenheit, inches, etc)")); - e_source_config_insert_widget ( - config, scratch_source, _("Units:"), widget); - context->units_combo = g_object_ref (widget); - gtk_widget_show (widget); - e_source_config_add_refresh_interval (config, scratch_source); - gweather_location_unref (world); - extension_name = E_SOURCE_EXTENSION_WEATHER_BACKEND; extension = e_source_get_extension (scratch_source, extension_name); @@ -244,13 +204,10 @@ cal_config_weather_insert_widgets (ESourceConfigBackend *backend, G_BINDING_SYNC_CREATE, cal_config_weather_string_to_location, cal_config_weather_location_to_string, - NULL, (GDestroyNotify) NULL); + gweather_location_ref (world), + (GDestroyNotify) gweather_location_unref); - g_object_bind_property ( - extension, "units", - context->units_combo, "active", - G_BINDING_BIDIRECTIONAL | - G_BINDING_SYNC_CREATE); + gweather_location_unref (world); } static gboolean |