# Use Qt Creator as an IDE or debugger UI [Qt Creator](https://www.qt.io/ide/) ([Wiki](https://en.wikipedia.org/wiki/Qt_Creator)) is a cross-platform C++ IDE. You can use Qt Creator as a daily IDE or just as a GDB frontend (which does not require project configuration). [TOC] ## IDE ### Workflow features * Built-in code completion. * Navigate to classes, files, or symbols with `ctrl+k`. * Switch between declaration and definition with `F2`. * Build with `ctrl+shift+b`. * Build and run with `ctrl+r`, or debug with `F5`. * Switch between the header file and cpp file with `F4`. ### Setup 1. Install the latest Qt Creator. 2. Under chromium/src `gn gen out/Default --ide=qtcreator`. 3. Start it with `qtcreator out/Default/qtcreator_project/all.creator`. 4. Help - Plugins - check ClangCodeModel to enable std completion. It takes 3 minutes to parse all of chrome's C++ files on my workstation!!! And it does not block while parsing. #### Code Style 1. Help - About Plugins, enable Beautifier. 2. Tools - Options - Beautifier - Clang Format, change the Clang format command to: `$depot_tools_dir/clang-format`, and set `Use predefined style: file`. You can also set a keyboard shortcut for it. 3. Tools - Options - Code Style, import this xml file. ``` CodeStyleData true false false false false true true true true false false false true false false true false false false 2 true false 2 true true 2 DisplayName chrome ``` #### Build & Run 1. (Optional) Enable the issues pane for easy navigation to the location of compiler errors. qtcreator expects to find compiler errors on stderr, but ninja forwards all subcommand output to stdout. So use the following wrapper script to forward it to stderr instead. ``` #!/bin/sh /path/to/depot_tools/ninja "$@" >&2 ``` 2. In the left panel - Projects, set up the ninja command in the build and clean steps, and add the path to chrome in the run configuration. ## Debugger **You can skip the project settings and use QtCreator as a single file standalone GDB frontend.** 1. Tools - Options - Build & Run - Debuggers, make sure GDB is set. 2. Tools - Options - Kits, change the Desktop kit to GDB (LLDB doesn't work on Linux). 3. Open the file you want to debug. 4. Debug - Start Debugging - Attach to running Application, you may need to open chrome's task manager to find the process id. ### Tips, tricks, and troubleshooting #### The debugger exits immediately Ensure yama allows you to attach to another process: ``` $ echo 0 | sudo tee /proc/sys/kernel/yama/ptrace_scope ``` #### The debugger does not stop on breakpoints Ensure you are using GDB on Linux, not LLDB. #### More See https://chromium.googlesource.com/chromium/src/+/master/docs/linux_debugging.md