This repo is deprecated. Development has moved to the Infer repo.
This repository aims to share some useful clang plugins developed at Facebook. They are mostly used by infer.
It contains frontend plugins to the clang compiler to process the syntax of source files directly to accomplish more general tasks; specifically, we have developed a clang-to-ocaml bridge to make code analyses easier.
-
libtooling
: frontend plugins (currently a clang-to-json AST exporter), -
clang-ocaml
: OCaml libraries to process the JSON output of frontend plugins,
The current version of the plugins requires recent version of the clang compiler, re-compiled from source. Clang source which is used by this project can be found in clang/src/
General instructions to compile clang can be found here: http://clang.llvm.org/get_started.html
To compile and use the required version of clang, please run ./clang/setup.sh. Using this script should make the variable CLANG_PREFIX unnecessary to compile the plugin.
Caveat:
- Because of the nature of C++, clang and the plugins need to be compiled with the exact same C++ libraries.
- Also, the default stripping command of clang in release mode breaks plugins.
Once the target compiler is installed, make test
should run the unit tests.
OCaml users may also run:
make -C clang-ocaml test #requires proper ocaml libraries, see included clang-ocaml/README
Additional configuration options are available in Makefile.config
.
The plugins are MIT-licensed.