Module IR.Annot
type t
=
{
class_name : string;
name of the annotation
parameters : parameter list;
}
Type to represent an
@Annotation
with potentially complex parameter values such as arrays or other annotations.
and parameter
=
{
name : string option;
value : value;
}
and value
=
|
Str of string
|
Bool of bool
|
Enum of
{
class_typ : Typ.t;
value : string;
}
|
Array of value list
|
Class of Typ.t
|
Annot of t
Type to represent possible annotation parameter values. Note that support for numeric parameters is missing for now due to an issue with
MaximumSharing
andint64
.
val compare : t -> t -> int
val compare_parameter : parameter -> parameter -> int
val compare_value : value -> value -> int
val equal : t -> t -> bool
val equal_parameter : parameter -> parameter -> bool
val equal_value : value -> value -> bool
val compare : t -> t -> int
val compare_parameter : parameter -> parameter -> int
val compare_value : value -> value -> int
val volatile : t
annotation for fields marked with the "volatile" keyword
val final : t
annotation for fields marked with the "final" keyword
val has_matching_str_value : pred:(string -> bool) -> value -> bool
Check if annotation parameter value contains a string satisfying a predicate. For convenience it works both with raw
Str
andStr
insideArray
.
val find_parameter : t -> name:string -> value option
val pp : F.formatter -> t -> unit
Pretty print an annotation.
module Item : sig ... end
module Class : sig ... end
module Method : sig ... end