You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Sam Blackshear 4fc0ecd86b
[clang] don't include procname in broken cfg error message
7 years ago
..
ALVar.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
ALVar.mli [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
CLintersContext.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
CLintersContext.mli [linters] Do not report MUTABLE_LOCAL_VARIABLE_IN_COMPONENT_FILE for the loop indices 8 years ago
CProcname.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
CProcname.mli [cleanup] Move ObjC/C++-specific Procname functions to dedicated module 7 years ago
CTLExceptions.ml [cleanup] add missing `open! IStd` 7 years ago
CTLExceptions.mli [ocamlformat] Upgrade to ocamlformat 0.4 7 years ago
CTLParserHelper.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
CTLParserHelper.mli [AL] add `--linters-validate-syntax-only` to check whether there are any syntax errors in AL files 8 years ago
CType.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
CType.mli [cleanup] remove dead code 7 years ago
CType_decl.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
CType_decl.mli [clang] upgrade internal clang 7 years ago
Capture.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
Capture.mli [clang] do not run clang on unsupported commands 7 years ago
CiOSVersionNumbers.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
CiOSVersionNumbers.mli [cleanup] remove dead code 7 years ago
ClangCommand.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
ClangCommand.mli [clang] do not run clang on unsupported commands 7 years ago
ClangLogging.ml [clang] don't include procname in broken cfg error message 7 years ago
ClangLogging.mli [clang] log broken CFGs 7 years ago
ClangPointers.ml [cleanup] remove dead code 7 years ago
ClangPointers.mli [cleanup] remove dead code 7 years ago
ClangWrapper.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
ClangWrapper.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
ComponentKit.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
ComponentKit.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
README.md [docs] Extend src/clang/README.md with info about AST 8 years ago
ast_expressions.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
ast_expressions.mli [clang] convert some assert false's to structured fails 7 years ago
cArithmetic_trans.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cArithmetic_trans.mli [frontend] Parse binary operator using types of parameters 7 years ago
cAst_utils.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cAst_utils.mli Remove unnecessary option type 7 years ago
cContext.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cContext.mli [clang] Make another crash into incorrect_assumption 7 years ago
cEnum_decl.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cEnum_decl.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cField_decl.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cField_decl.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cFrontend.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cFrontend.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cFrontend_checkers.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cFrontend_checkers.mli [cleanup] remove dead code 7 years ago
cFrontend_checkers_main.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cFrontend_checkers_main.mli Open Core.Std by default, still use Caml Hashtbl, Map, Set 8 years ago
cFrontend_config.ml combine ocaml_pos and ml_loc 7 years ago
cFrontend_config.mli combine ocaml_pos and ml_loc 7 years ago
cFrontend_decl.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cFrontend_decl.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cFrontend_errors.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cFrontend_errors.mli [linters] Add a linter for checking const pointers to Objective-C classes 8 years ago
cGeneral_utils.ml [IList] move to base/ and use Core 7 years ago
cGeneral_utils.mli [clang] Find fields from the properties corresponding to the property implementations. 7 years ago
cIssue.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cIssue.mli [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cLocation.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cLocation.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cMethodSignature.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cMethodSignature.mli [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cMethod_trans.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cMethod_trans.mli [clang] improve `CMethodSignature` interface 7 years ago
cModule_type.ml [capture] get rid of call graphs 7 years ago
cPredicates.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cPredicates.mli Add function to retrieve the lifetime of an ivar pointer and check if it is strong 7 years ago
cTL.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cTL.mli [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cTrans.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cTrans.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cTrans_models.ml [clang] improve `CMethodSignature` interface 7 years ago
cTrans_models.mli [clang] improve `CMethodSignature` interface 7 years ago
cTrans_utils.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cTrans_utils.mli [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cType_to_sil_type.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
cType_to_sil_type.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cVar_decl.ml [istd] break IStd.ml into sensible components 7 years ago
cVar_decl.mli [clang] Added logging of caught exceptions of type IncorrectAssumption to clang frontend 7 years ago
clang_ast_extend.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
ctl_lexer.mll [al] use "quotes" for user imports 7 years ago
ctl_parser.mly [al] use "quotes" for user imports 7 years ago
ctl_parser_types.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
ctl_parser_types.mli [linters] Add logging and caught exceptions to the linters 7 years ago
objcCategory_decl.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
objcCategory_decl.mli [cleanup] remove dead code 7 years ago
objcInterface_decl.ml [IList] move to base/ and use Core 7 years ago
objcInterface_decl.mli [cleanup] remove dead code 7 years ago
objcProperty_decl.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
objcProperty_decl.mli Add a lint rule warning about ObjC custom setters for weak properties 7 years ago
objcProtocol_decl.ml [cleanup] remove dead code 7 years ago
objcProtocol_decl.mli [cleanup] remove dead code 7 years ago
tableaux.ml [ocamlformat] Upgrade to ocamlformat 0.5 7 years ago
tableaux.mli [cleanup] remove dead code 7 years ago
types_lexer.mll [linters] Support reference types in the linters type parser 8 years ago
types_parser.mly [AL] New exception ALFileException with source-location info 8 years ago

README.md

Clang Front-End

This is the front-end for the clang compiler.

The main entry point is ClangWrapper.

General structure

  1. Given a compilation command from the build system, sanitize it, attach ASTExporter clang plugin to the relevant commands and run it.
  2. Parse the AST from Biniou format to OCaml data structure.
  3. (optional) Invoke translation to SIL via CFrontend.
  4. (optional) Invoke linters via CFrontend_checkers_main. More on linters

Format of the AST

OCaml data structure is defined in atd format. The clang_ast_t.atd file is generated from comments in ASTExporter.h file.

For more information, refer to the relevant documentation in facebook-clang-plugins:

Hacking on .atd file

  1. Create a simple example (example.cpp) source file with construct that needs to be exported. The smaller the better.
  2. Export extra information by changing code in libtooling/ASTExporter.h. For more information, refer to the ATD_GUIDELINES.
  3. Compile Infer with the new version of facebook-clang-plugins. Running make all from top level of Infer repository will do that. Sometimes there may be compilation errors due to .atd file changes - they need to be fixed.
  4. Use newly exported information information in the frontend.

Tips & Tricks:

  • To view the AST in a human readable version, Infer can generate .bdump file: infer -g -- clang -c example.cpp && sh example.cpp.ast.sh. Then open example.cpp.ast.bdump
  • To inspect ast dump visually: clang -c example.cpp -Xclang -ast-dump. It doesn't include all the information that Infer sees, but it's pretty concise
  • If running bdump is failing (it happens on huge sources sometimes), there is a way to view it in "Yojson" format. To do that, replace all occurrences of BiniouASTExporter with YojsonASTExporter in .ast.sh script.