Newer
Older
(**************************************************************************)
(* *)
(* This file is part of WP plug-in of Frama-C. *)
(* *)
(* Copyright (C) 2007-2021 *)
(* CEA (Commissariat a l'energie atomique et aux energies *)
(* 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 Tactical
let condition original p = (* keep original kind of simple condition *)
match original.condition with
| Type _ -> Type p
| Have _ -> Have p
| When _ -> When p
| Core _ -> Core p
| Init _ -> Init p
| _ -> assert false
let tactical_step step =
Tactical.replace_single ~at:step.id ("Removed", Conditions.Have Lang.F.p_true)
module TermLset = Qed.Listset.Make(Lang.F.QED.Term)
let remove = List.sort_uniq Lang.F.compare remove in
let collect p =
| _ -> [ p ]
in
begin match step.condition with
| Type p | Have p | When p | Core p | Init p ->
let ps = Lang.F.e_props @@ collect p in
let cond = condition step @@ Lang.F.p_bool @@ Lang.F.e_and ps in
Tactical.replace_single ~at:step.id ("Filtered", cond)
| _ -> raise Not_found
end
module Smap = Qed.Idxmap.Make
(struct
type t = step
let id s = s.id
end)
let collect_remove m = function
| Inside(Step step, remove) ->
let l =
try Smap.find step m
with Not_found -> []
in
Smap.add step (remove :: l) m
| _ -> raise Not_found
let fold_selection s seq =
let m = List.fold_left collect_remove Smap.empty s in
"Filtered", Smap.fold (fun s l seq -> snd @@ tactical_inside s l seq) m seq
let process (f: sequent -> string * sequent) s = [ f s ]
class clear =
object(_)
inherit Tactical.make ~id:"Wp.clear"
~title:"Clear"
~params:[]
method select _feedback sel =
match sel with
| Clause(Step step) ->
begin
try Applicable(process @@ tactical_inside step [remove])
with Not_found -> Not_applicable
| Multi es ->
Applicable (process @@ fold_selection es)
end
let tactical = Tactical.export (new clear)