-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathexplode.ml
52 lines (46 loc) · 1.73 KB
/
explode.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
(***********************************************************************)
(* *)
(* HEVEA *)
(* *)
(* Luc Maranget, projet Moscova, INRIA Rocquencourt *)
(* *)
(* Copyright 2001 Institut National de Recherche en Informatique et *)
(* Automatique. Distributed only by permission. *)
(* *)
(* $Id: explode.ml,v 1.7 2012-06-05 14:55:39 maranget Exp $ *)
(***********************************************************************)
open Htmltext
open Tree
let of_styles env r = match env with
| [] -> r
| _ -> Node (env,[r])
let rec tree env t k = match t with
| Text s ->
of_styles env (Text s)::k
| Blanks s ->
of_styles
(List.filter (fun s -> not (Htmltext.blanksNeutral s)) env)
(Blanks s)::
k
| Node (s,ts) ->
begin try
let new_env = Htmltext.add_style s env in
List.fold_right (tree new_env) ts k
with
| Split (s,env) ->
let ts = List.fold_right (tree []) ts [] in
let now =
if Util.is_blanks ts then
(List.filter (fun s -> not (Htmltext.blanksNeutral s)) env)
else
env in
match ts with
| [] -> k
| _ ->
of_styles now (Node ([s],ts))::k
end
| ONode (so,sc,ts) ->
of_styles env
(ONode
(so,sc, List.fold_right (tree []) ts []))::k
let trees ts = List.fold_right (tree []) ts []