12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576(**************************************************************************)(* *)(* SPDX-License-Identifier LGPL-2.1 *)(* Copyright (C) *)(* CEA (Commissariat à l'énergie atomique et aux énergies alternatives) *)(* *)(**************************************************************************)moduleTable=Datatype.String.Hashtblletvarinfos=Table.create13letlogic_functions=Table.create13letaxiomatics=Table.create13letget_variablenamemake=ifTable.memvarinfosnamethenTable.findvarinfosnameelsebegintryGlobals.Vars.find_from_astinfonameGlobalwithNot_found->letvi=make()inTable.addvarinfosnamevi;viendletget_logic_functionnamemake=ifTable.memlogic_functionsnamethenTable.findlogic_functionsnameelsebeginmatchLogic_env.find_all_logic_functionsnamewith|[]->letli=make()inTable.addlogic_functionsnameli;Logic_utils.add_logic_functionli;li|[x]->x|_::_->Options.not_yet_implemented"Logic function overloading"endletin_axiomatic_functions=Table.create13letget_logic_function_in_axiomaticnamemake=ifTable.memin_axiomatic_functionsnamethenTable.findin_axiomatic_functionsnameelsebeginletmake_then_findname=letopenCil_typesinlet(ax_name,ax_list),functions=make()inList.iter(funf->Table.addin_axiomatic_functionsf.l_var_info.lv_namef;Logic_utils.add_logic_functionf)functions;Table.addaxiomaticsax_nameax_list;Table.findin_axiomatic_functionsnameintrymatchLogic_env.find_all_logic_functionsnamewith|[]->make_then_findname|[x]->x|_::_->Options.not_yet_implemented"Logic function overloading"withNot_found->Options.fatal"Failed to build %s"nameendletclear()=Table.clearvarinfosletglobalsloc=letopenCil_typesinletl=[]inletl=Table.fold(fun_xl->GVarDecl(x,loc)::l)varinfoslinletannotxloc=GAnnot(x,loc)inletfun_or_predxloc=annot(Dfun_or_pred(x,loc))locinletaxiomaticnamelistloc=annot(Daxiomatic(name,list,[],loc))locinletl=Table.fold(fun_xl->fun_or_predxloc::l)logic_functionslinletl=Table.fold(funnxl->axiomaticnxloc::l)axiomaticslinl