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.
51 lines
1.1 KiB
51 lines
1.1 KiB
(*
|
|
* Copyright (c) 2018-present, Facebook, Inc.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*)
|
|
|
|
open! IStd
|
|
|
|
type t =
|
|
| Base of AccessPath.base
|
|
| FieldOffset of t * Typ.Fieldname.t
|
|
(* field access *)
|
|
| ArrayOffset of t * Typ.t * t list
|
|
(* array access *)
|
|
| AddressOf of t
|
|
(* address of operator & *)
|
|
| Dereference of t
|
|
(* dereference operator * *)
|
|
[@@deriving compare]
|
|
|
|
val to_access_path : t -> AccessPath.t
|
|
|
|
val to_access_paths : t list -> AccessPath.t list
|
|
|
|
val of_id : Ident.t -> Typ.t -> t
|
|
(** create an access expression from an ident *)
|
|
|
|
val get_base : t -> AccessPath.base
|
|
|
|
val replace_base : remove_deref_after_base:bool -> AccessPath.base -> t -> t
|
|
|
|
val is_base : t -> bool
|
|
|
|
val get_typ : t -> Tenv.t -> Typ.t option
|
|
|
|
val pp : Format.formatter -> t -> unit
|
|
|
|
val equal : t -> t -> bool
|
|
|
|
val of_lhs_exp :
|
|
include_array_indexes:bool
|
|
-> add_deref:bool
|
|
-> Exp.t
|
|
-> Typ.t
|
|
-> f_resolve_id:(Var.t -> t option)
|
|
-> t option
|
|
(** convert [lhs_exp] to an access expression, resolving identifiers using [f_resolve_id] *)
|
|
|
|
val normalize : t -> t
|