File: find_enclosing_loop.ml

package info (click to toggle)
frama-c 20161101%2Bsilicon%2Bdfsg-5
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 42,324 kB
  • ctags: 35,695
  • sloc: ml: 200,142; ansic: 31,465; makefile: 2,334; sh: 1,643; lisp: 259; python: 85; asm: 26
file content (33 lines) | stat: -rw-r--r-- 818 bytes parent folder | download | duplicates (2)
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
open Cil
open Cil_types

class check =
object(self)
  inherit Visitor.frama_c_inplace
  val current_loop = Stack.create ()
  method vstmt_aux s =
    let res =
      match s.skind with
        | Loop _ -> Stack.push s current_loop; 
            ChangeDoChildrenPost
              (s, 
               fun s -> ignore (Stack.pop current_loop); s)
        | _ -> DoChildren
    in
    let has_loop =
      try
        Some 
          (Kernel_function.find_enclosing_loop (Extlib.the self#current_kf) s)
      with Not_found -> None
    in
    (match has_loop with
      | Some s -> assert (s == Stack.top current_loop)
      | None -> assert (Stack.is_empty current_loop));
    res
end

let run () =
  Visitor.visitFramacFileSameGlobals (new check) (Ast.get());
  Kernel.result "Script done"

let () = Db.Main.extend run