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.
107 lines
2.8 KiB
107 lines
2.8 KiB
(*
|
|
* Copyright (c) 2013 - present Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*)
|
|
|
|
open! Utils
|
|
open CFrontend_utils
|
|
|
|
(** Define the signature of a method consisting of its name, its arguments, *)
|
|
(** return type, location and whether its an instance method. *)
|
|
|
|
type method_signature = {
|
|
mutable name : Procname.t;
|
|
args : (Mangled.t * Clang_ast_t.qual_type) list;
|
|
ret_type : Clang_ast_t.type_ptr;
|
|
attributes : Clang_ast_t.attribute list;
|
|
loc : Clang_ast_t.source_range;
|
|
is_instance : bool;
|
|
is_cpp_virtual : bool;
|
|
language : Config.clang_lang;
|
|
pointer_to_parent : Clang_ast_t.pointer option;
|
|
pointer_to_property_opt : Clang_ast_t.pointer option; (* If set then method is a getter/setter *)
|
|
return_param_typ : Typ.t option;
|
|
}
|
|
|
|
let ms_get_name { name } =
|
|
name
|
|
|
|
let ms_set_name ms name =
|
|
ms.name <- name
|
|
|
|
let ms_get_args { args } =
|
|
args
|
|
|
|
let ms_get_ret_type { ret_type } =
|
|
ret_type
|
|
|
|
let ms_get_attributes { attributes } =
|
|
attributes
|
|
|
|
let ms_get_loc { loc } =
|
|
loc
|
|
|
|
let ms_is_instance { is_instance } =
|
|
is_instance
|
|
|
|
let ms_is_cpp_virtual { is_cpp_virtual } =
|
|
is_cpp_virtual
|
|
|
|
let ms_get_lang { language } =
|
|
language
|
|
|
|
let ms_get_pointer_to_parent { pointer_to_parent } =
|
|
pointer_to_parent
|
|
|
|
let ms_get_pointer_to_property_opt { pointer_to_property_opt } =
|
|
pointer_to_property_opt
|
|
|
|
let ms_get_return_param_typ { return_param_typ } =
|
|
return_param_typ
|
|
|
|
(* A method is a getter if it has a link to a property and *)
|
|
(* it has 1 argument (this includes self) *)
|
|
let ms_is_getter { pointer_to_property_opt; args } =
|
|
Option.is_some pointer_to_property_opt &&
|
|
IList.length args == 1
|
|
|
|
(* A method is a setter if it has a link to a property and *)
|
|
(* it has 2 argument (this includes self) *)
|
|
let ms_is_setter { pointer_to_property_opt; args } =
|
|
Option.is_some pointer_to_property_opt &&
|
|
IList.length args == 2
|
|
|
|
let make_ms name args ret_type attributes loc is_instance ?is_cpp_virtual language pointer_to_parent
|
|
pointer_to_property_opt return_param_typ =
|
|
let is_cpp_virtual = match is_cpp_virtual with
|
|
| Some is_cpp_virtual -> is_cpp_virtual
|
|
| None -> false in
|
|
{
|
|
name;
|
|
args;
|
|
ret_type;
|
|
attributes;
|
|
loc;
|
|
is_instance;
|
|
is_cpp_virtual;
|
|
language;
|
|
pointer_to_parent;
|
|
pointer_to_property_opt;
|
|
return_param_typ;
|
|
}
|
|
|
|
let replace_name_ms ms name =
|
|
{ ms with name }
|
|
|
|
let ms_to_string ms =
|
|
"Method " ^ (Procname.to_string ms.name) ^ " " ^
|
|
IList.to_string
|
|
(fun (s1, s2) -> (Mangled.to_string s1) ^ ", " ^ (Ast_utils.string_of_qual_type s2))
|
|
ms.args
|
|
^ "->" ^ (Ast_utils.string_of_type_ptr ms.ret_type) ^ " " ^
|
|
Clang_ast_j.string_of_source_range ms.loc
|