GTK Inspector¶
The GTK inspector is the built-in interactive debugging support in GTK.
The Inspector is extremely powerful, and allows designers and application developers to test CSS changes on-the-fly, magnify widgets to see even the smallest details, and check the structure of the UI and the properties of each object.
data:image/s3,"s3://crabby-images/2067c/2067c13c1845c4174c9657434f888511fc618ebc" alt="The main window of the GTK inspector"
data:image/s3,"s3://crabby-images/fad3e/fad3ec37166e24310a3bef1b1a79c0b7bb1fc3df" alt="The main window of the GTK inspector"
Enabling the GTK Inspector¶
To enable the GTK inspector, you can use the Control + Shift + I
or Control + Shift + D keyboard shortcuts, or set the
GTK_DEBUG=interactive
environment variable.
There are a few more environment variables that can be set to influence
how the inspector renders its UI. GTK_INSPECTOR_DISPLAY
and
GTK_INSPECTOR_RENDERER
determine the GDK display and the GSK
renderer that the inspector is using.
In some situations, it may be inappropriate to give users access to
the GTK inspector. The keyboard shortcuts can be disabled with the
enable-inspector-keybinding
key in the org.gtk.Settings.Debug
GSettings schema.
Objects¶
The main entry point of the Inspector is the Objects page:
data:image/s3,"s3://crabby-images/ffc59/ffc596e0b505fa75ad1d4e046066801e977c72e1" alt="The UI scene graph"
data:image/s3,"s3://crabby-images/5ad0b/5ad0baa2a3e88f3474a827889cdafd6366c13dfa" alt="The UI scene graph"
You can see the structure of the window, with each widget, its siblings and children, as well as ancillary objects like event controllers and layout managers.
Note
You can use the target icon to select a widget to inspect with your pointing device.
Once you select an object, you can inspect its type, state, builder id, reference count, geometry:
data:image/s3,"s3://crabby-images/9f4e7/9f4e7dda07ac5af8117f36aafdcbb22c863d464b" alt="The state of a widget"
data:image/s3,"s3://crabby-images/2e7b3/2e7b3c32931f80396ade19a7e161b6abf09089cb" alt="The state of a widget"
The object properties, with the ability to modify their value:
data:image/s3,"s3://crabby-images/5503a/5503a4e0e23ce6852418765944fdd06f77e08800" alt="The properties of a widget"
data:image/s3,"s3://crabby-images/6d70f/6d70f442f86415e67e6becd4eceddbc1c54cf4d5" alt="The properties of a widget"
The CSS properties for a widget, including the CSS selectors hierarchy:
data:image/s3,"s3://crabby-images/430a6/430a65c09941496dabc7016e6a962c5ea7d8cc96" alt="The CSS nodes of a widget"
data:image/s3,"s3://crabby-images/1bf3f/1bf3f7ab70c50958347238871115c95fe0316281" alt="The CSS nodes of a widget"
The actions installed by the object:
data:image/s3,"s3://crabby-images/5b246/5b246406e0c6aafa1256e9920f8625dde95f7b96" alt="The actions of a widget"
data:image/s3,"s3://crabby-images/5b771/5b771fd31d3fa5f6f97ac1309594c959664c6225" alt="The actions of a widget"
The event controllers used by the widget:
data:image/s3,"s3://crabby-images/36487/364871c3be7020b4fe85c3b9ffccf653bba4b0a0" alt="The event controllers of a widget"
data:image/s3,"s3://crabby-images/c2cdb/c2cdb8bb590420b5ccb6f4c2c8764631ddfb7b66" alt="The event controllers of a widget"
The accessibility role, attributes, and bounds:
data:image/s3,"s3://crabby-images/7fbfe/7fbfedc5067664dc84b9208e6d584ed85ddf95d0" alt="The accessibility information of a widget"
data:image/s3,"s3://crabby-images/42edc/42edc0ddaad816cfc2e2e239737de7dbf975bd2a" alt="The accessibility information of a widget"
You can also zoom the widget, with different levels of magnification, as a helpful tool to ensure that the rendering is accurate:
data:image/s3,"s3://crabby-images/1a051/1a05145f6a563dad3171e4e3ec38fc5d17ef70d9" alt="The widget magnifier"
data:image/s3,"s3://crabby-images/da0a2/da0a28e7453074b79a7ad0cf3e172e9395be32a4" alt="The widget magnifier"
Global¶
The Global page contains information related to the version and configuration of GTK:
data:image/s3,"s3://crabby-images/927f9/927f989a08449d8d5bf27e5736ab4b07b47fa720" alt="The Global page of the inspector"
data:image/s3,"s3://crabby-images/709c6/709c68ed2978f11bc348f04020d1158c31f212f8" alt="The Global page of the inspector"
You can also find the global state of your application, like its
application ID, or the resource path for
automatically loading GResource
bundles.
CSS¶
The CSS page allows you to load CSS rules, like new classes, and apply them instantenously. This page is useful for experimenting with styling and overrides.
data:image/s3,"s3://crabby-images/57d24/57d24e1fd1383596a4a6f184aea466848ffdcbdf" alt="The Global page of the inspector"
data:image/s3,"s3://crabby-images/0def9/0def9e572005bcb654d8318bdea2a3d527e56a3a" alt="The Global page of the inspector"
Recorder¶
The Recorder page allows you to record the rendering pipeline of a GTK application, and inspect the render nodes, their state, and their contents:
data:image/s3,"s3://crabby-images/1fc6e/1fc6ea8e74a2db7b6d20ce3ff1e35b5af158e871" alt="The Recorder page of the inspector"
data:image/s3,"s3://crabby-images/a4a43/a4a437256a5db809d3a45eaeee48ad425a852feb" alt="The Recorder page of the inspector"
Tip
The recording can be saved into a file, and used when reporting rendering bugs to GTK.
Extra pages¶
The GTK inspector is extensible through GIO extension points; applications can register their own inspector pages that GTK will add to the main inspector window.
Adwaita¶
Applications using libadwaita will automatically show an Adwaita page with additional settings and controls:
data:image/s3,"s3://crabby-images/9df10/9df10299e34b8000c43be3a70f1db9d7eb38a483" alt="The Adwaita page of the inspector"
data:image/s3,"s3://crabby-images/aa63d/aa63d258746472430278f48defbddb42eb41ab74" alt="The Adwaita page of the inspector"