[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v2] gui: Add undocumented --measure-startup option.
From: |
John Darrington |
Subject: |
Re: [PATCH v2] gui: Add undocumented --measure-startup option. |
Date: |
Sat, 21 Apr 2012 06:45:41 +0000 |
User-agent: |
Mutt/1.5.18 (2008-05-17) |
This looks a lot better.
I haven't tried it.
J'
On Fri, Apr 20, 2012 at 10:03:57PM -0700, Ben Pfaff wrote:
This is useful for testing the effects of code changes upon the
time required to start PSPPIRE.
---
v1->v2: Don't make the splash screen disappear more quickly on fast
machines.
src/ui/gui/main.c | 37 +++++++++++++++++++++++++++++++++++--
1 files changed, 35 insertions(+), 2 deletions(-)
diff --git a/src/ui/gui/main.c b/src/ui/gui/main.c
index bb8f19d..54f9056 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)
{
@@ -138,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 ();
}
@@ -177,6 +188,16 @@ 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)
@@ -200,6 +221,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 ();
@@ -250,9 +280,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) )
{
--
1.7.2.5
_______________________________________________
pspp-dev mailing list
address@hidden
https://lists.gnu.org/mailman/listinfo/pspp-dev
--
PGP Public key ID: 1024D/2DE827B3
fingerprint = 8797 A26D 0854 2EAB 0285 A290 8A67 719C 2DE8 27B3
See http://keys.gnupg.net or any PGP keyserver for public key.
signature.asc
Description: Digital signature