Code

Merging from trunk
[inkscape.git] / src / debug / gdk-event-latency-tracker.cpp
1 /*
2  * Inkscape::Debug::GdkEventLatencyTracker - tracks backlog of GDK events
3  *
4  * Authors:
5  *   MenTaLguY <mental@rydia.net>
6  *
7  * Copyright (C) 2008 MenTaLguY
8  *
9  * Released under GNU GPL, read the file 'COPYING' for more information
10  */
12 #include "debug/gdk-event-latency-tracker.h"
13 #include "prefs-utils.h"
15 namespace Inkscape {
16 namespace Debug {
18 GdkEventLatencyTracker::GdkEventLatencyTracker()
19     : start_seconds(0.0), max_latency(0.0), skew(1.0), last_elapsed(0.0), last_seconds(0.0)
20 {
21     elapsed.stop();
22     elapsed.reset();
23 }
25 boost::optional<double> GdkEventLatencyTracker::process(GdkEvent const *event) {
26     guint32 const timestamp=gdk_event_get_time(const_cast<GdkEvent *>(event));
27     if (timestamp == GDK_CURRENT_TIME) {
28         return boost::optional<double>();
29     }
30     double const timestamp_seconds = timestamp / 1000.0;
32     if (start_seconds == 0.0) {
33         elapsed.start();
34         start_seconds = timestamp_seconds;
35         skew = prefs_get_double_attribute_limited("debug.latency", "skew", 1.0, 0.5, 2.0);
36         return boost::optional<double>(0.0);
37     } else {
38         last_elapsed = elapsed.elapsed();
39         last_seconds = timestamp_seconds;
40         double const current_seconds = (last_elapsed * skew) + start_seconds;
41         double delta = current_seconds - timestamp_seconds;
42         if (delta < 0.0) {
43             start_seconds += -delta;
44             delta = 0.0;
45         } else if (delta > max_latency) {
46             max_latency = delta;
47         }
48         return boost::optional<double>(delta);
49     }
50 }
52 double GdkEventLatencyTracker::getSkew() {
53     double val = 0.0;
54     if ((last_elapsed > 0.0) && (last_seconds > 0.0)) {
55         val = (last_seconds - start_seconds) / last_elapsed;
56     }
57     return val;
58 }
60 GdkEventLatencyTracker &GdkEventLatencyTracker::default_tracker() {
61     static GdkEventLatencyTracker tracker;
62     return tracker;
63 }
65 }
66 }
68 /*
69   Local Variables:
70   mode:c++
71   c-file-style:"stroustrup"
72   c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +))
73   indent-tabs-mode:nil
74   fill-column:99
75   End:
76 */
77 // vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=99 :