-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathByteViewEngine.fs
172 lines (161 loc) · 7.09 KB
/
ByteViewEngine.fs
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
module ByteViewEngine
open System.Text
open System.IO
open System
open System.Xml
type Stream with
member inline x.Write(buffer:byte []) = x.Write(buffer,0,buffer.Length)
member inline x.Write(value:string) = let buffer = value |> Encoding.UTF8.GetBytes in x.Write(buffer,0,buffer.Length)
type VNode = (list<Stream -> unit>) -> Stream -> unit
type PNode = (list<Stream -> unit>) -> VNode
let attrClosetTag = ">" |> Encoding.UTF8.GetBytes
let voidCloseTag = " />" |> Encoding.UTF8.GetBytes
let commentOpenTag = "<!-- " |> Encoding.UTF8.GetBytes
let commentCloseTag = " -->" |> Encoding.UTF8.GetBytes
let equalsTag = "=" |> Encoding.UTF8.GetBytes
let attr (key:string) (value:string) (wr:Stream) =
key |> Encoding.UTF8.GetBytes |> wr.Write
wr.Write(equalsTag,0,equalsTag.Length)
value |> Encoding.UTF8.GetBytes |> wr.Write
let attrbool (key:string) (wr:Stream) =
wr.Write key
let parentNode (tag:string) : (list<Stream -> unit>) -> (list<Stream -> unit>) -> Stream -> unit =
let opentag = ("<" + tag) |> Encoding.UTF8.GetBytes
let closetag = ("</" + tag + ">") |> Encoding.UTF8.GetBytes
fun (attrs:list<Stream -> unit>) (children:list<Stream -> unit>) (wr:Stream) ->
wr.Write (opentag,0,opentag.Length)
for attr in attrs do
attr wr
wr.Write attrClosetTag
for child in children do
child wr
wr.Write closetag
let voidNode (tag:string) : ((Stream -> unit) list) -> Stream -> unit =
let opentag = ("<" + tag) |> Encoding.UTF8.GetBytes
fun (attrs:(Stream -> unit) list) (wr:Stream) ->
wr.Write opentag
for attr in attrs do
attr wr
wr.Write voidCloseTag
let encodedText (txt:string) (wr:Stream) = wr.Write txt // include encoder
let rawText (txt:string) (wr:Stream) = wr.Write txt
let comment (txt:string) (wr:Stream) =
wr.Write commentOpenTag
wr.Write txt
wr.Write commentCloseTag
let html : PNode = parentNode "html"
let ``base`` : VNode = voidNode "base"
let head : PNode = parentNode "head"
let link : VNode = voidNode "link"
let meta : VNode = voidNode "meta"
let style : PNode = parentNode "style"
let title : PNode = parentNode "title"
let body : PNode = parentNode "body"
let address : PNode = parentNode "address"
let article : PNode = parentNode "article"
let aside : PNode = parentNode "aside"
let footer : PNode = parentNode "footer"
let hgroup : PNode = parentNode "hgroup"
let h1 : PNode = parentNode "h1"
let h2 : PNode = parentNode "h2"
let h3 : PNode = parentNode "h3"
let h4 : PNode = parentNode "h4"
let h5 : PNode = parentNode "h5"
let h6 : PNode = parentNode "h6"
let header : PNode = parentNode "header"
let nav : PNode = parentNode "nav"
let section : PNode = parentNode "section"
let dd : PNode = parentNode "dd"
let div : PNode = parentNode "div"
let dl : PNode = parentNode "dl"
let dt : PNode = parentNode "dt"
let figcaption : PNode = parentNode "figcaption"
let figure : PNode = parentNode "figure"
let hr : VNode = voidNode "hr"
let li : PNode = parentNode "li"
let main : PNode = parentNode "main"
let ol : PNode = parentNode "ol"
let p : PNode = parentNode "p"
let pre : PNode = parentNode "pre"
let ul : PNode = parentNode "ul"
let a : PNode = parentNode "a"
let abbr : PNode = parentNode "abbr"
let b : PNode = parentNode "b"
let bdi : PNode = parentNode "bdi"
let bdo : PNode = parentNode "bdo"
let br : VNode = voidNode "br"
let cite : PNode = parentNode "cite"
let code : PNode = parentNode "code"
let data : PNode = parentNode "data"
let dfn : PNode = parentNode "dfn"
let em : PNode = parentNode "em"
let i : PNode = parentNode "i"
let kbd : PNode = parentNode "kbd"
let mark : PNode = parentNode "mark"
let q : PNode = parentNode "q"
let rp : PNode = parentNode "rp"
let rt : PNode = parentNode "rt"
let rtc : PNode = parentNode "rtc"
let ruby : PNode = parentNode "ruby"
let s : PNode = parentNode "s"
let samp : PNode = parentNode "samp"
let small : PNode = parentNode "small"
let span : PNode = parentNode "span"
let strong : PNode = parentNode "strong"
let sub : PNode = parentNode "sub"
let sup : PNode = parentNode "sup"
let time : PNode = parentNode "time"
let u : PNode = parentNode "u"
let var : PNode = parentNode "var"
let wbr : VNode = voidNode "wbr"
let area : VNode = voidNode "area"
let audio : PNode = parentNode "audio"
let img : VNode = voidNode "img"
let map : PNode = parentNode "map"
let track : VNode = voidNode "track"
let video : PNode = parentNode "video"
let embed : VNode = voidNode "embed"
let object : PNode = parentNode "object"
let param : VNode = voidNode "param"
let source : VNode = voidNode "source"
let canvas : PNode = parentNode "canvas"
let noscript : PNode = parentNode "noscript"
let script : PNode = parentNode "script"
let del : PNode = parentNode "del"
let ins : PNode = parentNode "ins"
let caption : PNode = parentNode "caption"
let col : VNode = voidNode "col"
let colgroup : PNode = parentNode "colgroup"
let table : PNode = parentNode "table"
let tbody : PNode = parentNode "tbody"
let td : PNode = parentNode "td"
let tfoot : PNode = parentNode "tfoot"
let th : PNode = parentNode "th"
let thead : PNode = parentNode "thead"
let tr : PNode = parentNode "tr"
let button : PNode = parentNode "button"
let datalist : PNode = parentNode "datalist"
let fieldset : PNode = parentNode "fieldset"
let form : PNode = parentNode "form"
let input : VNode = voidNode "input"
let label : PNode = parentNode "label"
let legend : PNode = parentNode "legend"
let meter : PNode = parentNode "meter"
let optgroup : PNode = parentNode "optgroup"
let option : PNode = parentNode "option"
let output : PNode = parentNode "output"
let progress : PNode = parentNode "progress"
let select : PNode = parentNode "select"
let textarea : PNode = parentNode "textarea"
let details : PNode = parentNode "details"
let dialog : PNode = parentNode "dialog"
let menu : PNode = parentNode "menu"
let menuitem : VNode = voidNode "menuitem"
let summary : PNode = parentNode "summary"
//////////////
let private docTypeTag = "<!DOCTYPE html>" |> Encoding.UTF8.GetBytes
let private newLineTag = Environment.NewLine |> Encoding.UTF8.GetBytes
let renderHtmlDocument ( document : Stream -> unit ) (writer : Stream) =
writer.Write docTypeTag
document writer
writer.Write newLineTag