fixes for utf and non-utf locales
This commit is contained in:
parent
4a5e483105
commit
9d9d09a564
3 changed files with 458 additions and 473 deletions
|
@ -135,7 +135,7 @@ add_model_to_option_menu (const XklConfigItemPtr configItem, GtkWidget * menu)
|
||||||
GtkWidget *menuItem = GTK_WIDGET (existingItemNode->data);
|
GtkWidget *menuItem = GTK_WIDGET (existingItemNode->data);
|
||||||
GtkWidget *lbl = GTK_BIN (menuItem)->child;
|
GtkWidget *lbl = GTK_BIN (menuItem)->child;
|
||||||
const char *txt = gtk_label_get_text (GTK_LABEL (lbl));
|
const char *txt = gtk_label_get_text (GTK_LABEL (lbl));
|
||||||
if (g_strcasecmp (txt, utfModelName) > 0)
|
if (g_utf8_collate(txt, utfModelName) > 0)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
g_free (utfModelName);
|
g_free (utfModelName);
|
||||||
|
|
|
@ -47,7 +47,8 @@ static int maxSelectedLayouts = -1;
|
||||||
void
|
void
|
||||||
clear_xkb_elements_list (GSList * list)
|
clear_xkb_elements_list (GSList * list)
|
||||||
{
|
{
|
||||||
while (list != NULL) {
|
while (list != NULL)
|
||||||
|
{
|
||||||
GSList *p = list;
|
GSList *p = list;
|
||||||
list = list->next;
|
list = list->next;
|
||||||
g_free (p->data);
|
g_free (p->data);
|
||||||
|
@ -72,10 +73,8 @@ add_variant_to_available_layouts_tree (const XklConfigItemPtr
|
||||||
GtkWidget *layoutsTree = WID ("xkb_layouts_available");
|
GtkWidget *layoutsTree = WID ("xkb_layouts_available");
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
GtkTreeStore *treeStore =
|
GtkTreeStore *treeStore =
|
||||||
GTK_TREE_STORE (gtk_tree_view_get_model
|
GTK_TREE_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (layoutsTree)));
|
||||||
(GTK_TREE_VIEW (layoutsTree)));
|
const gchar *fullLayoutName = GSwitchItConfigMergeItems (current1stLevelId,
|
||||||
const gchar *fullLayoutName =
|
|
||||||
GSwitchItConfigMergeItems (current1stLevelId,
|
|
||||||
configItem->name);
|
configItem->name);
|
||||||
char *utfVariantName = xci_desc_to_utf8 (configItem);
|
char *utfVariantName = xci_desc_to_utf8 (configItem);
|
||||||
|
|
||||||
|
@ -91,8 +90,7 @@ add_layout_to_available_layouts_tree (const XklConfigItemPtr
|
||||||
{
|
{
|
||||||
GtkWidget *layoutsTree = WID ("xkb_layouts_available");
|
GtkWidget *layoutsTree = WID ("xkb_layouts_available");
|
||||||
GtkTreeStore *treeStore =
|
GtkTreeStore *treeStore =
|
||||||
GTK_TREE_STORE (gtk_tree_view_get_model
|
GTK_TREE_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (layoutsTree)));
|
||||||
(GTK_TREE_VIEW (layoutsTree)));
|
|
||||||
char *utfLayoutName = xci_desc_to_utf8 (configItem);
|
char *utfLayoutName = xci_desc_to_utf8 (configItem);
|
||||||
|
|
||||||
gtk_tree_store_append (treeStore, ¤t1stLevelIter, NULL);
|
gtk_tree_store_append (treeStore, ¤t1stLevelIter, NULL);
|
||||||
|
@ -104,8 +102,7 @@ add_layout_to_available_layouts_tree (const XklConfigItemPtr
|
||||||
|
|
||||||
XklConfigEnumLayoutVariants (configItem->name,
|
XklConfigEnumLayoutVariants (configItem->name,
|
||||||
(ConfigItemProcessFunc)
|
(ConfigItemProcessFunc)
|
||||||
add_variant_to_available_layouts_tree,
|
add_variant_to_available_layouts_tree, dialog);
|
||||||
dialog);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -119,13 +116,11 @@ enable_disable_layouts_buttons (GladeXML * dialog)
|
||||||
GtkWidget *selectedLayoutsTree = WID ("xkb_layouts_selected");
|
GtkWidget *selectedLayoutsTree = WID ("xkb_layouts_selected");
|
||||||
|
|
||||||
GtkTreeSelection *aSelection =
|
GtkTreeSelection *aSelection =
|
||||||
gtk_tree_view_get_selection (GTK_TREE_VIEW
|
gtk_tree_view_get_selection (GTK_TREE_VIEW (availableLayoutsTree));
|
||||||
(availableLayoutsTree));
|
|
||||||
const int nSelectedAvailableLayouts =
|
const int nSelectedAvailableLayouts =
|
||||||
gtk_tree_selection_count_selected_rows (aSelection);
|
gtk_tree_selection_count_selected_rows (aSelection);
|
||||||
GtkTreeSelection *sSelection =
|
GtkTreeSelection *sSelection =
|
||||||
gtk_tree_view_get_selection (GTK_TREE_VIEW
|
gtk_tree_view_get_selection (GTK_TREE_VIEW (selectedLayoutsTree));
|
||||||
(selectedLayoutsTree));
|
|
||||||
const int nSelectedSelectedLayouts =
|
const int nSelectedSelectedLayouts =
|
||||||
gtk_tree_selection_count_selected_rows (sSelection);
|
gtk_tree_selection_count_selected_rows (sSelection);
|
||||||
gboolean canMoveUp = FALSE;
|
gboolean canMoveUp = FALSE;
|
||||||
|
@ -139,16 +134,15 @@ enable_disable_layouts_buttons (GladeXML * dialog)
|
||||||
|
|
||||||
gtk_widget_set_sensitive (addLayoutBtn,
|
gtk_widget_set_sensitive (addLayoutBtn,
|
||||||
(nSelectedAvailableLayouts > 0)
|
(nSelectedAvailableLayouts > 0)
|
||||||
&& (nSelectedLayouts <
|
&& (nSelectedLayouts < maxSelectedLayouts));
|
||||||
maxSelectedLayouts));
|
gtk_widget_set_sensitive (delLayoutBtn, nSelectedSelectedLayouts > 0);
|
||||||
gtk_widget_set_sensitive (delLayoutBtn,
|
|
||||||
nSelectedSelectedLayouts > 0);
|
|
||||||
|
|
||||||
if (gtk_tree_selection_get_selected (sSelection, NULL, &iter)) {
|
if (gtk_tree_selection_get_selected (sSelection, NULL, &iter))
|
||||||
GtkTreePath *path =
|
{
|
||||||
gtk_tree_model_get_path (selectedLayoutsModel,
|
GtkTreePath *path = gtk_tree_model_get_path (selectedLayoutsModel,
|
||||||
&iter);
|
&iter);
|
||||||
if (path != NULL) {
|
if (path != NULL)
|
||||||
|
{
|
||||||
int *indices = gtk_tree_path_get_indices (path);
|
int *indices = gtk_tree_path_get_indices (path);
|
||||||
int idx = indices[0];
|
int idx = indices[0];
|
||||||
canMoveUp = idx > 0;
|
canMoveUp = idx > 0;
|
||||||
|
@ -168,8 +162,7 @@ prepare_selected_layouts_tree (GladeXML * dialog)
|
||||||
GtkWidget *treeView = WID ("xkb_layouts_selected");
|
GtkWidget *treeView = WID ("xkb_layouts_selected");
|
||||||
GtkCellRenderer *renderer =
|
GtkCellRenderer *renderer =
|
||||||
GTK_CELL_RENDERER (gtk_cell_renderer_text_new ());
|
GTK_CELL_RENDERER (gtk_cell_renderer_text_new ());
|
||||||
GtkTreeViewColumn *column =
|
GtkTreeViewColumn *column = gtk_tree_view_column_new_with_attributes (NULL,
|
||||||
gtk_tree_view_column_new_with_attributes (NULL,
|
|
||||||
renderer,
|
renderer,
|
||||||
"text",
|
"text",
|
||||||
0,
|
0,
|
||||||
|
@ -181,10 +174,8 @@ prepare_selected_layouts_tree (GladeXML * dialog)
|
||||||
gtk_tree_view_append_column (GTK_TREE_VIEW (treeView), column);
|
gtk_tree_view_append_column (GTK_TREE_VIEW (treeView), column);
|
||||||
g_signal_connect_swapped (G_OBJECT (selection), "changed",
|
g_signal_connect_swapped (G_OBJECT (selection), "changed",
|
||||||
G_CALLBACK
|
G_CALLBACK
|
||||||
(enable_disable_layouts_buttons),
|
(enable_disable_layouts_buttons), dialog);
|
||||||
dialog);
|
maxSelectedLayouts = XklMultipleLayoutsSupported ()? XkbNumKbdGroups : 1;
|
||||||
maxSelectedLayouts =
|
|
||||||
XklMultipleLayoutsSupported ()? XkbNumKbdGroups : 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -194,32 +185,34 @@ fill_selected_layouts_tree (GladeXML * dialog)
|
||||||
GSList *curLayout;
|
GSList *curLayout;
|
||||||
GtkListStore *listStore =
|
GtkListStore *listStore =
|
||||||
GTK_LIST_STORE (gtk_tree_view_get_model
|
GTK_LIST_STORE (gtk_tree_view_get_model
|
||||||
(GTK_TREE_VIEW
|
(GTK_TREE_VIEW (WID ("xkb_layouts_selected"))));
|
||||||
(WID ("xkb_layouts_selected"))));
|
|
||||||
gtk_list_store_clear (listStore);
|
gtk_list_store_clear (listStore);
|
||||||
|
|
||||||
for (curLayout = layouts; curLayout != NULL;
|
for (curLayout = layouts; curLayout != NULL; curLayout = curLayout->next)
|
||||||
curLayout = curLayout->next) {
|
{
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
char *l, *sl, *v, *sv;
|
char *l, *sl, *v, *sv;
|
||||||
|
char *v1, *utfVisible;
|
||||||
const char *visible = (char *) curLayout->data;
|
const char *visible = (char *) curLayout->data;
|
||||||
gtk_list_store_append (listStore, &iter);
|
gtk_list_store_append (listStore, &iter);
|
||||||
if (GSwitchItConfigGetDescriptions
|
if (GSwitchItConfigGetDescriptions (visible, &sl, &l, &sv, &v))
|
||||||
(visible, &sl, &l, &sv, &v))
|
|
||||||
visible = GSwitchItConfigFormatFullLayout (l, v);
|
visible = GSwitchItConfigFormatFullLayout (l, v);
|
||||||
|
v1 = g_strdup (visible);
|
||||||
|
utfVisible = g_locale_to_utf8 (g_strstrip (v1), -1, NULL, NULL, NULL);
|
||||||
gtk_list_store_set (listStore, &iter,
|
gtk_list_store_set (listStore, &iter,
|
||||||
0, visible, 1, curLayout->data, -1);
|
0, utfVisible, 1, curLayout->data, -1);
|
||||||
|
g_free (utfVisible);
|
||||||
|
g_free (v1);
|
||||||
}
|
}
|
||||||
|
|
||||||
clear_xkb_elements_list (layouts);
|
clear_xkb_elements_list (layouts);
|
||||||
enable_disable_layouts_buttons (dialog);
|
enable_disable_layouts_buttons (dialog);
|
||||||
if (idx2Select != -1) {
|
if (idx2Select != -1)
|
||||||
|
{
|
||||||
GtkTreeSelection *selection =
|
GtkTreeSelection *selection =
|
||||||
gtk_tree_view_get_selection ((GTK_TREE_VIEW
|
gtk_tree_view_get_selection ((GTK_TREE_VIEW
|
||||||
(WID
|
(WID ("xkb_layouts_selected"))));
|
||||||
("xkb_layouts_selected"))));
|
GtkTreePath *path = gtk_tree_path_new_from_indices (idx2Select, -1);
|
||||||
GtkTreePath *path =
|
|
||||||
gtk_tree_path_new_from_indices (idx2Select, -1);
|
|
||||||
gtk_tree_selection_select_path (selection, path);
|
gtk_tree_selection_select_path (selection, path);
|
||||||
gtk_tree_path_free (path);
|
gtk_tree_path_free (path);
|
||||||
idx2Select = -1;
|
idx2Select = -1;
|
||||||
|
@ -237,8 +230,7 @@ sort_tree_content (GtkWidget * treeView)
|
||||||
gtk_tree_sortable_set_sort_column_id (GTK_TREE_SORTABLE
|
gtk_tree_sortable_set_sort_column_id (GTK_TREE_SORTABLE
|
||||||
(sortedTreeModel), 0,
|
(sortedTreeModel), 0,
|
||||||
GTK_SORT_ASCENDING);
|
GTK_SORT_ASCENDING);
|
||||||
gtk_tree_view_set_model (GTK_TREE_VIEW (treeView),
|
gtk_tree_view_set_model (GTK_TREE_VIEW (treeView), sortedTreeModel);
|
||||||
sortedTreeModel);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -249,8 +241,7 @@ fill_available_layouts_tree (GladeXML * dialog)
|
||||||
GtkWidget *treeView = WID ("xkb_layouts_available");
|
GtkWidget *treeView = WID ("xkb_layouts_available");
|
||||||
GtkCellRenderer *renderer =
|
GtkCellRenderer *renderer =
|
||||||
GTK_CELL_RENDERER (gtk_cell_renderer_text_new ());
|
GTK_CELL_RENDERER (gtk_cell_renderer_text_new ());
|
||||||
GtkTreeViewColumn *column =
|
GtkTreeViewColumn *column = gtk_tree_view_column_new_with_attributes (NULL,
|
||||||
gtk_tree_view_column_new_with_attributes (NULL,
|
|
||||||
renderer,
|
renderer,
|
||||||
"text",
|
"text",
|
||||||
0,
|
0,
|
||||||
|
@ -263,14 +254,12 @@ fill_available_layouts_tree (GladeXML * dialog)
|
||||||
gtk_tree_view_append_column (GTK_TREE_VIEW (treeView), column);
|
gtk_tree_view_append_column (GTK_TREE_VIEW (treeView), column);
|
||||||
|
|
||||||
XklConfigEnumLayouts ((ConfigItemProcessFunc)
|
XklConfigEnumLayouts ((ConfigItemProcessFunc)
|
||||||
add_layout_to_available_layouts_tree,
|
add_layout_to_available_layouts_tree, dialog);
|
||||||
dialog);
|
|
||||||
|
|
||||||
sort_tree_content (treeView);
|
sort_tree_content (treeView);
|
||||||
g_signal_connect_swapped (G_OBJECT (selection), "changed",
|
g_signal_connect_swapped (G_OBJECT (selection), "changed",
|
||||||
G_CALLBACK
|
G_CALLBACK
|
||||||
(enable_disable_layouts_buttons),
|
(enable_disable_layouts_buttons), dialog);
|
||||||
dialog);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -281,8 +270,8 @@ add_selected_layout (GtkWidget * button, GladeXML * dialog)
|
||||||
(WID ("xkb_layouts_available")));
|
(WID ("xkb_layouts_available")));
|
||||||
GtkTreeIter selectedIter;
|
GtkTreeIter selectedIter;
|
||||||
GtkTreeModel *model;
|
GtkTreeModel *model;
|
||||||
if (gtk_tree_selection_get_selected
|
if (gtk_tree_selection_get_selected (selection, &model, &selectedIter))
|
||||||
(selection, &model, &selectedIter)) {
|
{
|
||||||
gchar *id;
|
gchar *id;
|
||||||
GSList *layoutsList = get_selected_layouts_list ();
|
GSList *layoutsList = get_selected_layouts_list ();
|
||||||
gtk_tree_model_get (model, &selectedIter, 1, &id, -1);
|
gtk_tree_model_get (model, &selectedIter, 1, &id, -1);
|
||||||
|
@ -300,29 +289,28 @@ move_selected_layout (GladeXML * dialog, int offset)
|
||||||
(WID ("xkb_layouts_selected")));
|
(WID ("xkb_layouts_selected")));
|
||||||
GtkTreeIter selectedIter;
|
GtkTreeIter selectedIter;
|
||||||
GtkTreeModel *model;
|
GtkTreeModel *model;
|
||||||
if (gtk_tree_selection_get_selected
|
if (gtk_tree_selection_get_selected (selection, &model, &selectedIter))
|
||||||
(selection, &model, &selectedIter)) {
|
{
|
||||||
GSList *layoutsList = get_selected_layouts_list ();
|
GSList *layoutsList = get_selected_layouts_list ();
|
||||||
GtkTreePath *path = gtk_tree_model_get_path (model,
|
GtkTreePath *path = gtk_tree_model_get_path (model,
|
||||||
&selectedIter);
|
&selectedIter);
|
||||||
if (path != NULL) {
|
if (path != NULL)
|
||||||
|
{
|
||||||
int *indices = gtk_tree_path_get_indices (path);
|
int *indices = gtk_tree_path_get_indices (path);
|
||||||
char *id = NULL;
|
char *id = NULL;
|
||||||
GSList *node2Remove =
|
GSList *node2Remove = g_slist_nth (layoutsList, indices[0]);
|
||||||
g_slist_nth (layoutsList, indices[0]);
|
|
||||||
|
|
||||||
layoutsList =
|
layoutsList = g_slist_remove_link (layoutsList, node2Remove);
|
||||||
g_slist_remove_link (layoutsList, node2Remove);
|
|
||||||
|
|
||||||
id = (char *) node2Remove->data;
|
id = (char *) node2Remove->data;
|
||||||
g_slist_free_1 (node2Remove);
|
g_slist_free_1 (node2Remove);
|
||||||
|
|
||||||
if (offset == 0)
|
if (offset == 0)
|
||||||
g_free (id);
|
g_free (id);
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
layoutsList =
|
layoutsList =
|
||||||
g_slist_insert (layoutsList, id,
|
g_slist_insert (layoutsList, id, indices[0] + offset);
|
||||||
indices[0] + offset);
|
|
||||||
idx2Select = indices[0] + offset;
|
idx2Select = indices[0] + offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -58,8 +58,7 @@ can_add_option (GladeXML * dialog)
|
||||||
GtkWidget *availableOptionsTree = WID ("xkb_options_available");
|
GtkWidget *availableOptionsTree = WID ("xkb_options_available");
|
||||||
GtkWidget *selectedOptionsTree = WID ("xkb_options_selected");
|
GtkWidget *selectedOptionsTree = WID ("xkb_options_selected");
|
||||||
GtkTreeSelection *aSelection =
|
GtkTreeSelection *aSelection =
|
||||||
gtk_tree_view_get_selection (GTK_TREE_VIEW
|
gtk_tree_view_get_selection (GTK_TREE_VIEW (availableOptionsTree));
|
||||||
(availableOptionsTree));
|
|
||||||
GtkTreeIter aiter, siter, groupIter;
|
GtkTreeIter aiter, siter, groupIter;
|
||||||
GtkTreeModel *availableOptionsModel, *selectedOptionsModel;
|
GtkTreeModel *availableOptionsModel, *selectedOptionsModel;
|
||||||
GtkTreePath *path, *groupPath;
|
GtkTreePath *path, *groupPath;
|
||||||
|
@ -78,19 +77,20 @@ can_add_option (GladeXML * dialog)
|
||||||
|
|
||||||
depth = gtk_tree_path_get_depth (path);
|
depth = gtk_tree_path_get_depth (path);
|
||||||
|
|
||||||
if (depth != 2) {
|
if (depth != 2)
|
||||||
|
{
|
||||||
gtk_tree_path_free (path);
|
gtk_tree_path_free (path);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!gtk_tree_model_iter_parent
|
if (!gtk_tree_model_iter_parent (availableOptionsModel, &groupIter, &aiter))
|
||||||
(availableOptionsModel, &groupIter, &aiter)) {
|
{
|
||||||
gtk_tree_path_free (path);
|
gtk_tree_path_free (path);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
groupPath =
|
groupPath = gtk_tree_model_get_path (availableOptionsModel, &groupIter);
|
||||||
gtk_tree_model_get_path (availableOptionsModel, &groupIter);
|
if (groupPath == NULL)
|
||||||
if (groupPath == NULL) {
|
{
|
||||||
gtk_tree_path_free (path);
|
gtk_tree_path_free (path);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -102,7 +102,8 @@ can_add_option (GladeXML * dialog)
|
||||||
&selectedFullOptionId, -1);
|
&selectedFullOptionId, -1);
|
||||||
|
|
||||||
if (!GSwitchItConfigSplitItems
|
if (!GSwitchItConfigSplitItems
|
||||||
(selectedFullOptionId, &selectedGroupId, &selectedOptionId)) {
|
(selectedFullOptionId, &selectedGroupId, &selectedOptionId))
|
||||||
|
{
|
||||||
gtk_tree_path_free (groupPath);
|
gtk_tree_path_free (groupPath);
|
||||||
gtk_tree_path_free (path);
|
gtk_tree_path_free (path);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -115,31 +116,35 @@ can_add_option (GladeXML * dialog)
|
||||||
|
|
||||||
retval = TRUE;
|
retval = TRUE;
|
||||||
|
|
||||||
if (gtk_tree_model_get_iter_first (selectedOptionsModel, &siter)) {
|
if (gtk_tree_model_get_iter_first (selectedOptionsModel, &siter))
|
||||||
do {
|
{
|
||||||
|
do
|
||||||
|
{
|
||||||
char *sid = NULL;
|
char *sid = NULL;
|
||||||
gtk_tree_model_get (selectedOptionsModel,
|
gtk_tree_model_get (selectedOptionsModel, &siter, 1, &sid, -1);
|
||||||
&siter, 1, &sid, -1);
|
if (multipleAllowed)
|
||||||
if (multipleAllowed) {
|
{
|
||||||
// look for the _same_ option - and do not allow it twice
|
// look for the _same_ option - and do not allow it twice
|
||||||
if (!g_strcasecmp
|
if (!g_strcasecmp (sid, selectedFullOptionId))
|
||||||
(sid, selectedFullOptionId)) {
|
{
|
||||||
retval = FALSE;
|
retval = FALSE;
|
||||||
}
|
}
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// look for options within same group
|
// look for options within same group
|
||||||
char *sgid = NULL, *soid = NULL;
|
char *sgid = NULL, *soid = NULL;
|
||||||
gtk_tree_model_get (selectedOptionsModel,
|
gtk_tree_model_get (selectedOptionsModel, &siter, 1, &sid, -1);
|
||||||
&siter, 1, &sid, -1);
|
|
||||||
if (GSwitchItConfigSplitItems
|
if (GSwitchItConfigSplitItems
|
||||||
(sid, &sgid, &soid)
|
(sid, &sgid, &soid)
|
||||||
&& !g_strcasecmp (sgid,
|
&& !g_strcasecmp (sgid, selectedGroupId))
|
||||||
selectedGroupId)) {
|
{
|
||||||
retval = FALSE;
|
retval = FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
g_free (sid);
|
g_free (sid);
|
||||||
} while (retval && gtk_tree_model_iter_next
|
}
|
||||||
|
while (retval && gtk_tree_model_iter_next
|
||||||
(selectedOptionsModel, &siter));
|
(selectedOptionsModel, &siter));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -160,14 +165,12 @@ enable_disable_options_buttons (GladeXML * dialog)
|
||||||
GtkWidget *selectedOptionsTree = WID ("xkb_options_selected");
|
GtkWidget *selectedOptionsTree = WID ("xkb_options_selected");
|
||||||
|
|
||||||
GtkTreeSelection *sSelection =
|
GtkTreeSelection *sSelection =
|
||||||
gtk_tree_view_get_selection (GTK_TREE_VIEW
|
gtk_tree_view_get_selection (GTK_TREE_VIEW (selectedOptionsTree));
|
||||||
(selectedOptionsTree));
|
|
||||||
const int nSelectedSelectedOptions =
|
const int nSelectedSelectedOptions =
|
||||||
gtk_tree_selection_count_selected_rows (sSelection);
|
gtk_tree_selection_count_selected_rows (sSelection);
|
||||||
|
|
||||||
gtk_widget_set_sensitive (addOptionBtn, can_add_option (dialog));
|
gtk_widget_set_sensitive (addOptionBtn, can_add_option (dialog));
|
||||||
gtk_widget_set_sensitive (delOptionBtn,
|
gtk_widget_set_sensitive (delOptionBtn, nSelectedSelectedOptions > 0);
|
||||||
nSelectedSelectedOptions > 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -179,8 +182,7 @@ prepare_selected_options_tree (GladeXML * dialog)
|
||||||
GtkWidget *treeView = WID ("xkb_options_selected");
|
GtkWidget *treeView = WID ("xkb_options_selected");
|
||||||
GtkCellRenderer *renderer =
|
GtkCellRenderer *renderer =
|
||||||
GTK_CELL_RENDERER (gtk_cell_renderer_text_new ());
|
GTK_CELL_RENDERER (gtk_cell_renderer_text_new ());
|
||||||
GtkTreeViewColumn *column =
|
GtkTreeViewColumn *column = gtk_tree_view_column_new_with_attributes (NULL,
|
||||||
gtk_tree_view_column_new_with_attributes (NULL,
|
|
||||||
renderer,
|
renderer,
|
||||||
"text",
|
"text",
|
||||||
0,
|
0,
|
||||||
|
@ -192,8 +194,7 @@ prepare_selected_options_tree (GladeXML * dialog)
|
||||||
gtk_tree_view_append_column (GTK_TREE_VIEW (treeView), column);
|
gtk_tree_view_append_column (GTK_TREE_VIEW (treeView), column);
|
||||||
g_signal_connect_swapped (G_OBJECT (selection), "changed",
|
g_signal_connect_swapped (G_OBJECT (selection), "changed",
|
||||||
G_CALLBACK
|
G_CALLBACK
|
||||||
(enable_disable_options_buttons),
|
(enable_disable_options_buttons), dialog);
|
||||||
dialog);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -204,8 +205,8 @@ add_selected_option (GtkWidget * button, GladeXML * dialog)
|
||||||
(WID ("xkb_options_available")));
|
(WID ("xkb_options_available")));
|
||||||
GtkTreeIter selectedIter;
|
GtkTreeIter selectedIter;
|
||||||
GtkTreeModel *model;
|
GtkTreeModel *model;
|
||||||
if (gtk_tree_selection_get_selected
|
if (gtk_tree_selection_get_selected (selection, &model, &selectedIter))
|
||||||
(selection, &model, &selectedIter)) {
|
{
|
||||||
gchar *id;
|
gchar *id;
|
||||||
GSList *optionsList = get_selected_options_list ();
|
GSList *optionsList = get_selected_options_list ();
|
||||||
gtk_tree_model_get (model, &selectedIter, 1, &id, -1);
|
gtk_tree_model_get (model, &selectedIter, 1, &id, -1);
|
||||||
|
@ -223,19 +224,18 @@ remove_selected_option (GtkWidget * button, GladeXML * dialog)
|
||||||
(WID ("xkb_options_selected")));
|
(WID ("xkb_options_selected")));
|
||||||
GtkTreeIter selectedIter;
|
GtkTreeIter selectedIter;
|
||||||
GtkTreeModel *model;
|
GtkTreeModel *model;
|
||||||
if (gtk_tree_selection_get_selected
|
if (gtk_tree_selection_get_selected (selection, &model, &selectedIter))
|
||||||
(selection, &model, &selectedIter)) {
|
{
|
||||||
GSList *optionsList = get_selected_options_list ();
|
GSList *optionsList = get_selected_options_list ();
|
||||||
GtkTreePath *path = gtk_tree_model_get_path (model,
|
GtkTreePath *path = gtk_tree_model_get_path (model,
|
||||||
&selectedIter);
|
&selectedIter);
|
||||||
if (path != NULL) {
|
if (path != NULL)
|
||||||
|
{
|
||||||
int *indices = gtk_tree_path_get_indices (path);
|
int *indices = gtk_tree_path_get_indices (path);
|
||||||
char *id = NULL;
|
char *id = NULL;
|
||||||
GSList *node2Remove =
|
GSList *node2Remove = g_slist_nth (optionsList, indices[0]);
|
||||||
g_slist_nth (optionsList, indices[0]);
|
|
||||||
|
|
||||||
optionsList =
|
optionsList = g_slist_remove_link (optionsList, node2Remove);
|
||||||
g_slist_remove_link (optionsList, node2Remove);
|
|
||||||
|
|
||||||
id = (char *) node2Remove->data;
|
id = (char *) node2Remove->data;
|
||||||
g_slist_free_1 (node2Remove);
|
g_slist_free_1 (node2Remove);
|
||||||
|
@ -256,10 +256,8 @@ add_option_to_available_options_tree (const XklConfigItemPtr
|
||||||
GtkWidget *optionsTree = WID ("xkb_options_available");
|
GtkWidget *optionsTree = WID ("xkb_options_available");
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
GtkTreeStore *treeStore =
|
GtkTreeStore *treeStore =
|
||||||
GTK_TREE_STORE (gtk_tree_view_get_model
|
GTK_TREE_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (optionsTree)));
|
||||||
(GTK_TREE_VIEW (optionsTree)));
|
const gchar *fullOptionName = GSwitchItConfigMergeItems (current1stLevelId,
|
||||||
const gchar *fullOptionName =
|
|
||||||
GSwitchItConfigMergeItems (current1stLevelId,
|
|
||||||
configItem->name);
|
configItem->name);
|
||||||
char *utfOptionName = xci_desc_to_utf8 (configItem);
|
char *utfOptionName = xci_desc_to_utf8 (configItem);
|
||||||
|
|
||||||
|
@ -277,8 +275,7 @@ add_group_to_available_options_tree (const XklConfigItemPtr
|
||||||
{
|
{
|
||||||
GtkWidget *optionsTree = WID ("xkb_options_available");
|
GtkWidget *optionsTree = WID ("xkb_options_available");
|
||||||
GtkTreeStore *treeStore =
|
GtkTreeStore *treeStore =
|
||||||
GTK_TREE_STORE (gtk_tree_view_get_model
|
GTK_TREE_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (optionsTree)));
|
||||||
(GTK_TREE_VIEW (optionsTree)));
|
|
||||||
char *utfGroupName = xci_desc_to_utf8 (configItem);
|
char *utfGroupName = xci_desc_to_utf8 (configItem);
|
||||||
|
|
||||||
gtk_tree_store_append (treeStore, ¤t1stLevelIter, NULL);
|
gtk_tree_store_append (treeStore, ¤t1stLevelIter, NULL);
|
||||||
|
@ -290,8 +287,7 @@ add_group_to_available_options_tree (const XklConfigItemPtr
|
||||||
current1stLevelId = configItem->name;
|
current1stLevelId = configItem->name;
|
||||||
|
|
||||||
XklConfigEnumOptions (configItem->name, (ConfigItemProcessFunc)
|
XklConfigEnumOptions (configItem->name, (ConfigItemProcessFunc)
|
||||||
add_option_to_available_options_tree,
|
add_option_to_available_options_tree, dialog);
|
||||||
dialog);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -303,8 +299,7 @@ fill_available_options_tree (GladeXML * dialog)
|
||||||
GtkWidget *treeView = WID ("xkb_options_available");
|
GtkWidget *treeView = WID ("xkb_options_available");
|
||||||
GtkCellRenderer *renderer =
|
GtkCellRenderer *renderer =
|
||||||
GTK_CELL_RENDERER (gtk_cell_renderer_text_new ());
|
GTK_CELL_RENDERER (gtk_cell_renderer_text_new ());
|
||||||
GtkTreeViewColumn *column =
|
GtkTreeViewColumn *column = gtk_tree_view_column_new_with_attributes (NULL,
|
||||||
gtk_tree_view_column_new_with_attributes (NULL,
|
|
||||||
renderer,
|
renderer,
|
||||||
"text",
|
"text",
|
||||||
0,
|
0,
|
||||||
|
@ -317,15 +312,13 @@ fill_available_options_tree (GladeXML * dialog)
|
||||||
gtk_tree_view_append_column (GTK_TREE_VIEW (treeView), column);
|
gtk_tree_view_append_column (GTK_TREE_VIEW (treeView), column);
|
||||||
|
|
||||||
XklConfigEnumOptionGroups ((GroupProcessFunc)
|
XklConfigEnumOptionGroups ((GroupProcessFunc)
|
||||||
add_group_to_available_options_tree,
|
add_group_to_available_options_tree, dialog);
|
||||||
dialog);
|
|
||||||
|
|
||||||
sort_tree_content (treeView);
|
sort_tree_content (treeView);
|
||||||
|
|
||||||
g_signal_connect_swapped (G_OBJECT (selection), "changed",
|
g_signal_connect_swapped (G_OBJECT (selection), "changed",
|
||||||
G_CALLBACK
|
G_CALLBACK
|
||||||
(enable_disable_options_buttons),
|
(enable_disable_options_buttons), dialog);
|
||||||
dialog);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -335,28 +328,32 @@ fill_selected_options_tree (GladeXML * dialog)
|
||||||
GSList *curOption;
|
GSList *curOption;
|
||||||
GtkListStore *listStore =
|
GtkListStore *listStore =
|
||||||
GTK_LIST_STORE (gtk_tree_view_get_model
|
GTK_LIST_STORE (gtk_tree_view_get_model
|
||||||
(GTK_TREE_VIEW
|
(GTK_TREE_VIEW (WID ("xkb_options_selected"))));
|
||||||
(WID ("xkb_options_selected"))));
|
|
||||||
gtk_list_store_clear (listStore);
|
gtk_list_store_clear (listStore);
|
||||||
|
|
||||||
for (curOption = options; curOption != NULL;
|
for (curOption = options; curOption != NULL; curOption = curOption->next)
|
||||||
curOption = curOption->next) {
|
{
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
char *groupName, *optionName;
|
char *groupName, *optionName;
|
||||||
const char *visible = (char *) curOption->data;
|
const char *visible = (char *) curOption->data;
|
||||||
|
|
||||||
if (GSwitchItConfigSplitItems
|
if (GSwitchItConfigSplitItems (visible, &groupName, &optionName))
|
||||||
(visible, &groupName, &optionName)) {
|
{
|
||||||
XklConfigItem citem;
|
XklConfigItem citem;
|
||||||
g_snprintf (citem.name, sizeof (citem.name), "%s",
|
char *v1, *utfVisible;
|
||||||
optionName);
|
g_snprintf (citem.name, sizeof (citem.name), "%s", optionName);
|
||||||
if (XklConfigFindOption (groupName, &citem)) {
|
if (XklConfigFindOption (groupName, &citem))
|
||||||
|
{
|
||||||
visible = citem.description;
|
visible = citem.description;
|
||||||
}
|
}
|
||||||
|
v1 = g_strdup (visible);
|
||||||
|
utfVisible =
|
||||||
|
g_locale_to_utf8 (g_strstrip (v1), -1, NULL, NULL, NULL);
|
||||||
gtk_list_store_append (listStore, &iter);
|
gtk_list_store_append (listStore, &iter);
|
||||||
gtk_list_store_set (listStore, &iter,
|
gtk_list_store_set (listStore, &iter,
|
||||||
0, visible, 1, curOption->data,
|
0, utfVisible, 1, curOption->data, -1);
|
||||||
-1);
|
g_free (utfVisible);
|
||||||
|
g_free (v1);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue