package goblint
Static analysis framework for C
Install
Dune Dependency
Authors
Maintainers
Sources
goblint-2.5.0.tbz
sha256=452d8491527aea21f2cbb11defcc14ba0daf9fdb6bdb9fc0af73e56eac57b916
sha512=1993cd45c4c7fe124ca6e157f07d17ec50fab5611b270a434ed1b7fb2910aa85a8e6eaaa77dad770430710aafb2f6d676c774dd33942d921f23e2f9854486551
doc/goblint.lib/Goblint_lib/WideningTokenLifter/index.html
Module Goblint_lib.WideningTokenLifter
Widening tokens are a generic and dynamic mechanism for delaying widening.
All abstract elements carry a set of tokens, which analyses can add into. Lifted abstract elements are only widened if the token set does not increase, i.e. adding a widening token delays a widening.
module Token = WideningToken
module TS : sig ... end
Widening token set.
val add_ref : (Token.t -> unit) Stdlib.ref
val add : Token.t -> unit
Add widening token to local state.
val side_tokens : TS.t Stdlib.ref
val with_side_token : TS.elt -> (unit -> 'a) -> 'a
with_side_token t f
adds widening token t
to all side effects in f
.
val with_side_tokens : TS.t -> (unit -> 'a) -> 'a
with_side_tokens ts f
adds widening tokens ts
to all side effects in f
.
with_local_side_tokens f
adds all widening tokens from local state to all side effects in f
.
Lift D
to carry widening tokens. All operations delegate to inner domain, except widening tokens are used to delay widenings.
module Lifter (S : Analyses.Spec) : Analyses.Spec
Lift S
to carry widening tokens with both local and global states.
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>