X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fmain.c;h=ddc2a5b5fbbc29e6efa5585e7375a3b280e80b33;hb=5206c60ba8beaddccdf571db65709b38dbadb3fd;hp=cc5ebe3f644748d130bbe11450f3c5d021ae22f9;hpb=32ee0e0402d6d56674f53a47d879ec5c07dabe09;p=pspp diff --git a/src/ui/gui/main.c b/src/ui/gui/main.c index cc5ebe3f64..ddc2a5b5fb 100644 --- a/src/ui/gui/main.c +++ b/src/ui/gui/main.c @@ -1,5 +1,5 @@ /* PSPPIRE - a graphical user interface for PSPP. - Copyright (C) 2004, 2005, 2006, 2010, 2011 Free Software Foundation + Copyright (C) 2004, 2005, 2006, 2010, 2011, 2012 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 @@ -50,6 +50,7 @@ enum OPT_HELP, OPT_VERSION, OPT_NO_SPLASH, + OPT_MEASURE_STARTUP, N_STARTUP_OPTIONS }; @@ -57,9 +58,15 @@ static const struct argv_option startup_options[N_STARTUP_OPTIONS] = { {"help", 'h', no_argument, OPT_HELP}, {"version", 'V', no_argument, OPT_VERSION}, - {"no-splash", 'q', no_argument, OPT_NO_SPLASH} + {"no-splash", 'q', no_argument, OPT_NO_SPLASH}, + {"measure-startup", 0, no_argument, OPT_MEASURE_STARTUP}, }; +/* --measure-startup: Prints the elapsed time to start up and load any file + specified on the command line. */ +static gboolean measure_startup; +static GTimer *startup; + static void usage (void) { @@ -106,7 +113,8 @@ Informative output:\n\ -h, --help display this help and exit\n\ -V, --version output version information and exit\n\ \n\ -A non-option argument is interpreted as a .sav or .por file to load.\n"), +A non-option argument is interpreted as a .sav file, a .por file or a syntax\n\ +file to load.\n"), program_name, gtk_help, inc_path); free (inc_path); @@ -137,6 +145,10 @@ startup_option_callback (int id, void *show_splash_) *show_splash = FALSE; break; + case OPT_MEASURE_STARTUP: + measure_startup = TRUE; + break; + default: NOT_REACHED (); } @@ -176,13 +188,25 @@ hide_splash_window (gpointer data) return FALSE; } +static gboolean +print_startup_time (gpointer data) +{ + g_timer_stop (startup); + printf ("%.3f seconds elapsed\n", g_timer_elapsed (startup, NULL)); + g_timer_destroy (startup); + startup = NULL; + return FALSE; +} + +/* static gboolean quit_one_loop (gpointer data) { gtk_main_quit (); return FALSE; } +*/ struct initialisation_parameters { @@ -199,6 +223,15 @@ run_inner_loop (gpointer data) g_timeout_add (500, hide_splash_window, ip->splash_window); + if (measure_startup) + { + GSource *source = g_idle_source_new (); + g_source_set_priority (source, G_PRIORITY_LOW); + g_source_set_callback (source, print_startup_time, NULL, NULL); + g_source_attach (source, NULL); + g_source_unref (source); + } + gtk_main (); de_initialize (); @@ -218,25 +251,32 @@ static GMemVTable vtable = }; #ifdef __APPLE__ +static const bool apple = true; +#else +static const bool apple = false; +#endif + /* Searches ARGV for the -psn_xxxx option that the desktop application launcher passes in, and removes it if it finds it. Returns the new value of ARGC. */ -static int +static inline int remove_psn (int argc, char **argv) { - int i; - - for (i = 0; i < argc; i++) + if (apple) { - if (!strncmp(argv[i], "-psn", 4)) - { - remove_element (argv, argc + 1, sizeof *argv, i); - return argc - 1; - } + int i; + + for (i = 0; i < argc; i++) + { + if (!strncmp (argv[i], "-psn", 4)) + { + remove_element (argv, argc + 1, sizeof *argv, i); + return argc - 1; + } + } } return argc; } -#endif /* __APPLE__ */ int main (int argc, char *argv[]) @@ -249,9 +289,12 @@ main (int argc, char *argv[]) set_program_name (argv[0]); g_mem_set_vtable (&vtable); + g_thread_init (NULL); gtk_disable_setlocale (); + startup = g_timer_new (); + g_timer_start (startup); if ( ! gtk_parse_args (&argc, &argv) ) { @@ -266,9 +309,7 @@ main (int argc, char *argv[]) g_warning ("%s", vers); } -#ifdef __APPLE__ argc = remove_psn (argc, argv); -#endif /* Parse our own options. This must come BEFORE gdk_init otherwise options such as @@ -290,13 +331,14 @@ main (int argc, char *argv[]) init_p.splash_window = create_splash_window (); init_p.data_file = optind < argc ? argv[optind] : NULL; - if ( show_splash ) - gtk_widget_show (init_p.splash_window); + // if ( show_splash ) + // gtk_widget_show (init_p.splash_window); - g_idle_add (quit_one_loop, 0); + // g_idle_add (quit_one_loop, 0); - gtk_quit_add (0, run_inner_loop, &init_p); - gtk_main (); + // gtk_quit_add (0, run_inner_loop, &init_p); + run_inner_loop (&init_p); + // gtk_main (); return 0; }