static void migrate_46_plugin_actions (XfconfChannel *channel, XfceRc *rc) { gint type; guint first_action = 0; guint second_action = 0; if (!xfce_rc_has_entry (rc, "type")) return; type = xfce_rc_read_int_entry (rc, "types", 0); switch (type) { case 0: /* ACTION_QUIT */ first_action = 1; break; case 1: /* ACTION_LOCK */ first_action = 2; break; default: /* ACTION_QUIT_LOCK */ first_action = 1; second_action = 3; break; } xfconf_channel_set_uint (channel, "/first-action", first_action); xfconf_channel_set_uint (channel, "/second-action", second_action); }
static void migrate_46_plugin_iconbox (XfconfChannel *channel, XfceRc *rc) { /* tasklist in iconbox mode */ xfconf_channel_set_uint (channel, "/show-labels", FALSE); migrate_46_plugin_bool ("only_hidden", "show-only-minimized", FALSE); migrate_46_plugin_bool ("all_workspaces", "include-all-workspaces", TRUE); /* TODO * xfce_rc_write_int_entry (rc, "expand", iconbox->expand); */ }
/* Setting '/min-notification-timeout' changed either at widget or at xfconf property */ static void _xfdashboard_settings_widget_changed_notification_timeout(XfdashboardSettings *self, GtkRange *inRange) { XfdashboardSettingsPrivate *priv; guint value; g_return_if_fail(XFDASHBOARD_IS_SETTINGS(self)); g_return_if_fail(GTK_IS_RANGE(inRange)); priv=self->priv; /* Get value from widget */ value=floor(gtk_range_get_value(inRange)*1000); /* Set value at xfconf property */ xfconf_channel_set_uint(priv->xfconfChannel, "/min-notification-timeout", value); }
static void migrate_46_plugin_separator (XfconfChannel *channel, XfceRc *rc) { gint type; guint style; if (!xfce_rc_has_entry (rc, "separator-type")) return; type = xfce_rc_read_int_entry (rc, "separator-type", 0); switch (type) { case 0: /* SEP_SPACE */ style = 0; /* SEPARATOR_PLUGIN_STYLE_TRANSPARENT */ break; case 1: /* SEP_EXPAND */ style = 0; /* SEPARATOR_PLUGIN_STYLE_TRANSPARENT */ xfconf_channel_set_bool (channel, "/expand", TRUE); break; case 2: /* SEP_LINE */ style = 1; /* SEPARATOR_PLUGIN_STYLE_SEPARATOR */ break; case 3: /* SEP_HANDLE */ style = 2; /* SEPARATOR_PLUGIN_STYLE_HANDLE */ break; default: /* SEP_DOTS */ style = 3; /* SEPARATOR_PLUGIN_STYLE_DOTS */ break; } xfconf_channel_set_uint (channel, "/style", style); }
static void migrate_46_plugin_clock (XfconfChannel *channel, XfceRc *rc) { gint type; if (xfce_rc_has_entry (rc, "ClockType")) { type = xfce_rc_read_int_entry (rc, "ClockType", 0); if (type == 4) /* XFCE_CLOCK_LCD */ type++; /* Skip CLOCK_PLUGIN_MODE_FUZZY */ xfconf_channel_set_uint (channel, "/mode", type); } migrate_46_plugin_string ("DigitalFormat", "digital-format", "%R"); migrate_46_plugin_string ("TooltipFormat", "tooltip-format", "%A %d %B %Y"); migrate_46_plugin_bool ("ShowFrame", "show-frame", TRUE); migrate_46_plugin_bool ("ShowSeconds", "show-seconds", FALSE); migrate_46_plugin_bool ("ShowMilitary", "show-military", FALSE); migrate_46_plugin_bool ("ShowMeridiem", "show-meridiem", TRUE); migrate_46_plugin_bool ("FlashSeparators", "flash-separators", FALSE); migrate_46_plugin_bool ("TrueBinary", "true-binary", FALSE); }
static void migrate_46_end_element_handler (GMarkupParseContext *context, const gchar *element_name, gpointer user_data, GError **error) { ConfigParser *parser = user_data; SnapPosition snap_position; gboolean horizontal; gchar prop[128]; gchar *position; g_return_if_fail (XFCONF_IS_CHANNEL (parser->channel)); switch (parser->state) { case START: g_set_error (error, G_MARKUP_ERROR_PARSE, G_MARKUP_ERROR, "Unexpected end element \"%s\"", element_name); break; case PANEL: if (strcmp ("panel", element_name) == 0) { parser->state = PANELS; /* store ids array */ g_snprintf (prop, sizeof (prop), "/panels/panel-%u/plugin-ids", parser->panel_id_counter); xfconf_channel_set_arrayv (parser->channel, prop, parser->panel_plugin_ids); xfconf_array_free (parser->panel_plugin_ids); /* translate the old screen position to a snap position and orientation */ migrate_46_panel_screen_position (parser->panel_screen_position, &snap_position, &horizontal); g_snprintf (prop, sizeof (prop), "/panels/panel-%u/horizontal", parser->panel_id_counter); xfconf_channel_set_bool (parser->channel, prop, horizontal); g_snprintf (prop, sizeof (prop), "/panels/panel-%u/position", parser->panel_id_counter); position = g_strdup_printf ("p=%d;x=%d;y=%d", snap_position, parser->panel_xoffset, parser->panel_yoffset); xfconf_channel_set_string (parser->channel, prop, position); g_free (position); /* set transparency */ g_snprintf (prop, sizeof (prop), "/panels/panel-%u/leave-opacity", parser->panel_id_counter); xfconf_channel_set_uint (parser->channel, prop, 100 - parser->panel_transparency); g_snprintf (prop, sizeof (prop), "/panels/panel-%u/enter-opacity", parser->panel_id_counter); xfconf_channel_set_uint (parser->channel, prop, parser->panel_activetrans ? 100 - parser->panel_transparency : 100); /* prepare for the next panel */ parser->panel_id_counter++; } break; case PANELS: if (strcmp ("panels", element_name) == 0) { parser->state = START; xfconf_channel_set_uint (parser->channel, "/panels", parser->panel_id_counter); } break; case PROPERTIES: if (strcmp ("properties", element_name) == 0) parser->state = PANEL; break; case ITEMS: if (strcmp ("items", element_name) == 0) parser->state = PANEL; break; default: g_set_error (error, G_MARKUP_ERROR_UNKNOWN_ELEMENT, G_MARKUP_ERROR, "Unknown end element \"%s\"", element_name); break; } }
static void migrate_46_panel_set_property (ConfigParser *parser, const gchar *property_name, const gchar *value, GError **error) { gchar prop[128]; GdkDisplay *display; gchar *name; gint num; if (strcmp (property_name, "size") == 0) { g_snprintf (prop, sizeof (prop), "/panels/panel-%u/size", parser->panel_id_counter); xfconf_channel_set_uint (parser->channel, prop, CLAMP (atoi (value), 16, 128)); } else if (strcmp (property_name, "fullwidth") == 0) { g_snprintf (prop, sizeof (prop), "/panels/panel-%u/length", parser->panel_id_counter); xfconf_channel_set_uint (parser->channel, prop, (atoi (value) != 0) ? 100 : 0); } else if (strcmp (property_name, "screen-position") == 0) { parser->panel_screen_position = CLAMP (atoi (value), XFCE_SCREEN_POSITION_NONE, XFCE_SCREEN_POSITION_FLOATING_V); } else if (strcmp (property_name, "xoffset") == 0) { parser->panel_xoffset = MAX (0, atoi (value)); } else if (strcmp (property_name, "yoffset") == 0) { parser->panel_yoffset = MAX (0, atoi (value)); } else if (strcmp (property_name, "monitor") == 0) { /* in 4.4 and 4.6 we only use monitor and make no difference between monitors * and screen's, so check the setup of the user to properly convert this */ num = MAX (0, atoi (value)); if (G_LIKELY (num > 0)) { display = gdk_display_get_default (); if (display != NULL && gdk_display_get_n_screens (display) > 1) name = g_strdup_printf ("screen-%d", num); else name = g_strdup_printf ("monitor-%d", num); g_snprintf (prop, sizeof (prop), "/panels/panel-%u/output", parser->panel_id_counter); xfconf_channel_set_string (parser->channel, prop, name); g_free (name); } } else if (strcmp (property_name, "handlestyle") == 0) { g_snprintf (prop, sizeof (prop), "/panels/panel-%u/locked", parser->panel_id_counter); xfconf_channel_set_bool (parser->channel, prop, atoi (value) == 0); } else if (strcmp (property_name, "autohide") == 0) { g_snprintf (prop, sizeof (prop), "/panels/panel-%u/autohide", parser->panel_id_counter); xfconf_channel_set_bool (parser->channel, prop, (atoi (value) == 1)); } else if (strcmp (property_name, "transparency") == 0) { parser->panel_transparency = CLAMP (atoi (value), 0, 100); } else if (strcmp (property_name, "activetrans") == 0) { parser->panel_activetrans = (atoi (value) == 1); } else { g_set_error (error, G_MARKUP_ERROR_UNKNOWN_ATTRIBUTE, G_MARKUP_ERROR, "Unknown property \"%s\" in #%d \"panel\" element", property_name, parser->panel_id_counter); } }