summaryrefslogtreecommitdiffstats
path: root/pdb/groups/debug.pdb
blob: da1111085f0e1d26f91417ea88fd7536e2e6e28a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
# GIMP - The GNU Image Manipulation Program
# Copyright (C) 1995 Spencer Kimball and Peter Mattis

# 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
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.

# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.

# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <https://www.gnu.org/licenses/>.

# "Perlized" from C source by Manish Singh <yosh@gimp.org>

sub debug_timer_start {
    $blurb = 'Starts measuring elapsed time.';

    $help = <<'HELP';
This procedure starts a timer, measuring the elapsed time since the call.
Each call to this procedure should be matched by a call to
gimp_debug_timer_end(), which returns the elapsed time.

If there is already an active timer, it is not affected by the call, however, a
matching gimp_debug_timer_end() call is still required.
HELP

    &ell_pdb_misc('2017');

    &std_pdb_debug();

    %invoke = (
	code => <<'CODE'
{
  if (gimp_debug_timer_counter++ == 0)
    gimp_debug_timer = g_timer_new ();
}
CODE
    );
}

sub debug_timer_end {
    $blurb = 'Finishes measuring elapsed time.';

    $help = <<'HELP';
This procedure stops the timer started by a previous gimp_debug_timer_start()
call, and prints and returns the elapsed time.

If there was already an active timer at the time of corresponding call to
gimp_debug_timer_start(), a dummy value is returned.
HELP

    &ell_pdb_misc('2017');

    &std_pdb_debug();

    @outargs = (
        { name => 'elapsed', type => 'float',
          desc => 'The elapsed time, in seconds' }
    );


    %invoke = (
	code => <<'CODE'
{
  elapsed = 0.0;

  if (gimp_debug_timer_counter == 0)
    success = FALSE;
  else if (--gimp_debug_timer_counter == 0)
    {
      elapsed = g_timer_elapsed (gimp_debug_timer, NULL);

      g_printerr ("GIMP debug timer: %g seconds\n", elapsed);

      g_timer_destroy (gimp_debug_timer);

      gimp_debug_timer = NULL;
    }
}
CODE
    );
}


$extra{app}->{code} = <<'CODE';
static GTimer *gimp_debug_timer         = NULL;
static gint    gimp_debug_timer_counter = 0;
CODE


@procs = qw(debug_timer_start debug_timer_end);

%exports = (app => [@procs], lib => [@procs]);

$desc = 'Debug';
$doc_title = 'gimpdebug';
$doc_short_desc = 'Debug utility functions';
$doc_long_desc = 'Miscellaneous debug utility functions. Not part of the stable library interface.';

1;