X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fpsppire-var-view.c;h=e47b7b61e8d84dc37ef291cac4d3700fc7cc2f8d;hb=c1945b7547f9f7b96dcd90f884a396fdd0018b3b;hp=c71a5e66103e2821814972461c12b46e1de0aa5a;hpb=7fbadad9d6d9cad8805cafdd9ea157e753029ea0;p=pspp diff --git a/src/ui/gui/psppire-var-view.c b/src/ui/gui/psppire-var-view.c index c71a5e6610..e47b7b61e8 100644 --- a/src/ui/gui/psppire-var-view.c +++ b/src/ui/gui/psppire-var-view.c @@ -21,6 +21,7 @@ #include "psppire-var-ptr.h" #include "psppire-select-dest.h" +#include #include #include @@ -101,33 +102,20 @@ psppire_var_view_get_type (void) return psppire_var_view_type; } -void +void psppire_var_view_clear (PsppireVarView *vv) { - gint i; - for (i = 0; i < vv->n_lists; ++i) - g_object_unref (vv->list[i]); - - g_free (vv->list); + GtkListStore *l = gtk_list_store_newv (vv->n_cols, vv->cols); - vv->n_lists = 0; - vv->l_idx = -1; - vv->list = NULL; - - psppire_var_view_push_model (vv); + gtk_tree_view_set_model (GTK_TREE_VIEW (vv), GTK_TREE_MODEL (l)); } static void psppire_var_view_finalize (GObject *object) { - gint i; PsppireVarView *var_view = PSPPIRE_VAR_VIEW (object); g_free (var_view->nums); - for (i = 0; i < var_view->n_lists; ++i) - g_object_unref (var_view->list[i]); - - g_free (var_view->list); g_free (var_view->cols); } @@ -193,58 +181,37 @@ set_renderers (PsppireVarView *var_view) { gint c; var_view->nums = g_malloc (sizeof *var_view->nums * var_view->n_cols); - + for (c = 0 ; c < var_view->n_cols; ++c) { GtkCellRenderer *renderer = gtk_cell_renderer_text_new (); GtkTreeViewColumn *col = gtk_tree_view_column_new (); - + gchar *label = g_strdup_printf (_("Var%d"), c + 1); - + gtk_tree_view_column_set_min_width (col, 100); gtk_tree_view_column_set_sizing (col, GTK_TREE_VIEW_COLUMN_FIXED); gtk_tree_view_column_set_resizable (col, TRUE); gtk_tree_view_column_set_title (col, label); - + g_free (label); - + var_view->nums[c] = c; - + gtk_tree_view_column_pack_start (col, renderer, TRUE); gtk_tree_view_column_set_cell_data_func (col, renderer, display_cell_var_name, &var_view->nums[c], 0); - + gtk_tree_view_append_column (GTK_TREE_VIEW (var_view), col); } } - - -/* Set a model, which is an GtkListStore of gpointers which point to a variable */ -void -psppire_var_view_push_model (PsppireVarView *vv) -{ - vv->n_lists++; - vv->l_idx++; - vv->list = xrealloc (vv->list, sizeof (*vv->list) * vv->n_lists); - vv->list[vv->l_idx] = gtk_list_store_newv (vv->n_cols, vv->cols); - g_object_ref (vv->list[vv->l_idx]); - gtk_tree_view_set_model (GTK_TREE_VIEW (vv), GTK_TREE_MODEL (vv->list[vv->l_idx])); -} - -gboolean -psppire_var_view_set_current_model (PsppireVarView *vv, gint n) +GtkTreeModel * +psppire_var_view_get_current_model (PsppireVarView *vv) { - if (n < 0 || n >= vv->n_lists) - return FALSE; - - vv->l_idx = n; - - gtk_tree_view_set_model (GTK_TREE_VIEW (vv), GTK_TREE_MODEL (vv->list[vv->l_idx])); - - return TRUE; + return gtk_tree_view_get_model (GTK_TREE_VIEW (vv)); } static void @@ -307,8 +274,6 @@ psppire_var_view_base_init (PsppireVarViewClass *class) GObjectClass *object_class = G_OBJECT_CLASS (class); - - object_class->finalize = psppire_var_view_finalize; } @@ -325,10 +290,10 @@ psppire_var_view_base_finalize (PsppireVarViewClass *class, static void psppire_var_view_init (PsppireVarView *vv) { + GtkTreeSelection* selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (vv)); vv->cols = 0; - vv->n_lists = 0; - vv->l_idx = -1; - vv->list = NULL; + + gtk_tree_selection_set_mode (selection, GTK_SELECTION_MULTIPLE); } @@ -343,27 +308,23 @@ gboolean psppire_var_view_get_iter_first (PsppireVarView *vv, GtkTreeIter *iter) { GtkTreeIter dummy; - if ( vv->l_idx < 0) - return FALSE; - - return gtk_tree_model_get_iter_first (GTK_TREE_MODEL (vv->list[vv->l_idx]), iter ? iter : &dummy); + GtkTreeModel *model = gtk_tree_view_get_model (GTK_TREE_VIEW (vv)); + return gtk_tree_model_get_iter_first (model, iter ? iter : &dummy); } gboolean psppire_var_view_get_iter_next (PsppireVarView *vv, GtkTreeIter *iter) { - if ( vv->l_idx < 0) - return FALSE; - - return gtk_tree_model_iter_next (GTK_TREE_MODEL (vv->list[vv->l_idx]), iter); + GtkTreeModel *model = gtk_tree_view_get_model (GTK_TREE_VIEW (vv)); + return gtk_tree_model_iter_next (model, iter); } const struct variable * -psppire_var_view_get_variable (PsppireVarView *vv, gint column, GtkTreeIter *iter) +psppire_var_view_get_var_from_model (GtkTreeModel *model, gint column, GtkTreeIter *iter) { const struct variable *var = NULL; GValue value = {0}; - gtk_tree_model_get_value (GTK_TREE_MODEL (vv->list[vv->l_idx]), iter, column, &value); + gtk_tree_model_get_value (model, iter, column, &value); if ( G_VALUE_TYPE (&value) == PSPPIRE_VAR_PTR_TYPE) var = g_value_get_boxed (&value); @@ -376,6 +337,15 @@ psppire_var_view_get_variable (PsppireVarView *vv, gint column, GtkTreeIter *ite return var; } +const struct variable * +psppire_var_view_get_variable (PsppireVarView *vv, gint column, GtkTreeIter *iter) +{ + GtkTreeModel *model = gtk_tree_view_get_model (GTK_TREE_VIEW (vv)); + return psppire_var_view_get_var_from_model (model, column, iter); +} + + + /* Append the names of selected variables to STRING. Returns the number of variables appended. @@ -402,12 +372,37 @@ psppire_var_view_append_names (PsppireVarView *vv, gint column, GString *string) return n_vars; } +/* Return a linked list of struct variables which are + contained in VV. + The caller is responsible for freeing the returned list. + The variables however are owned by their dictionary + and should not be freed. + */ +GSList * +psppire_var_view_list_names (PsppireVarView *vv, gint column) +{ + GtkTreeIter iter; + GSList *list = NULL; + + if ( psppire_var_view_get_iter_first (vv, &iter) ) + { + do + { + const struct variable *var = psppire_var_view_get_variable (vv, column, &iter); + list = g_slist_prepend (list, CONST_CAST (struct variable *, var)); + } + while (psppire_var_view_get_iter_next (vv, &iter)); + } + + return list; +} + /* Append the names of selected variables to STR Returns the number of variables appended. */ -gint +gint psppire_var_view_append_names_str (PsppireVarView *vv, gint column, struct string *str) { gint n_vars = 0;