package goblint
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Static analysis framework for C
Install
dune-project
Dependency
Authors
Maintainers
Sources
goblint-2.7.1.tbz
sha256=af01aac256229f33a90a9fcbfed04b01e3097f154d4d124f006476d6387c6a66
sha512=2a93bfe16881adbc2d8dcbfe38c1e19cd24ca105d8e1eda13d02440f3002874ffe2957dfd937510765233a054a40568b0052db92e31d382a5bd215d1ec12565c
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 = WideningTokenmodule TS : sig ... endWidening token set.
val add_ref : (Token.t -> unit) Domain.DLS.keyval add : Token.t -> unitAdd widening token to local state.
val with_side_token : TS.elt -> (unit -> 'a) -> 'awith_side_token t f adds widening token t to all side effects in f.
val with_side_tokens : TS.t -> (unit -> 'a) -> 'awith_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.SpecLift S to carry widening tokens with both local and global states.
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>