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 1a75ec9cf8
[cleanup] Move ObjC/C++-specific Procname functions to dedicated module
7 years ago
..
ALVar.ml [ocamlformat] Upgrade ocamlformat to v0.2 from opam 7 years ago
ALVar.mli New test for the tableaux method. 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 7 years ago
CProcname.ml [cleanup] Move ObjC/C++-specific Procname functions to dedicated module 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 [cleanup] remove dead code 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 7 years ago
CType.ml [cleanup] remove dead code 7 years ago
CType.mli [cleanup] remove dead code 7 years ago
CType_decl.ml [cleanup] remove dead code 7 years ago
CType_decl.mli [cleanup] remove dead code 7 years ago
Capture.ml [pp] print contents of argfiles, recursively, on error 7 years ago
Capture.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
CiOSVersionNumbers.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
CiOSVersionNumbers.mli [cleanup] remove dead code 7 years ago
ClangCommand.ml [pp] print contents of argfiles, recursively, on error 7 years ago
ClangCommand.mli [pp] print contents of argfiles, recursively, on error 7 years ago
ClangLogging.ml [linters] Add logging and caught exceptions to the linters 7 years ago
ClangLogging.mli [linters] Add logging and caught exceptions to the linters 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 base and ocamlformat 7 years ago
ClangWrapper.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
ComponentKit.ml [ocamlformat] Upgrade base and ocamlformat 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 [clang] convert some assert false's to structured fails 7 years ago
ast_expressions.mli [clang] convert some assert false's to structured fails 7 years ago
cArithmetic_trans.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
cArithmetic_trans.mli [cleanup] Remove the retain count implementation from ObjC that is unused. 7 years ago
cAst_utils.ml [linters] Add logging and caught exceptions to the linters 7 years ago
cAst_utils.mli [linters] Add logging and caught exceptions to the linters 7 years ago
cContext.ml [clang] Make another crash into incorrect_assumption 7 years ago
cContext.mli [clang] Make another crash into incorrect_assumption 7 years ago
cEnum_decl.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
cEnum_decl.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cField_decl.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
cField_decl.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cFrontend.ml [db] record symbolic capture timestamps for source files 7 years ago
cFrontend.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cFrontend_checkers.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
cFrontend_checkers.mli [cleanup] remove dead code 7 years ago
cFrontend_checkers_main.ml [al] import files relatively to the current al file 7 years ago
cFrontend_checkers_main.mli Open Core.Std by default, still use Caml Hashtbl, Map, Set 8 years ago
cFrontend_config.ml [clang] change CTrans_utils.Self.SelfClassException to use new CFrontend_config.ocaml_pos type instead of raw tuple 7 years ago
cFrontend_config.mli [linters] Add logging and caught exceptions to the linters 7 years ago
cFrontend_decl.ml [IR] combine is_objc_instance_method and is_cpp_instance_method fields in ProcAttributes into method_kind 7 years ago
cFrontend_decl.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cFrontend_errors.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
cFrontend_errors.mli [linters] Add a linter for checking const pointers to Objective-C classes 7 years ago
cGeneral_utils.ml [clang] make ast_node argument optional in Unimplemented and IncorrectAssumption exception raising functions 7 years ago
cGeneral_utils.mli [clang] Added logging of caught exceptions of type IncorrectAssumption to clang frontend 7 years ago
cIssue.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
cIssue.mli [cleanup] remove dead code 7 years ago
cLocation.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
cLocation.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cMethod_signature.ml [IR] combine is_objc_instance_method and is_cpp_instance_method fields in ProcAttributes into method_kind 7 years ago
cMethod_signature.mli [IR] combine is_objc_instance_method and is_cpp_instance_method fields in ProcAttributes into method_kind 7 years ago
cMethod_trans.ml [cleanup] Move ObjC/C++-specific Procname functions to dedicated module 7 years ago
cMethod_trans.mli [IR] combine is_objc_instance_method and is_cpp_instance_method fields in ProcAttributes into method_kind 7 years ago
cModule_type.ml [capture] get rid of call graphs 7 years ago
cPredicates.ml [cleanup] Move ObjC/C++-specific Procname functions to dedicated module 7 years ago
cPredicates.mli [cleanup] remove dead code 7 years ago
cTL.ml [linters] Add logging and caught exceptions to the linters 7 years ago
cTL.mli Add a lint rule warning about ObjC custom setters for weak properties 7 years ago
cTrans.ml [cleanup] Move ObjC/C++-specific Procname functions to dedicated module 7 years ago
cTrans.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cTrans_models.ml [cleanup] Move ObjC/C++-specific Procname functions to dedicated module 7 years ago
cTrans_models.mli [cleanup] Move ObjC/C++-specific Procname functions to dedicated module 7 years ago
cTrans_utils.ml [cleanup] Move ObjC/C++-specific Procname functions to dedicated module 7 years ago
cTrans_utils.mli [clang] Make another crash into incorrect_assumption 7 years ago
cType_to_sil_type.ml [ocamlformat] Upgrade base and ocamlformat 7 years ago
cType_to_sil_type.mli Convert Reason to OCaml, and auto-format OCaml 8 years ago
cVar_decl.ml [clang] make ast_node argument optional in Unimplemented and IncorrectAssumption exception raising functions 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 [linters] Add logging and caught exceptions to the linters 7 years ago
ctl_parser_types.mli [linters] Add logging and caught exceptions to the linters 7 years ago
objcCategory_decl.ml [cleanup] remove dead code 7 years ago
objcCategory_decl.mli [cleanup] remove dead code 7 years ago
objcInterface_decl.ml [cleanup] remove dead code 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 [cleanup] remove dead code 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 7 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.