[AL] Adding a new transition to siblings

Reviewed By: skcho

Differential Revision: D18689255

fbshipit-source-id: f2b095382
master
Dulma Churchill 5 years ago committed by Facebook Github Bot
parent b15395ad60
commit 766fc2c072

@ -1 +1 @@
Subproject commit b97ae1305b35e22ce80eeea28c5545c36a49db26 Subproject commit f691096a2d34b81da7d6b05bfd4fffa280472f09

@ -28,6 +28,7 @@ type transitions =
| Cond | Cond
| PointerToDecl (** stmt to decl *) | PointerToDecl (** stmt to decl *)
| Protocol (** decl to decl *) | Protocol (** decl to decl *)
| Sibling (** decl to decl *)
| SourceExpr | SourceExpr
[@@deriving compare] [@@deriving compare]
@ -43,7 +44,7 @@ let is_transition_to_successor trans =
| Cond | Cond
| SourceExpr -> | SourceExpr ->
true true
| Super | PointerToDecl | Protocol | AccessorForProperty _ -> | Super | PointerToDecl | Protocol | AccessorForProperty _ | Sibling ->
false false
@ -158,6 +159,8 @@ module Debug = struct
Format.pp_print_string fmt "Protocol" Format.pp_print_string fmt "Protocol"
| PointerToDecl -> | PointerToDecl ->
Format.pp_print_string fmt "PointerToDecl" Format.pp_print_string fmt "PointerToDecl"
| Sibling ->
Format.pp_print_string fmt "Sibling"
| SourceExpr -> | SourceExpr ->
Format.pp_print_string fmt "SourceExpr" Format.pp_print_string fmt "SourceExpr"
in in
@ -935,6 +938,28 @@ let transition_via_field_name node name =
[] []
let transition_via_sibling node =
let open Clang_ast_t in
match node with
| Decl orig_decl -> (
let decl_info = Clang_ast_proj.get_decl_tuple orig_decl in
match CAst_utils.get_decl_opt decl_info.Clang_ast_t.di_parent_pointer with
| Some (TranslationUnitDecl (_, decls, _, _))
| Some (ObjCImplementationDecl (_, _, decls, _, _))
| Some (ObjCInterfaceDecl (_, _, decls, _, _))
| Some (ObjCProtocolDecl (_, _, decls, _, _))
| Some (ObjCCategoryDecl (_, _, decls, _, _))
| Some (ObjCCategoryImplDecl (_, _, decls, _, _))
| Some (RecordDecl (_, _, _, decls, _, _, _)) ->
List.filter_map
~f:(fun decl -> if not (phys_equal decl orig_decl) then Some (Decl decl) else None)
decls
| _ ->
[] )
| Stmt _ ->
[]
(* given a node an returns a list of nodes an' such that an transition to an' via label trans *) (* given a node an returns a list of nodes an' such that an transition to an' via label trans *)
let next_state_via_transition an trans = let next_state_via_transition an trans =
match (an, trans) with match (an, trans) with
@ -946,6 +971,8 @@ let next_state_via_transition an trans =
transition_via_fields an transition_via_fields an
| _, Parameters -> | _, Parameters ->
transition_via_parameters an transition_via_parameters an
| _, Sibling ->
transition_via_sibling an
| Decl d, InitExpr | Decl d, Body -> | Decl d, InitExpr | Decl d, Body ->
transition_decl_to_stmt d trans transition_decl_to_stmt d trans
| Decl d, Protocol -> | Decl d, Protocol ->

@ -28,6 +28,7 @@ type transitions =
| Cond | Cond
| PointerToDecl (** stmt to decl *) | PointerToDecl (** stmt to decl *)
| Protocol (** decl to decl *) | Protocol (** decl to decl *)
| Sibling (** decl to decl *)
| SourceExpr | SourceExpr
[@@deriving compare] [@@deriving compare]

@ -83,6 +83,7 @@ rule token = parse
| "InitExpr" {INIT_EXPR} | "InitExpr" {INIT_EXPR}
| "Cond" {COND} | "Cond" {COND}
| "PointerToDecl" {POINTER_TO_DECL} | "PointerToDecl" {POINTER_TO_DECL}
| "Sibling" {SIBLING}
| "SourceExpr" {SOURCE_EXPR} | "SourceExpr" {SOURCE_EXPR}
| id { IDENTIFIER (Lexing.lexeme lexbuf) } | id { IDENTIFIER (Lexing.lexeme lexbuf) }
| '"' { read_string (Buffer.create 80) lexbuf } | '"' { read_string (Buffer.create 80) lexbuf }

@ -86,6 +86,7 @@
%token PARAMETER_NAME %token PARAMETER_NAME
%token PARAMETER_POS %token PARAMETER_POS
%token POINTER_TO_DECL %token POINTER_TO_DECL
%token SIBLING
%token SOURCE_EXPR %token SOURCE_EXPR
%token PROTOCOL %token PROTOCOL
%token EOF %token EOF
@ -250,8 +251,9 @@ transition_label:
| PARAMETER_NAME alexp { Some (CTL.ParameterName $2) } | PARAMETER_NAME alexp { Some (CTL.ParameterName $2) }
| PARAMETER_POS alexp { Some (CTL.ParameterPos $2) } | PARAMETER_POS alexp { Some (CTL.ParameterPos $2) }
| POINTER_TO_DECL { Some CTL.PointerToDecl } | POINTER_TO_DECL { Some CTL.PointerToDecl }
| SOURCE_EXPR { Some CTL.SourceExpr}
| PROTOCOL { Some CTL.Protocol } | PROTOCOL { Some CTL.Protocol }
| SIBLING { Some CTL.Sibling}
| SOURCE_EXPR { Some CTL.SourceExpr}
; ;
formula_EF: formula_EF:

@ -897,3 +897,18 @@ SET report_when =
is_create_method_parameter is_create_method_parameter
HOLDS-IN-NODE CallExpr; HOLDS-IN-NODE CallExpr;
}; };
DEFINE-CHECKER CLASS_AND_VAR = {
LET global_var_exists =
is_node("VarDecl");
LET var_decl =
(HOLDS-NEXT WITH-TRANSITION Sibling
(global_var_exists()));
SET report_when =
WHEN var_decl() AND declaration_has_name("SiblingExample")
HOLDS-IN-NODE ObjCInterfaceDecl;
SET message = "Found a global var next to a class";
};

@ -0,0 +1,13 @@
/*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#import <Foundation/NSObject.h>
int x;
@interface SiblingExample : NSObject
@end

@ -227,6 +227,8 @@ codetoanalyze/objc/linters-for-test-only/PrivateInstanceMethod.m, UselessClass::
codetoanalyze/objc/linters-for-test-only/PrivateInstanceMethod.m, UselessClass::b, 11, TEST_RETURN_METHOD, no_bucket, WARNING, [] codetoanalyze/objc/linters-for-test-only/PrivateInstanceMethod.m, UselessClass::b, 11, TEST_RETURN_METHOD, no_bucket, WARNING, []
codetoanalyze/objc/linters-for-test-only/PrivateInstanceMethod.m, UselessClass::b, 18, TEST_IS_METHOD_EXPOSED, no_bucket, WARNING, [] codetoanalyze/objc/linters-for-test-only/PrivateInstanceMethod.m, UselessClass::b, 18, TEST_IS_METHOD_EXPOSED, no_bucket, WARNING, []
codetoanalyze/objc/linters-for-test-only/PrivateInstanceMethod.m, UselessClass::b, 18, TEST_RETURN_METHOD, no_bucket, WARNING, [] codetoanalyze/objc/linters-for-test-only/PrivateInstanceMethod.m, UselessClass::b, 18, TEST_RETURN_METHOD, no_bucket, WARNING, []
codetoanalyze/objc/linters-for-test-only/al_definitions/sibling_example.m, Linters_dummy_method, 9, TEST_VAR_TYPE_CHECK, no_bucket, WARNING, []
codetoanalyze/objc/linters-for-test-only/al_definitions/sibling_example.m, Linters_dummy_method, 11, CLASS_AND_VAR, no_bucket, WARNING, []
codetoanalyze/objc/linters-for-test-only/const.m, Linters_dummy_method, 7, CONST_NAMING, no_bucket, WARNING, [] codetoanalyze/objc/linters-for-test-only/const.m, Linters_dummy_method, 7, CONST_NAMING, no_bucket, WARNING, []
codetoanalyze/objc/linters-for-test-only/const.m, Linters_dummy_method, 7, TEST_VAR_TYPE_CHECK, no_bucket, WARNING, [] codetoanalyze/objc/linters-for-test-only/const.m, Linters_dummy_method, 7, TEST_VAR_TYPE_CHECK, no_bucket, WARNING, []
codetoanalyze/objc/linters-for-test-only/const.m, Linters_dummy_method, 8, CONST_NAMING, no_bucket, WARNING, [] codetoanalyze/objc/linters-for-test-only/const.m, Linters_dummy_method, 8, CONST_NAMING, no_bucket, WARNING, []

Loading…
Cancel
Save