package goblint
Static analysis framework for C
Install
Dune Dependency
Authors
Maintainers
Sources
goblint-2.0.1.tbz
sha256=dba2b664c7c125687e708e871d83fbfb6ba6d9ee98d235b4850d9a238caa84de
sha512=529987cde39691ad9e955000a3603e89c1c8cf14ed5e8b4cd3a7fc26e47d016aff571b472e2329725133c46f8d0cb45a05b88994eeffaa221a4d31b4c543adcd
doc/goblint.lib/Goblint_lib/Uninit/Spec/index.html
Module Uninit.Spec
include module type of struct include Analyses.DefaultSpec end
module G = Goblint_lib.Analyses.DefaultSpec.G
module V = Goblint_lib.Analyses.DefaultSpec.V
val vdecl : ('a, 'b, 'c, 'd) Analyses.ctx -> 'e -> 'a
val asm : ('a, 'b, 'c, 'd) Analyses.ctx -> 'a
val skip : ('a, 'b, 'c, 'd) Analyses.ctx -> 'a
val query : 'b -> 'a Queries.t -> 'a
val event : ('a, 'b, 'c, 'd) Analyses.ctx -> 'e -> 'f -> 'a
val sync : ('a, 'b, 'c, 'd) Analyses.ctx -> 'e -> 'a
module A = Goblint_lib.Analyses.DefaultSpec.A
module Addr = Goblint_lib.ValueDomain.Addr
module D = ValueDomain.AddrSetDomain
module C = ValueDomain.AddrSetDomain
type trans_in = D.t
type trans_out = D.t
val startstate : 'a -> D.t
val threadenter : 'a -> 'b -> 'c -> 'd -> D.t list
val threadspawn : ('a, 'b, 'c, 'd) Analyses.ctx -> 'e -> 'f -> 'g -> 'h -> 'a
val exitstate : 'a -> D.t
val conv_offset :
[< `Field of 'b * 'a | `Index of Prelude.Ana.exp * 'a | `NoOffset ] as 'a ->
[> `Field of 'b * 'c | `Index of IntDomain.IntDomTuple.t * 'c | `NoOffset ] as 'c
val access_address :
Queries.ask ->
'a ->
Prelude.Ana.lval ->
(CilType.Varinfo.t
* [> `Field of CilType.Fieldinfo.t * 'b
| `Index of IntDomain.IntDomTuple.t * 'b
| `NoOffset ] as 'b
* 'a)
list
val access_one_byval :
Queries.ask ->
bool ->
Prelude.Ana.exp ->
(CilType.Varinfo.t
* [> `Field of CilType.Fieldinfo.t * 'a
| `Index of IntDomain.IntDomTuple.t * 'a
| `NoOffset ] as 'a
* bool)
list
val access_lv_byval :
Queries.ask ->
Prelude.Ana.lval ->
(CilType.Varinfo.t
* [> `Field of CilType.Fieldinfo.t * 'a
| `Index of IntDomain.IntDomTuple.t * 'a
| `NoOffset ] as 'a
* bool)
list
val varoffs :
Queries.ask ->
Prelude.Ana.exp ->
(CilType.Varinfo.t
* [> `Field of CilType.Fieldinfo.t * 'a
| `Index of IntDomain.IntDomTuple.t * 'a
| `NoOffset ] as 'a)
list
val vars : Queries.ask -> Prelude.Ana.exp -> Addr.t list
val is_prefix_of :
(Prelude.Ana.varinfo * (Addr.field, Addr.idx) Lval.offs) ->
(Prelude.Ana.varinfo * (Addr.field, Addr.idx) Lval.offs) ->
bool
val is_expr_initd : Queries.ask -> Prelude.Ana.exp -> D.t -> bool
val remove_if_prefix :
(Prelude.Ana.varinfo * (Addr.field, Addr.idx) Lval.offs) ->
D.t ->
D.t
type lval_offs = (Addr.field, Addr.idx) Lval.offs
type var_offs = Prelude.Ana.varinfo * lval_offs
val get_pfx :
Prelude.Ana.varinfo ->
lval_offs ->
lval_offs ->
Prelude.Ana.typ ->
Prelude.Ana.typ ->
var_offs list
val init_lval : Queries.ask -> Prelude.Ana.lval -> D.t -> D.t
val to_addrs : Prelude.Ana.varinfo -> Addr.t list
val remove_unreachable : Queries.ask -> Prelude.Ana.exp list -> D.t -> D.t
val assign :
(D.t, 'a, 'b, 'c) Analyses.ctx ->
Prelude.Ana.lval ->
Prelude.Ana.exp ->
trans_out
val branch :
(D.t, 'a, 'b, 'c) Analyses.ctx ->
Prelude.Ana.exp ->
bool ->
trans_out
val body : (D.t, 'a, 'b, 'c) Analyses.ctx -> Prelude.Ana.fundec -> trans_out
val return :
(D.t, 'a, 'b, 'c) Analyses.ctx ->
Prelude.Ana.exp option ->
Prelude.Ana.fundec ->
trans_out
val enter :
(D.t, 'a, 'b, 'c) Analyses.ctx ->
Prelude.Ana.lval option ->
Prelude.Ana.fundec ->
Prelude.Ana.exp list ->
(D.t * D.t) list
val combine :
(D.t, 'a, 'b, 'c) Analyses.ctx ->
Prelude.Ana.lval option ->
'd ->
Prelude.Ana.fundec ->
Prelude.Ana.exp list ->
'e ->
D.t ->
trans_out
val special :
(D.t, 'a, 'b, 'c) Analyses.ctx ->
Prelude.Ana.lval option ->
Prelude.Ana.varinfo ->
Prelude.Ana.exp list ->
D.t
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>