module Logic_typing:sig..end
val type_rel : Logic_ptree.relation -> Cil_types.relationval type_binop : Logic_ptree.binop -> Cil_types.binopval unescape : string -> string
val wcharlist_of_string : string -> int64 list
val is_arithmetic_type : Cil_types.logic_type -> bool
val is_integral_type : Cil_types.logic_type -> bool
val is_set_type : Cil_types.logic_type -> bool
val is_array_type : Cil_types.logic_type -> bool
val is_pointer_type : Cil_types.logic_type -> bool
val is_list_type : Cil_types.logic_type -> boolval type_of_list_elem : Cil_types.logic_type -> Cil_types.logic_typeval type_of_pointed : Cil_types.logic_type -> Cil_types.logic_type
val type_of_array_elem : Cil_types.logic_type -> Cil_types.logic_type
val type_of_set_elem : Cil_types.logic_type -> Cil_types.logic_type
val ctype_of_pointed : Cil_types.logic_type -> Cil_types.typ
val ctype_of_array_elem : Cil_types.logic_type -> Cil_types.typ
val add_offset_lval : Cil_types.term_offset -> Cil_types.term_lval -> Cil_types.term_lvalval arithmetic_conversion : Cil_types.logic_type -> Cil_types.logic_type -> Cil_types.logic_type
module Lenv:sig..end
type type_namespace =
| |
Typedef |
|||
| |
Struct |
|||
| |
Union |
|||
| |
Enum |
(* |
The different namespaces a C type can belong to, used when we are searching
a type by its name.
| *) |
module Type_namespace:Datatype.Swith type t = type_namespace
type typing_context = {
|
is_loop : |
|||
|
anonCompFieldName : |
|||
|
conditionalConversion : |
|||
|
find_macro : |
|||
|
find_var : |
|||
|
find_enum_tag : |
|||
|
find_comp_field : |
|||
|
find_type : |
|||
|
find_label : |
|||
|
remove_logic_function : |
|||
|
remove_logic_type : |
|||
|
remove_logic_ctor : |
|||
|
add_logic_function : |
|||
|
add_logic_type : |
|||
|
add_logic_ctor : |
|||
|
find_all_logic_functions : |
|||
|
find_logic_type : |
|||
|
find_logic_ctor : |
|||
|
pre_state : |
|||
|
post_state : |
|||
|
assigns_env : |
|||
|
silent : |
|||
|
type_predicate : |
(* |
typechecks a predicate. Note that the first argument is itself a
typing_context, which allows for open recursion. Namely, it is
possible for the extension to change the type-checking functions for
the sub-nodes of the parsed tree, and not only for the toplevel lexpr.Consult the Plugin Development Guide for additional details. | *) |
|
type_term : |
|||
|
type_assigns : |
|||
|
error : |
val register_behavior_extension : string ->
(typing_context:typing_context ->
loc:Cil_types.location ->
Logic_ptree.lexpr list -> Cil_types.acsl_extension_kind) ->
unitregister_behavior_extension name f registers a typing function f to
be used to type clause with name name.
Here is a basic example:
let count = ref 0 in
let foo_typer ~typing_context ~loc ps =
match ps with p::[] ->
Ext_preds
(typing_context.type_predicate
typing_context
(typing_context.post_state [Normal])
p))
| [] -> let id = !count in incr count; Ext_id id
| _ -> typing_context.error loc "expecting a predicate after keyword FOO"
let () = register_behavior_extension "FOO" foo_typermodule Make:functor (C:sigval is_loop :unit -> boolwhether the annotation we want to type is contained in a loop. Only useful when creating objects of typecode_annotation.
val anonCompFieldName :stringval conditionalConversion :Cil_types.typ -> Cil_types.typ -> Cil_types.typval find_macro :string -> Logic_ptree.lexprval find_var :string -> Cil_types.logic_varval find_enum_tag :string -> Cil_types.exp * Cil_types.typval find_type :Logic_typing.type_namespace -> string -> Cil_types.typval find_comp_field :Cil_types.compinfo -> string -> Cil_types.offsetval find_label :string -> Cil_types.stmt Pervasives.refval remove_logic_function :string -> unitval remove_logic_type :string -> unitval remove_logic_ctor :string -> unitval add_logic_function :Cil_types.logic_info -> unitval add_logic_type :string -> Cil_types.logic_type_info -> unitval add_logic_ctor :string -> Cil_types.logic_ctor_info -> unitval find_all_logic_functions :string -> Cil_types.logic_info listval find_logic_type :string -> Cil_types.logic_type_infoval find_logic_ctor :string -> Cil_types.logic_ctor_infoval integral_cast :Cil_types.typ -> Cil_types.term -> Cil_types.termWhat to do when we have a term of type Integer in a context expecting a C integral type.
Since Nitrogen-20111001
RaisesFailureto reject such conversion
val error :Cil_types.location ->
('a, Format.formatter, unit, 'b) Pervasives.format4 -> 'araises an error at the given location and with the given message.
Since Magnesium-20151001
end) ->sig..end
val append_old_and_post_labels : Lenv.t -> Lenv.tval append_here_label : Lenv.t -> Lenv.tval append_pre_label : Lenv.t -> Lenv.tval append_init_label : Lenv.t -> Lenv.tval add_var : string -> Cil_types.logic_var -> Lenv.t -> Lenv.tval add_result : Lenv.t -> Cil_types.logic_type -> Lenv.t\result in the environment.val enter_post_state : Lenv.t -> Cil_types.termination_kind -> Lenv.tval post_state_env : Cil_types.termination_kind -> Cil_types.logic_type -> Lenv.t\result in the env.
NB: if the kind of the post-state is neither Normal nor Returns,
this is not a normal ACSL environment. Use with caution.