return TRUE;
}
-\f
+\f
gboolean
init_prepare (GSource * source, gint * timeout_)
on_local_options (GApplication * application,
GVariantDict * options, gpointer user_data)
{
- GVariant *b;
-
- b =
- g_variant_dict_lookup_value (options, "no-splash",
- G_VARIANT_TYPE_BOOLEAN);
- if (b)
- {
+ {
+ GVariant *b =
+ g_variant_dict_lookup_value (options, "no-unique",
+ G_VARIANT_TYPE_BOOLEAN);
+ if (b)
+ {
+ GApplicationFlags flags = g_application_get_flags (application);
+ flags |= G_APPLICATION_NON_UNIQUE;
+ g_application_set_flags (application, flags);
+ g_variant_unref (b);
+ }
+ }
+ {
+ GVariant *b =
+ g_variant_dict_lookup_value (options, "no-splash",
+ G_VARIANT_TYPE_BOOLEAN);
+ if (b)
g_variant_unref (b);
- }
- else
- {
+ else
start_time = g_get_monotonic_time ();
- }
+ }
+
return -1;
}
return G_SOURCE_REMOVE;
}
+
static void
-on_activate (GApplication * app, gpointer ud)
+wait_for_splash (GApplication *app, GtkWindow *x)
{
- post_initialise (app);
-
- GtkWindow *x = create_data_window ();
if (wsplash)
{
- gtk_window_set_transient_for (GTK_WINDOW (wsplash), GTK_WINDOW (x));
- gtk_application_add_window (GTK_APPLICATION (app), x);
+ gtk_window_set_transient_for (GTK_WINDOW (wsplash), x);
gtk_application_add_window (GTK_APPLICATION (app), GTK_WINDOW (wsplash));
gtk_window_set_keep_above (GTK_WINDOW (wsplash), TRUE);
gtk_window_present (GTK_WINDOW (wsplash));
static void
-on_open (GApplication * app, GFile ** files, gint n_files, gchar * hint,
+on_activate (GApplication * app, gpointer ud)
+{
+ post_initialise (app);
+
+ GtkWindow *x = create_data_window ();
+ gtk_application_add_window (GTK_APPLICATION (app), x);
+
+ wait_for_splash (app, x);
+}
+
+
+static void
+on_open (GApplication *app, GFile **files, gint n_files, gchar * hint,
gpointer ud)
{
post_initialise (app);
gchar *file = g_file_get_parse_name (files[0]);
- psppire_preload_file (file);
+ GtkWindow *x = psppire_preload_file (file);
g_free (file);
+
+ wait_for_splash (app, x);
}
{
GOptionEntry oe[] = {
{"version", 'V', G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
- show_version_and_exit, "Show version information and exit", 0},
+ show_version_and_exit, N_("Show version information and exit"), 0},
{NULL}
};
int
main (int argc, char *argv[])
{
+ set_program_name (argv[0]);
+
GtkApplication *app =
gtk_application_new ("gnu.pspp", G_APPLICATION_HANDLES_OPEN);
GOptionEntry oe[] = {
{"no-splash", 'q', G_OPTION_FLAG_NONE, G_OPTION_ARG_NONE, NULL,
- "Do not display the splash screen", 0},
+ N_("Do not display the splash screen"), 0},
+ {"no-unique", 'n', G_OPTION_FLAG_NONE, G_OPTION_ARG_NONE, NULL,
+ N_("Do not attempt single instance negotiation"), 0},
{NULL}
};