projects
/
pspp
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Update identifiers to reflect new identity of upstream package
[pspp]
/
src
/
ui
/
gui
/
goto-case-dialog.c
diff --git
a/src/ui/gui/goto-case-dialog.c
b/src/ui/gui/goto-case-dialog.c
index 32e93dbd4ca37afe07f9bd14ebcf01953199ec27..1b5e39a45dfd204628a0f676df5baf1fd950254c 100644
(file)
--- a/
src/ui/gui/goto-case-dialog.c
+++ b/
src/ui/gui/goto-case-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
, 2011, 2012, 2016
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
@@
-15,69
+15,59
@@
along with this program. If not, see <http://www.gnu.org/licenses/>. */
along with this program. If not, see <http://www.gnu.org/licenses/>. */
+#include <config.h>
#include "goto-case-dialog.h"
#include "goto-case-dialog.h"
-#include "
hel
per.h"
+#include "
builder-wrap
per.h"
#include "psppire-dialog.h"
#include "psppire-dialog.h"
-#include "
data-editor
.h"
+#include "
psppire-data-window
.h"
#include "psppire-data-store.h"
#include "psppire-data-store.h"
-#include
<gtksheet/gtksheet.h>
+#include
"psppire-data-sheet.h"
static void
static void
-refresh (
const struct data_editor *de, GladeXML
*xml)
+refresh (
PsppireDataSheet *ds, GtkBuilder
*xml)
{
{
- GtkSheet *data_sheet =
-
GTK_SHEET (get_widget_assert (de->xml, "data_sheet")
);
+ PsppireDataStore *store = NULL;
+
g_object_get (ds, "data-model", &store, NULL
);
- PsppireDataStore *ds =
-
PSPPIRE_DATA_STORE (gtk_sheet_get_model (data_sheet)
);
+ GtkWidget *case_num_entry = get_widget_assert (xml, "goto-case-case-num-entry");
+
casenumber case_count = gtk_tree_model_iter_n_children (GTK_TREE_MODEL (store), NULL
);
- GtkWidget *case_num_entry =
- get_widget_assert (xml, "goto-case-case-num-entry");
-
- casenumber case_count =
- psppire_data_store_get_case_count (ds);
-
- gtk_spin_button_set_range (GTK_SPIN_BUTTON (case_num_entry),
- 1, case_count);
+ gtk_spin_button_set_range (GTK_SPIN_BUTTON (case_num_entry), 1, case_count);
}
void
}
void
-goto_case_dialog (
GObject *o, gpointer data
)
+goto_case_dialog (
PsppireDataSheet *ds
)
{
{
+ GtkWindow *top_level;
gint response;
gint response;
- GladeXML *xml = XML_NEW ("psppire.glade");
- struct data_editor *de = data;
-
+ GtkBuilder *xml = builder_new ("goto-case.ui");
GtkWidget *dialog = get_widget_assert (xml, "goto-case-dialog");
GtkWidget *dialog = get_widget_assert (xml, "goto-case-dialog");
+ top_level = GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (ds)));
+ gtk_window_set_transient_for (GTK_WINDOW (dialog), top_level);
- gtk_window_set_transient_for (GTK_WINDOW (dialog), de->parent.window);
-
- refresh (de, xml);
+ refresh (ds, xml);
response = psppire_dialog_run (PSPPIRE_DIALOG (dialog));
response = psppire_dialog_run (PSPPIRE_DIALOG (dialog));
- if (
response == PSPPIRE_RESPONSE_GOTO
)
+ if (
response == PSPPIRE_RESPONSE_GOTO
)
{
{
- gint row, column;
- GtkSheet *data_sheet =
- GTK_SHEET (get_widget_assert (de->xml, "data_sheet"));
-
+ PsppireDataStore *store = NULL;
+ g_object_get (ds, "data-model", &store, NULL);
GtkWidget *case_num_entry =
GtkWidget *case_num_entry =
- get_widget_assert (xml, "goto-case-case-num-entry");
-
- gtk_sheet_get_active_cell (data_sheet, &row, &column);
+ get_widget_assert (xml, "goto-case-case-num-entry");
-
row
=
+
glong case_num
=
gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (case_num_entry))
gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (case_num_entry))
- - FIRST_CASE_NUMBER ;
-
- gtk_sheet_moveto (data_sheet,
- row, column,
- 0.5, 0.5);
-
- gtk_sheet_set_active_cell (data_sheet, row, column);
+ - FIRST_CASE_NUMBER ;
+
+ if (case_num >= 0 &&
+ case_num < gtk_tree_model_iter_n_children (GTK_TREE_MODEL (ds), NULL))
+ {
+ ssw_sheet_scroll_to (ds, -1, case_num);
+ ssw_sheet_set_active_cell (ds, -1, case_num, 0);
+ }
}
}
}
}