aboutsummaryrefslogtreecommitdiff
path: root/core/encoding/entity/example/entity_example.odin
blob: 8758d9ad915fdad58863112d97595dec49d53e99 (plain)
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
package unicode_entity_example

import "core:encoding/xml"
import "core:encoding/entity"
import "core:strings"
import "core:mem"
import "core:fmt"
import "core:time"

OPTIONS  :: xml.Options{
	flags            = {
		.Ignore_Unsupported, .Intern_Comments,
	},
	expected_doctype = "",
}

doc_print :: proc(doc: ^xml.Document) {
	buf: strings.Builder
	defer strings.destroy_builder(&buf)
	w := strings.to_writer(&buf)

	xml.print(w, doc)
	fmt.println(strings.to_string(buf))
}

_entities :: proc() {
	doc: ^xml.Document
	err: xml.Error

	DOC :: #load("../../../../tests/core/assets/XML/unicode.xml")

	parse_duration: time.Duration

	{
		time.SCOPED_TICK_DURATION(&parse_duration)
		doc, err = xml.parse(DOC, OPTIONS)
	}
	defer xml.destroy(doc)

	doc_print(doc)

	ms := time.duration_milliseconds(parse_duration)

	speed := (f64(1000.0) / ms) * f64(len(DOC)) / 1_024.0 / 1_024.0

	fmt.printf("Parse time: %.2f ms (%.2f MiB/s).\n", ms, speed)
	fmt.printf("Error: %v\n", err)
}

_main :: proc() {
	using fmt

	doc, err := xml.parse(#load("test.html"))
	defer xml.destroy(doc)
	doc_print(doc)

	if false {
		val := doc.root.children[1].children[2].value

		println()
		replaced, ok := entity.decode_xml(val)
		defer delete(replaced)

		printf("Before:      '%v', Err: %v\n", val, err)
		printf("Passthrough: '%v'\nOK: %v\n", replaced, ok)
		println()
	}

	if false {
		val := doc.root.children[1].children[2].value

		println()
		replaced, ok := entity.decode_xml(val, { .CDATA_Unbox })
		defer delete(replaced)

		printf("Before:      '%v', Err: %v\n", val, err)
		printf("CDATA_Unbox: '%v'\nOK: %v\n", replaced, ok)
		println()
	}

	if true {
		val := doc.root.children[1].children[2].value

		println()
		replaced, ok := entity.decode_xml(val, { .CDATA_Unbox, .CDATA_Decode })
		defer delete(replaced)

		printf("Before: '%v', Err: %v\n", val, err)
		printf("CDATA_Decode: '%v'\nOK: %v\n", replaced, ok)
		println()
	}

	if true {
		val := doc.root.children[1].children[1].value

		println()
		replaced, ok := entity.decode_xml(val, { .Comment_Strip })
		defer delete(replaced)

		printf("Before: '%v', Err: %v\n", val, err)
		printf("Comment_Strip: '%v'\nOK: %v\n", replaced, ok)
		println()
	}
}

main :: proc() {
	using fmt

	track: mem.Tracking_Allocator
	mem.tracking_allocator_init(&track, context.allocator)
	context.allocator = mem.tracking_allocator(&track)

	_main()
	//_entities()

	if len(track.allocation_map) > 0 {
		println()
		for _, v in track.allocation_map {
			printf("%v Leaked %v bytes.\n", v.location, v.size)
		}
	}	
}