Add clang-tidy documentation
Add documentation for how to use clang-tidy in chromium. BUG=None Review-Url: https://codereview.chromium.org/2139883002 Cr-Commit-Position: refs/heads/master@{#404872}
This commit is contained in:

committed by
Commit bot

parent
13628d49e1
commit
be2898eb2f
108
docs/clang_tidy.md
Normal file
108
docs/clang_tidy.md
Normal file
@ -0,0 +1,108 @@
|
||||
# Clang Tidy
|
||||
|
||||
[TOC]
|
||||
|
||||
## Danger, Will Robinson!
|
||||
|
||||
Support for `clang-tidy` in Chromium is very experimental, and is somewhat
|
||||
painful to use. We are exploring making it easier and integrating with existing
|
||||
tools, but aren't there yet. If you don't want to wait and enjoy tinkering,
|
||||
forge ahead. Otherwise, feel free to turn back now.
|
||||
|
||||
## Introduction
|
||||
|
||||
[clang-tidy](http://clang.llvm.org/extra/clang-tidy/) is a clang-based C++
|
||||
“linter” tool. Its purpose is to provide an extensible framework for diagnosing
|
||||
and fixing typical programming errors, like style violations, interface misuse,
|
||||
or bugs that can be deduced via static analysis.
|
||||
|
||||
## Setting Up
|
||||
|
||||
In addition to a full Chromium checkout, you need the clang-tidy binary. We
|
||||
recommend checking llvm's clang source and building the clang-tidy binary
|
||||
directly. Instructions for getting started with clang are available from
|
||||
[llvm](http://clang.llvm.org/get_started.html). You'll need to get llvm,
|
||||
clang, and the extra clang tools (you won't need Compiler-RT or libcxx).
|
||||
If you don't have it, you'll also need to install cmake as a part of this
|
||||
process.
|
||||
|
||||
Instead of building with `"Unix Makefiles"`, generate build files for Ninja with
|
||||
```
|
||||
cmake -GNinja ../llvm
|
||||
```
|
||||
|
||||
Then, instead of using `make`, use ninja to build the clang-tidy binary with
|
||||
```
|
||||
ninja clang-tidy
|
||||
```
|
||||
|
||||
This binary will be at (build)/bin/clang-tidy.
|
||||
|
||||
If you intend to use the `fix` feature of clang-tidy, you'll also need to build
|
||||
the `clang-apply-replacements` binary.
|
||||
```
|
||||
ninja clang-apply-replacements
|
||||
```
|
||||
|
||||
## Running clang-tidy
|
||||
|
||||
Running clang-tidy is (hopefully) simple.
|
||||
1. Build chrome normally.\*
|
||||
```
|
||||
ninja -C out/Release chrome
|
||||
```
|
||||
2. Generate the compilation database
|
||||
```
|
||||
ninja -C out/Release -t compdb objcxx cxx > compile_commands.json
|
||||
```
|
||||
3. Enter the build directory.
|
||||
```
|
||||
cd out/Release
|
||||
```
|
||||
4. Run clang-tidy.
|
||||
```
|
||||
<PATH_TO_LLVM_SRC>/tools/clang/tools/extra/clang-tidy/tools/run-clang-tidy.py \
|
||||
-p ../.. \# Set the root project directory, where compile_commands.json is.
|
||||
# Set the clang-tidy binary path, if it's not in your $PATH.
|
||||
-clang-tidy-binary <PATH_TO_LLVM_BUILD>/bin/clang-tidy \
|
||||
# Set the clang-apply-replacements binary path, if it's not in your $PATH
|
||||
# and you are using the `fix` behavior of clang-tidy.
|
||||
-clang-apply-replacements-binary \
|
||||
<PATH_TO_LLVM_BUILD>/bin/clang-apply-replacements \
|
||||
# The checks to employ in the build. Use `-*` to omit default checks.
|
||||
-checks=<CHECKS> \
|
||||
-header-filter=<FILTER> \# Optional, limit results to only certain files.
|
||||
-fix \# Optional, used if you want to have clang-tidy auto-fix errors.
|
||||
chrome/browser # The path to the files you want to check.
|
||||
|
||||
Copy-Paste Friendly (though you'll still need to stub in the variables):
|
||||
<PATH_TO_LLVM_SRC>/tools/clang/tools/extra/clang-tidy/tools/run-clang-tidy.py \
|
||||
-p ../.. \
|
||||
-clang-tidy-binary <PATH_TO_LLVM_BUILD>/bin/clang-tidy \
|
||||
-clang-apply-replacements-binary \
|
||||
<PATH_TO_LLVM_BUILD>/bin/clang-apply-replacements \
|
||||
-checks=<CHECKS> \
|
||||
-header-filter=<FILTER> \
|
||||
-fix \
|
||||
chrome/browser
|
||||
```
|
||||
|
||||
\*It's not clear which, if any, `gn` flags may cause issues for `clang-tidy`.
|
||||
I've had no problems building a component release build, both with and without
|
||||
goma. if you run into issues, let us know!
|
||||
|
||||
## Troubleshooting
|
||||
|
||||
If you see errors like
|
||||
```
|
||||
src/build/linux/debian_wheezy_amd64-sysroot/usr/include/wchar.h:40:11: error: 'stdarg.h' file not found [clang-diagnostic-error]
|
||||
```
|
||||
|
||||
then you should also build the `clang-headers` target in your llvm checkout.
|
||||
This is fixed by http://reviews.llvm.org/D22046, so if your llvm checkout is
|
||||
up-to-date, this shouldn't be needed.
|
||||
|
||||
## Questions
|
||||
|
||||
Questions? Reach out to rdevlin.cronin@chromium.org or thakis@chromium.org.
|
||||
Discoveries? Update the doc!
|
Reference in New Issue
Block a user