projects
/
pspp
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
psppire-data-sheet: Implement Edit|Paste.
[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 1b85a53665e7817abfd169d61be3a84ee677b735..282f41636883c21315d1f21d6ed08cfa1903a922 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, 2012 Free Software Foundation
+ Copyright (C) 2007, 201
1, 201
2 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
@@
-24,36
+24,36
@@
static void
static void
-refresh (
const PsppireDataWindow *de
, GtkBuilder *xml)
+refresh (
PsppireDataSheet *ds
, GtkBuilder *xml)
{
{
- PsppireDataStore *d
s = NULL
;
+ PsppireDataStore *d
ata_store = psppire_data_sheet_get_data_store (ds)
;
casenumber case_count ;
GtkWidget *case_num_entry = get_widget_assert (xml, "goto-case-case-num-entry");
casenumber case_count ;
GtkWidget *case_num_entry = get_widget_assert (xml, "goto-case-case-num-entry");
- g_object_get (de->data_editor, "data-store", &ds, NULL);
-
- case_count = psppire_data_store_get_case_count (ds);
+ case_count = psppire_data_store_get_case_count (data_store);
gtk_spin_button_set_range (GTK_SPIN_BUTTON (case_num_entry), 1, case_count);
}
void
gtk_spin_button_set_range (GTK_SPIN_BUTTON (case_num_entry), 1, case_count);
}
void
-goto_case_dialog (PsppireData
Window *de
)
+goto_case_dialog (PsppireData
Sheet *ds
)
{
{
+ GtkWindow *top_level;
gint response;
GtkBuilder *xml = builder_new ("goto-case.ui");
gint response;
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");
- gtk_window_set_transient_for (GTK_WINDOW (dialog), GTK_WINDOW (de));
+ top_level = GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (ds)));
+ gtk_window_set_transient_for (GTK_WINDOW (dialog), top_level);
- refresh (d
e
, xml);
+ refresh (d
s
, xml);
response = psppire_dialog_run (PSPPIRE_DIALOG (dialog));
if ( response == PSPPIRE_RESPONSE_GOTO )
{
response = psppire_dialog_run (PSPPIRE_DIALOG (dialog));
if ( response == PSPPIRE_RESPONSE_GOTO )
{
+ PsppireDataStore *data_store = psppire_data_sheet_get_data_store (ds);
glong case_num;
GtkWidget *case_num_entry =
get_widget_assert (xml, "goto-case-case-num-entry");
glong case_num;
GtkWidget *case_num_entry =
get_widget_assert (xml, "goto-case-case-num-entry");
@@
-61,6
+61,8
@@
goto_case_dialog (PsppireDataWindow *de)
case_num = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (case_num_entry))
- FIRST_CASE_NUMBER ;
case_num = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (case_num_entry))
- FIRST_CASE_NUMBER ;
- g_object_set (de->data_editor, "current-case", case_num, NULL);
+ if (case_num >= 0
+ && case_num < psppire_data_store_get_case_count (data_store))
+ psppire_data_sheet_goto_case (ds, case_num);
}
}
}
}