projects
/
pspp-builds.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge commit 'origin/stable'
[pspp-builds.git]
/
src
/
ui
/
gui
/
variable-info-dialog.c
diff --git
a/src/ui/gui/variable-info-dialog.c
b/src/ui/gui/variable-info-dialog.c
index 451b60bd6f841f2b378e9f704278ae1866afc242..178a834c7a0d8357c642997c649f81f9612488b6 100644
(file)
--- a/
src/ui/gui/variable-info-dialog.c
+++ b/
src/ui/gui/variable-info-dialog.c
@@
-1,5
+1,5
@@
/* PSPPIRE - a graphical user interface for PSPP.
/* PSPPIRE - a graphical user interface for PSPP.
- Copyright (C) 2007 Free Software Foundation
+ Copyright (C) 2007
, 2009
Free Software Foundation
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@
-16,19
+16,20
@@
#include <config.h>
#include <gtk/gtk.h>
#include <config.h>
#include <gtk/gtk.h>
-#include <glade/glade.h>
-#include "dict-display.h"
#include "var-display.h"
#include <data/variable.h>
#include "var-display.h"
#include <data/variable.h>
+#include <data/format.h>
#include <data/value-labels.h>
#include <data/value-labels.h>
-#include "
data-editor
.h"
+#include "
psppire-data-window
.h"
#include "psppire-dialog.h"
#include "psppire-var-store.h"
#include "psppire-dialog.h"
#include "psppire-var-store.h"
+#include "psppire-dictview.h"
#include "helper.h"
#include <language/syntax-string-source.h>
#include "helper.h"
#include <language/syntax-string-source.h>
-#include "syntax-editor.h"
+#include <libpspp/i18n.h>
+#include "helper.h"
#include <gettext.h>
#include <gettext.h>
@@
-36,58
+37,44
@@
#define N_(msgid) msgid
#define N_(msgid) msgid
-static struct variable *
-get_selected_variable (GtkTreeView *treeview)
-{
- struct variable *var;
- GtkTreeModel *top_model;
- GtkTreeIter top_iter;
-
- GtkTreeModel *model;
- GtkTreeIter iter;
+static const gchar none[] = N_("None");
- GtkTreeSelection *selection = gtk_tree_view_get_selection (treeview);
- if (! gtk_tree_selection_get_selected (selection,
- &top_model, &top_iter))
- {
- return NULL;
- }
-
- get_base_model (top_model, &top_iter, &model, &iter);
-
- g_assert (PSPPIRE_IS_DICT (model));
+static const gchar *
+label_to_string (const struct variable *var)
+{
+ const char *label = var_get_label (var);
- gtk_tree_model_get (model,
- &iter, DICT_TVM_COL_VAR, &var, -1);
+ if (NULL == label) return g_strdup (none);
- return
var
;
+ return
label
;
}
}
-
static void
static void
-populate_text (
GtkTree
View *treeview, gpointer data)
+populate_text (
PsppireDict
View *treeview, gpointer data)
{
gchar *text = 0;
GString *gstring;
{
gchar *text = 0;
GString *gstring;
+ PsppireDict *dict;
+
+ GtkTextBuffer *textbuffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (data));
+ const struct variable *var =
+ psppire_dict_view_get_selected_variable (treeview);
- GtkTextBuffer *textbuffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW(data));
- const struct variable *var = get_selected_variable (treeview);
if ( var == NULL)
return;
if ( var == NULL)
return;
+ g_object_get (treeview,
+ "dictionary", &dict,
+ NULL);
+
gstring = g_string_sized_new (200);
gstring = g_string_sized_new (200);
- text = name_to_string (var, NULL);
- g_string_assign (gstring, text);
- g_free (text);
+ g_string_assign (gstring, var_get_name (var));
g_string_append (gstring, "\n");
g_string_append (gstring, "\n");
- text = label_to_string (var, NULL);
- g_string_append_printf (gstring, _("Label: %s\n"), text);
- g_free (text);
-
+ g_string_append_printf (gstring, _("Label: %s\n"), label_to_string (var));
{
const struct fmt_spec *fmt = var_get_print_format (var);
char buffer[FMT_STRING_LEN_MAX + 1];
{
const struct fmt_spec *fmt = var_get_print_format (var);
char buffer[FMT_STRING_LEN_MAX + 1];
@@
-97,7
+84,7
@@
populate_text (GtkTreeView *treeview, gpointer data)
g_string_append_printf (gstring, _("Type: %s\n"), buffer);
}
g_string_append_printf (gstring, _("Type: %s\n"), buffer);
}
- text = missing_values_to_string (var, NULL);
+ text = missing_values_to_string (
dict,
var, NULL);
g_string_append_printf (gstring, _("Missing Values: %s\n"),
text);
g_free (text);
g_string_append_printf (gstring, _("Missing Values: %s\n"),
text);
g_free (text);
@@
-112,29
+99,27
@@
populate_text (GtkTreeView *treeview, gpointer data)
/* Value Labels */
if ( var_has_value_labels (var))
{
/* Value Labels */
if ( var_has_value_labels (var))
{
- struct val_labs_iterator *vli = 0;
- struct val_lab *vl;
- const struct val_labs *labs = var_get_value_labels (var);
+ const struct val_labs *vls = var_get_value_labels (var);
+ const struct val_lab **labels;
+ size_t n_labels;
+ size_t i;
g_string_append (gstring, "\n");
g_string_append (gstring, _("Value Labels:\n"));
g_string_append (gstring, "\n");
g_string_append (gstring, _("Value Labels:\n"));
-#if 1
-
for (vl = val_labs_first_sorted (labs, &vli
);
- vl;
- vl = val_labs_next (labs, &vli))
- {
+ labels = val_labs_sorted (vls);
+
n_labels = val_labs_count (vls
);
+ for (i = 0; i < n_labels; i++)
+ {
+ const struct val_lab *vl = labels[i];
gchar *const vstr =
gchar *const vstr =
- value_to_text (vl->value, *var_get_print_format (var));
+ value_to_text (vl->value,
dict,
*var_get_print_format (var));
-
text = pspp_locale_to_utf8 (vl->label, -1, NULL
);
+
g_string_append_printf (gstring, _("%s %s\n"), vstr, val_lab_get_label (vl)
);
- g_string_append_printf (gstring, _("%s %s\n"), vstr, text);
-
- g_free (text);
g_free (vstr);
}
g_free (vstr);
}
-#endif
+ free (labels);
}
gtk_text_buffer_set_text (textbuffer, gstring->str, gstring->len);
}
gtk_text_buffer_set_text (textbuffer, gstring->str, gstring->len);
@@
-157,17
+142,17
@@
treeview_item_selected (gpointer data)
}
}
-static gchar * generate_syntax (
GtkTree
View *treeview);
+static gchar * generate_syntax (
PsppireDict
View *treeview);
void
variable_info_dialog (GObject *o, gpointer data)
{
void
variable_info_dialog (GObject *o, gpointer data)
{
-
struct data_editor *de = data
;
+
PsppireDataWindow *de = PSPPIRE_DATA_WINDOW (data)
;
gint response ;
gint response ;
- G
ladeXML *xml = XML_NEW ("psppire.glade
");
+ G
tkBuilder *xml = builder_new ("variable-info-dialog.ui
");
GtkWidget *dialog = get_widget_assert (xml, "variable-info-dialog");
GtkWidget *treeview = get_widget_assert (xml, "treeview2");
GtkWidget *dialog = get_widget_assert (xml, "variable-info-dialog");
GtkWidget *treeview = get_widget_assert (xml, "treeview2");
@@
-177,13
+162,12
@@
variable_info_dialog (GObject *o, gpointer data)
g_object_get (de->data_editor, "var-store", &vs, NULL);
g_object_get (de->data_editor, "var-store", &vs, NULL);
- gtk_window_set_transient_for (GTK_WINDOW (dialog), de->parent.window);
-
- attach_dictionary_to_treeview (GTK_TREE_VIEW (treeview),
- vs->dict,
- GTK_SELECTION_SINGLE,
- NULL );
+ gtk_window_set_transient_for (GTK_WINDOW (dialog), GTK_WINDOW (de));
+ g_object_set (treeview,
+ "dictionary", vs->dict,
+ "selection-mode", GTK_SELECTION_SINGLE,
+ NULL);
g_signal_connect (treeview, "cursor-changed", G_CALLBACK (populate_text),
textview);
g_signal_connect (treeview, "cursor-changed", G_CALLBACK (populate_text),
textview);
@@
-201,23
+185,21
@@
variable_info_dialog (GObject *o, gpointer data)
case PSPPIRE_RESPONSE_GOTO:
{
const struct variable *var =
case PSPPIRE_RESPONSE_GOTO:
{
const struct variable *var =
-
get_selected_variable (GTK_TREE
_VIEW (treeview));
+
psppire_dict_view_get_selected_variable (PSPPIRE_DICT
_VIEW (treeview));
if ( NULL == var)
goto done;
if ( NULL == var)
goto done;
- g_object_set (de->data_editor, "current-variable", var_get_dict_index (var), NULL);
+ g_object_set (de->data_editor,
+ "current-variable", var_get_dict_index (var),
+ NULL);
}
break;
case PSPPIRE_RESPONSE_PASTE:
{
}
break;
case PSPPIRE_RESPONSE_PASTE:
{
- gchar *syntax = generate_syntax (GTK_TREE_VIEW (treeview));
-
- struct syntax_editor *se =
- (struct syntax_editor *) window_create (WINDOW_SYNTAX, NULL);
-
- gtk_text_buffer_insert_at_cursor (se->buffer, syntax, -1);
+ gchar *syntax = generate_syntax (PSPPIRE_DICT_VIEW (treeview));
+ paste_syntax_in_new_window (syntax);
g_free (syntax);
}
g_free (syntax);
}
@@
-231,9
+213,10
@@
variable_info_dialog (GObject *o, gpointer data)
}
static gchar *
}
static gchar *
-generate_syntax (
GtkTree
View *treeview)
+generate_syntax (
PsppireDict
View *treeview)
{
{
- const struct variable *var = get_selected_variable (treeview);
+ const struct variable *var =
+ psppire_dict_view_get_selected_variable (treeview);
if ( NULL == var)
return g_strdup ("");
if ( NULL == var)
return g_strdup ("");