Details
-
Bug
-
Resolution: Done
-
Not Evaluated
-
Qt Creator 4.15.0-beta1
-
None
-
Debian testing, Qt Creator built from master branch (as of commit 9e2c6fbfca99b8a1e2eccbe76a0715a2070cbf4c), GDB 10.1-1.7
-
-
fd9ca07a11b1fd24cac58f1c7629e05ca8441614
Description
GDB system pretty printers don't work if they are declared in autoloaded Python scripts and the objfiles are loaded dynamically. An example to reproduce is this scenario including the rr debugger.
Steps to reproduce:
- in GDB settings ("Tools" -> "Options" -> "Debugger" -> "GDB", set these settings:
- enable "Load system GDB pretty printers"
- set these additional startup commands:
set auto-load safe-path / set sysroot / set solib-search-path /tmp/gdb-pretty-printer-objfile-sample/
- extract the attached sample project "gdb-pretty-printer-objfile-sample.zip" into /tmp/ and change into the directory /tmp/gdb-pretty-printer-objfile-sample
- build using bear, so that a compile_commands.json is created:
bear -- make
- record a run of the test program using rr
rr record ./test
- replay using rr (providing debugging server to connect to later):
-
rr replay -s 50505 -k
- load the project into Qt Creator using the compile_commands.json file created in step 3 (experimental CompilationDatabaseProjectManager" plugin must be enabled)
- set breakpoint in line 5 of py-autoloaded-pretty-printers-in-newobjfile-event-main.cc (return statement)
- start debugging by connecting to the debugging server provided by rr/gdb (s. step 5):
- "Debug" -> "Start debugging" -> "Attach to running debug server"
- in the dialog, make sure that these are set:
- Server port: 50505
- executable: /tmp/gdb-pretty-printer-objfile-sample/test
- press OK
- check how value for variable "test" is displayed in the locals view when reaching the breakpoint
Actual result: just a pointer value is shown
Expected result: The value as printed by the pretty-printed should be used, as is the case when directly running the program in GDB (i.e. not with rr and the debug server) or when using plain GDB instead of Qt Creator: "MyClassTestLib object, id: 1"
Plain GDB:
(gdb) p test
$1 = "MyClassTestLib object, id: 1"
Further information: I have analyzed this a bit, will add more information in follow-up comments.
Attachments
For Gerrit Dashboard: QTCREATORBUG-25339 | ||||||
---|---|---|---|---|---|---|
# | Subject | Branch | Project | Status | CR | V |
333857,4 | Debugger: Import GDB pretty printers for new objfiles | master | qt-creator/qt-creator | Status: MERGED | +2 | 0 |