package frama-c
Platform dedicated to the analysis of source code written in C
Install
Dune Dependency
Authors
-
MMichele Alberti
-
TThibaud Antignac
-
GGergö Barany
-
PPatrick Baudin
-
NNicolas Bellec
-
TThibaut Benjamin
-
AAllan Blanchard
-
LLionel Blatter
-
FFrançois Bobot
-
RRichard Bonichon
-
VVincent Botbol
-
QQuentin Bouillaguet
-
DDavid Bühler
-
ZZakaria Chihani
-
LLoïc Correnson
-
JJulien Crétin
-
PPascal Cuoq
-
ZZaynah Dargaye
-
BBasile Desloges
-
JJean-Christophe Filliâtre
-
PPhilippe Herrmann
-
MMaxime Jacquemin
-
FFlorent Kirchner
-
AAlexander Kogtenkov
-
RRemi Lazarini
-
TTristan Le Gall
-
JJean-Christophe Léchenet
-
MMatthieu Lemerre
-
DDara Ly
-
DDavid Maison
-
CClaude Marché
-
AAndré Maroneze
-
TThibault Martin
-
FFonenantsoa Maurica
-
MMelody Méaulle
-
BBenjamin Monate
-
YYannick Moy
-
PPierre Nigron
-
AAnne Pacalet
-
VValentin Perrelle
-
GGuillaume Petiot
-
DDario Pinto
-
VVirgile Prevosto
-
AArmand Puccetti
-
FFélix Ridoux
-
VVirgile Robles
-
JJan Rochel
-
MMuriel Roger
-
JJulien Signoles
-
NNicolas Stouls
-
KKostyantyn Vorobyov
-
BBoris Yakobowski
Maintainers
Sources
frama-c-29.0-Copper.tar.gz
sha256=d2fbb3b8d0ff83945872e9e6fa258e934a706360e698dae3b4d5f971addf7493
doc/src/frama-c-instantiate.core/instantiator_builder.ml.html
Source file instantiator_builder.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
(**************************************************************************) (* *) (* This file is part of Frama-C. *) (* *) (* Copyright (C) 2007-2024 *) (* CEA (Commissariat à l'énergie atomique et aux énergies *) (* alternatives) *) (* *) (* you can redistribute it and/or modify it under the terms of the GNU *) (* Lesser General Public License as published by the Free Software *) (* Foundation, version 2.1. *) (* *) (* It is distributed in the hope that it will be useful, *) (* but WITHOUT ANY WARRANTY; without even the implied warranty of *) (* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *) (* GNU Lesser General Public License for more details. *) (* *) (* See the GNU Lesser General Public License version 2.1 *) (* for more details (enclosed in the file licenses/LGPLv2.1). *) (* *) (**************************************************************************) open Cil_types open Basic_blocks module type Generator_sig = sig module Hashtbl: Datatype.Hashtbl type override_key = Hashtbl.key val function_name: string val well_typed_call: lval option -> varinfo -> exp list -> bool val key_from_call: lval option -> varinfo -> exp list -> override_key val retype_args: override_key -> exp list -> exp list val args_for_original: override_key -> exp list -> exp list val generate_prototype: override_key -> (string * typ) val generate_spec: override_key -> location -> fundec -> funspec end module type Instantiator = sig module Enabled: Parameter_sig.Bool type override_key val function_name: string val well_typed_call: lval option -> varinfo -> exp list -> bool val key_from_call: lval option -> varinfo -> exp list -> override_key val retype_args: override_key -> exp list -> exp list val get_override: override_key -> fundec val get_kfs: unit -> kernel_function list val clear: unit -> unit end let build_body caller callee args_generator = let loc = Cil_datatype.Location.unknown in let ret_var = match Cil.getReturnType caller.svar.vtype with | t when Cil.isVoidType t -> None | t -> Some (Cil.makeLocalVar caller "__retres" t) in let call = let args = List.map Cil.evar caller.sformals in let args = args_generator args in Cil.mkStmt (Instr(call_function (Option.map Cil.var ret_var) callee args)) in let ret = Cil.mkStmt (Return (Option.map Cil.evar ret_var, loc)) in { (Cil.mkBlock [call ; ret]) with blocals = Option.to_list ret_var } module Make_instantiator (G: Generator_sig) = struct include G module Enabled = Options.NewInstantiator (G) module Cache = struct let tbl = G.Hashtbl.create 13 let find = G.Hashtbl.find tbl let add = G.Hashtbl.add tbl let fold f = G.Hashtbl.fold f tbl let clear () = G.Hashtbl.clear tbl end let make_fundec key = let open Globals.Functions in let (name, typ) = G.generate_prototype key in let fd = Basic_blocks.prepare_definition name typ in let orig = get_vi (find_by_name function_name) in let sbody = build_body fd orig (G.args_for_original key) in let fd = { fd with sbody } in Cfg.cfgFun fd ; fd let build_function key = let loc = Cil_datatype.Location.unknown in let fd = make_fundec key in let spec = Cil.empty_funspec () in Globals.Functions.replace_by_definition spec fd loc ; let kf = Globals.Functions.get fd.svar in let spec = generate_spec key loc fd in Annotations.add_behaviors Options.emitter kf spec.spec_behavior ; List.iter (Annotations.add_complete Options.emitter kf) spec.spec_complete_behaviors ; List.iter (Annotations.add_disjoint Options.emitter kf) spec.spec_disjoint_behaviors ; fd let get_override key = try Cache.find key with Not_found -> let fd = build_function key in Cache.add key fd ; fd (* If you use this before finalization, you'll have problems *) let get_kfs () = Cache.fold (fun _ fd l -> Globals.Functions.get fd.svar :: l) [] let clear () = Cache.clear () end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>