diff options
| author | MenTaLguY <mental@rydia.net> | 2008-07-08 19:16:01 +0000 |
|---|---|---|
| committer | mental <mental@users.sourceforge.net> | 2008-07-08 19:16:01 +0000 |
| commit | 5621aed042ec29e9606b2bdce44a1f42f61c8e6b (patch) | |
| tree | bc37f3fce13514460ab4f87a9aaad8862beeced3 /src/display/sp-canvas.cpp | |
| parent | disable motion hints again; still some subtle issues to work out (diff) | |
| download | inkscape-5621aed042ec29e9606b2bdce44a1f42f61c8e6b.tar.gz inkscape-5621aed042ec29e9606b2bdce44a1f42f61c8e6b.zip | |
instrument event latency
(bzr r6231)
Diffstat (limited to 'src/display/sp-canvas.cpp')
| -rw-r--r-- | src/display/sp-canvas.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/display/sp-canvas.cpp b/src/display/sp-canvas.cpp index def126cd3..3d63d7cdd 100644 --- a/src/display/sp-canvas.cpp +++ b/src/display/sp-canvas.cpp @@ -43,6 +43,9 @@ #include "display/rendermode.h" #include "libnr/nr-blit.h" #include "display/inkscape-cairo.h" +#include "debug/gdk-event-latency-tracker.h" + +using Inkscape::Debug::GdkEventLatencyTracker; // GTK_CHECK_VERSION returns false on failure #define HAS_GDK_EVENT_REQUEST_MOTIONS GTK_CHECK_VERSION(2, 12, 0) @@ -102,6 +105,7 @@ enum {ITEM_EVENT, ITEM_LAST_SIGNAL}; static void sp_canvas_request_update (SPCanvas *canvas); +static void track_latency(GdkEvent const *event); static void sp_canvas_item_class_init (SPCanvasItemClass *klass); static void sp_canvas_item_init (SPCanvasItem *item); static void sp_canvas_item_dispose (GObject *object); @@ -1097,6 +1101,14 @@ sp_canvas_destroy (GtkObject *object) (* GTK_OBJECT_CLASS (canvas_parent_class)->destroy) (object); } +static void track_latency(GdkEvent const *event) { + GdkEventLatencyTracker &tracker = GdkEventLatencyTracker::default_tracker(); + boost::optional<double> latency = tracker.process(event); + if (latency && *latency > 2.0) { + g_warning("Event latency reached %f sec", *latency); + } +} + /** * Returns new canvas as widget. */ @@ -1564,6 +1576,8 @@ sp_canvas_motion (GtkWidget *widget, GdkEventMotion *event) int status; SPCanvas *canvas = SP_CANVAS (widget); + track_latency((GdkEvent *)event); + if (event->window != SP_CANVAS_WINDOW (canvas)) return FALSE; |
