如何用clang analyzer定制静态分析规则(2)创建定制规则库篇
在上一篇《工程配置篇》里,我们已经了解了如何下载llvm和clang的源码,如何生成Xcode工程并完成编译,现在就开始定制自己的静态分析规则。
首先要明确的两点,一是clang自己的build target基本是静态链接的,但我们要做的是独立发布、独立加载的规则库,必须做成动态链接。二是开发静态分析规则,完全依赖clang提供的能力,考虑到开发、调试的方便,规则库工程将被建立在clang工程下。
我们实现的机制是应用了clang plugin机制,可参考 http://clang.llvm.org/docs/ClangPlugins.html 。具体到静态分析规则开发,可以使用更简单的checker plugin,详细原理会在后面阐述,此处暂只先说工程搭建。
1、CMake配置
clang analyzer的源码在
~/projects/analyzer/llvm/tools/clang/lib/StaticAnalyzer
<