aboutsummaryrefslogtreecommitdiffhomepage
path: root/site/dev/tools/qtdebugger.md
blob: bb3f97eba66d62c161997bca5c29ae56fa52038c (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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
Skia Debugger (deprecated)
=============

Introduction
------------

The Skia Debugger is a graphical tool used to step through and analyze the
contents of the Skia picture format. Pre-requisites include installing the Qt
Library and downloading the Skia code base.

Qt is available here: http://qt-project.org/downloads.

It can also be installed on linux using 

<!--?prettify?-->
~~~~
sudo apt-get install libqt4-dev
~~~~

Note that the debugger has been tested with Qt 4.8.6; it is known not to work
with Qt 5.0RC1 on the Mac.

Design Documents:

https://docs.google.com/a/google.com/document/d/1b8muqVzfbJmYbno9nTv5721V2nlFMfnqXYLNHiSQ4ws/pub


How to build and run
--------------------

Because the debugger uses Qt, you'll need to build skia in 64 bit mode:

<!--?prettify?-->

    GYP_DEFINES="skia_arch_width=64" python bin/sync-and-gyp
    ninja -C out/Debug debugger
    out/Debug/debugger

For Windows, Qt ships as 32 bit libraries so to build and run one should just be
able to:

<!--?prettify?-->
~~~~
cd trunk
make clean gyp
<open solution in VS2010 and build everything>
~~~~

Depending on how your Qt is installed you may also need to define an environment
variable like: 

~~~~
GYP_DEFINES=qt_sdk='C:\Qt\4.8.6\'
~~~~
(which needs to be set before you execute 'make gyp')

On Windows, you may need to copy several DLL and PDB files from %QTDIR%\bin into
your executable directory (out/Debug or out/Release):

QtCore4.dll QtCored4.dll QtCored4.pdb

QtGui4.dll QtGuid4.dll QtGuid4.pdb

QtOpenGL4.dll QtOpenGLd4.dll QtOpenGLd4.pdb 


Producing SKPs for usage
------------------------

You may either use the Skia testing images (GMs) for use in the debugger or
create your own via chromium.

To create SKPs from Chromium you must download and build chromium on your
platform of choice: http://www.chromium.org/Home

<!--?prettify?-->
~~~~
cd src
make chrome
out/Debug/chrome --no-sandbox --enable-gpu-benchmarking --force-compositing-mode
~~~~

After which go to Tools, Settings, Javascript Console and type:

<!--?prettify?-->
~~~~
chrome.gpuBenchmarking.printToSkPicture(dirname)
~~~~

Using the Debugger
------------------

The debugger is fairly straight forward to use once a picture is loaded in. We
can step through different commands via the up and down keys, and clicking on
the command in the list. We can pause execution of commands with the pause
button in order to inspect the details of the command in the inspector tabs
down below.

 
 Command      | Function
 -------------|-----------------------------------------------
 x            | toggles the visibility of the selected command
 alt-x        | clears all hidden commands
 ctrl-x       | shows all deleted commands
 b            | creates a breakpoint on a command
 alt-b        | clears all breakpoints
 ctrl-b       | shows all breakpoints
 ctrl-r       | rewinds the picture to the first command
 ctrl-p       | plays to the next breakpoint or last command
 ctrl-i       | Toggles the inspector and settings widgets
 ctrl-d       | Toggles the directory widget
 space        | Pauses drawing execution
 ctrl-o       | Opens a file dialog for loading pictures
 ctrl-s       | Saves the skp if you deleted any commands
 ctrl-shift-s | Saves the skp under the new specified name
 ctrl-q       | Quits

![Debugger interface](/dev/tools/debugger.png)