Logo Search packages:      
Sourcecode: inkscape version File versions

gdk-event-latency-tracker.h

/*
 * Inkscape::Debug::GdkEventLatencyTracker - tracks backlog of GDK events
 *
 * Authors:
 *   MenTaLguY <mental@rydia.net>
 *
 * Copyright (C) 2008 MenTaLguY
 *
 * Released under GNU GPL, read the file 'COPYING' for more information
 */

#ifndef SEEN_INKSCAPE_DEBUG_GDK_EVENT_LATENCY_TRACKER_H
#define SEEN_INKSCAPE_DEBUG_GDK_EVENT_LATENCY_TRACKER_H

#include <gdk/gdkevents.h>
#include <glibmm/timer.h>
#include <boost/optional.hpp>

namespace Inkscape {
namespace Debug {

class GdkEventLatencyTracker {
public:
    GdkEventLatencyTracker();
    boost::optional<double> process(GdkEvent const *e);
    double maxLatency() const { return max_latency; }
    double getSkew();

    static GdkEventLatencyTracker &default_tracker();

private:
    GdkEventLatencyTracker(GdkEventLatencyTracker const &); // no copy
    void operator=(GdkEventLatencyTracker const &); // no assign

    double start_seconds;
    double max_latency;
    double skew;
    double last_elapsed;
    double last_seconds;
    Glib::Timer elapsed;
};

}
}

#endif
/*
  Local Variables:
  mode:c++
  c-file-style:"stroustrup"
  c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +))
  indent-tabs-mode:nil
  fill-column:99
  End:
*/
// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=99 :

Generated by  Doxygen 1.6.0   Back to index