pspp-dev
[Top][All Lists]
Advanced

[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.

Attachment: signature.asc
Description: Digital signature


reply via email to

[Prev in Thread] Current Thread [Next in Thread]