Add predicates to check for protocols

Reviewed By: dulmarod

Differential Revision: D7867975

fbshipit-source-id: 20d599d
master
Brandon Kieft 7 years ago committed by Facebook Github Bot
parent 439839a9fa
commit 275f4c3a8c

@ -281,6 +281,14 @@ let is_objc_category_named an re =
is_objc_category_interface_named an re || is_objc_category_implementation_named an re is_objc_category_interface_named an re || is_objc_category_implementation_named an re
let is_objc_protocol_named an re =
match an with
| Ctl_parser_types.Decl (Clang_ast_t.ObjCProtocolDecl _) ->
declaration_has_name an re
| _ ->
false
let is_objc_method_named an name = let is_objc_method_named an name =
match an with match an with
| Ctl_parser_types.Decl (Clang_ast_t.ObjCMethodDecl _) -> | Ctl_parser_types.Decl (Clang_ast_t.ObjCMethodDecl _) ->
@ -763,6 +771,14 @@ let is_in_objc_category_named context name =
false false
let is_in_objc_protocol_named context name =
match context.CLintersContext.current_objc_protocol with
| Some protocol ->
is_objc_protocol_named (Decl protocol) name
| None ->
false
let captures_cxx_references an = List.length (captured_variables_cxx_ref an) > 0 let captures_cxx_references an = List.length (captured_variables_cxx_ref an) > 0
let is_binop_with_kind an alexp_kind = let is_binop_with_kind an alexp_kind =

@ -187,6 +187,12 @@ val is_objc_category_implementation_on_subclass_of :
* inherits from a class whose name matches the provided REGEXP * inherits from a class whose name matches the provided REGEXP
*) *)
val is_objc_protocol_named : Ctl_parser_types.ast_node -> ALVar.alexp -> bool
(**
* Checks if the current node is an ObjCProtocolDecl node
* whose name matches the provided REGEXP
*)
val is_objc_method_named : Ctl_parser_types.ast_node -> ALVar.alexp -> bool val is_objc_method_named : Ctl_parser_types.ast_node -> ALVar.alexp -> bool
(** (**
* Checks if the current node is an ObjCMethodDecl node * Checks if the current node is an ObjCMethodDecl node
@ -281,6 +287,12 @@ val is_in_objc_category_named : CLintersContext.context -> ALVar.alexp -> bool
* ObjCCategoryImplDecl node whose name matches the provided REGEXP * ObjCCategoryImplDecl node whose name matches the provided REGEXP
*) *)
val is_in_objc_protocol_named : CLintersContext.context -> ALVar.alexp -> bool
(**
* Checks if the current node is a subnode of an ObjCProtocolDecl
* node whose name matches the provided REGEXP
*)
val is_in_objc_method : CLintersContext.context -> ALVar.alexp -> bool val is_in_objc_method : CLintersContext.context -> ALVar.alexp -> bool
(** (**
* Checks if the current node, or a parent node, is an ObjCMethodDecl node * Checks if the current node, or a parent node, is an ObjCMethodDecl node

@ -1044,6 +1044,8 @@ let rec eval_Atomic pred_name_ args an lcxt =
CPredicates.is_in_objc_category_implementation_named lcxt name CPredicates.is_in_objc_category_implementation_named lcxt name
| "is_in_objc_category_named", [name], _ -> | "is_in_objc_category_named", [name], _ ->
CPredicates.is_in_objc_category_named lcxt name CPredicates.is_in_objc_category_named lcxt name
| "is_in_objc_protocol_named", [name], _ ->
CPredicates.is_in_objc_protocol_named lcxt name
| "is_ivar_atomic", [], an -> | "is_ivar_atomic", [], an ->
CPredicates.is_ivar_atomic an CPredicates.is_ivar_atomic an
| "is_method_property_accessor_of_ivar", [], an -> | "is_method_property_accessor_of_ivar", [], an ->
@ -1080,6 +1082,8 @@ let rec eval_Atomic pred_name_ args an lcxt =
CPredicates.is_objc_category_implementation_on_subclass_of an name CPredicates.is_objc_category_implementation_on_subclass_of an name
| "is_objc_category_on_subclass_of", [name], an -> | "is_objc_category_on_subclass_of", [name], an ->
CPredicates.is_objc_category_on_subclass_of an name CPredicates.is_objc_category_on_subclass_of an name
| "is_objc_protocol_named", [name], an ->
CPredicates.is_objc_protocol_named an name
| "is_objc_method_named", [name], an -> | "is_objc_method_named", [name], an ->
CPredicates.is_objc_method_named an name CPredicates.is_objc_method_named an name
| "is_objc_method_overriding", [], an -> | "is_objc_method_overriding", [], an ->

@ -576,6 +576,17 @@ DEFINE-CHECKER TEST_IF_METHOD_IS_IN_CATEGORY_ON_SUBCLASS_OF = {
}; };
DEFINE-CHECKER TEST_IF_METHOD_IS_IN_PROTOCOL_NAMED = {
SET report_when =
WHEN
is_in_objc_protocol_named("MyBaseClassProtocol")
HOLDS-IN-NODE ObjCMethodDecl;
SET message = "Method %name% is in the protocol named MyBaseClassProtocol.";
};
DEFINE-CHECKER TEST_IF_IS_CATEGORY_INTERFACE_NAMED = { DEFINE-CHECKER TEST_IF_IS_CATEGORY_INTERFACE_NAMED = {
SET report_when = SET report_when =
@ -676,6 +687,15 @@ DEFINE-CHECKER TEST_IF_IS_CLASS_NAMED = {
}; };
DEFINE-CHECKER TEST_IF_IS_PROTOCOL_NAMED = {
SET report_when =
is_objc_protocol_named("MyBaseClassProtocol");
SET message = "Node is a protocol named MyBaseClassProtocol.";
};
DEFINE-CHECKER TEST_IF_IS_METHOD_NAMED = { DEFINE-CHECKER TEST_IF_IS_METHOD_NAMED = {
SET report_when = SET report_when =

@ -7,6 +7,7 @@ codetoanalyze/objc/linters-for-test-only/CallingAMethodWithSelf.m, CallingAMetho
codetoanalyze/objc/linters-for-test-only/CallingAMethodWithSelf.m, CallingAMethodWithSelf_testView, 44, TEST_IS_METHOD_EXPOSED, WARNING, [] codetoanalyze/objc/linters-for-test-only/CallingAMethodWithSelf.m, CallingAMethodWithSelf_testView, 44, TEST_IS_METHOD_EXPOSED, WARNING, []
codetoanalyze/objc/linters-for-test-only/CallingAMethodWithSelf.m, CallingAMethodWithSelf_testView, 44, TEST_IS_OVERRIDING_METHOD, WARNING, [] codetoanalyze/objc/linters-for-test-only/CallingAMethodWithSelf.m, CallingAMethodWithSelf_testView, 44, TEST_IS_OVERRIDING_METHOD, WARNING, []
codetoanalyze/objc/linters-for-test-only/CallingAMethodWithSelf.m, CallingAMethodWithSelf_testView, 45, TEST_VAR_TYPE_CHECK, WARNING, [] codetoanalyze/objc/linters-for-test-only/CallingAMethodWithSelf.m, CallingAMethodWithSelf_testView, 45, TEST_VAR_TYPE_CHECK, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 7, TEST_IF_IS_PROTOCOL_NAMED, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 14, TEST_IF_IS_CLASS_NAMED, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 14, TEST_IF_IS_CLASS_NAMED, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 21, TEST_IF_IS_CATEGORY_INTERFACE_ON_CLASS_NAMED, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 21, TEST_IF_IS_CATEGORY_INTERFACE_ON_CLASS_NAMED, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 21, TEST_IF_IS_CATEGORY_ON_CLASS_NAMED, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 21, TEST_IF_IS_CATEGORY_ON_CLASS_NAMED, WARNING, []
@ -24,6 +25,8 @@ codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_metho
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 134, TEST_IF_IS_CATEGORY_ON_SUBCLASS_OF, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 134, TEST_IF_IS_CATEGORY_ON_SUBCLASS_OF, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 140, TEST_IF_IS_CATEGORY_IMPLEMENTATION_ON_SUBCLASS_OF, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 140, TEST_IF_IS_CATEGORY_IMPLEMENTATION_ON_SUBCLASS_OF, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 140, TEST_IF_IS_CATEGORY_ON_SUBCLASS_OF, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, Linters_dummy_method, 140, TEST_IF_IS_CATEGORY_ON_SUBCLASS_OF, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, MyBaseClassProtocol_myBaseClassProtocolOptionalMethod, 11, TEST_IF_METHOD_IS_IN_PROTOCOL_NAMED, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, MyBaseClassProtocol_myBaseClassProtocolRequiredMethod, 9, TEST_IF_METHOD_IS_IN_PROTOCOL_NAMED, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, MyBaseClass_myBaseClassCategoryMethod, 47, TEST_IF_METHOD_IS_IN_CATEGORY_INTERFACE_NAMED, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, MyBaseClass_myBaseClassCategoryMethod, 47, TEST_IF_METHOD_IS_IN_CATEGORY_INTERFACE_NAMED, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, MyBaseClass_myBaseClassCategoryMethod, 47, TEST_IF_METHOD_IS_IN_CATEGORY_INTERFACE_ON_CLASS_NAMED, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, MyBaseClass_myBaseClassCategoryMethod, 47, TEST_IF_METHOD_IS_IN_CATEGORY_INTERFACE_ON_CLASS_NAMED, WARNING, []
codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, MyBaseClass_myBaseClassCategoryMethod, 47, TEST_IF_METHOD_IS_IN_CATEGORY_NAMED, WARNING, [] codetoanalyze/objc/linters-for-test-only/GenericTestClass.m, MyBaseClass_myBaseClassCategoryMethod, 47, TEST_IF_METHOD_IS_IN_CATEGORY_NAMED, WARNING, []

Loading…
Cancel
Save