# line 1 "markup.rl"
# Copyright, 2016, by Samuel G. D. Williams. <http://www.codeotaku.com>
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE.
# line 207 "markup.rl"
require_relative '../error'
module Trenni
module Fallback
# line 33 "markup.rb"
class << self
attr_accessor :_markup_trans_keys
private :_markup_trans_keys, :_markup_trans_keys=
end
self._markup_trans_keys = [
0, 0, 0, 127, 0, 127,
0, 127, 0, 127, 62,
62, 34, 39, 34, 60,
34, 60, 9, 62, 34, 60,
9, 62, 38, 60, 38,
60, 38, 60, 45, 91,
45, 45, 45, 45, 45, 45,
45, 62, 79, 79, 67,
67, 84, 84, 89, 89,
80, 80, 69, 69, 62, 62,
67, 67, 68, 68, 65,
65, 84, 84, 65, 65,
91, 91, 93, 93, 93, 93,
62, 93, 0, 127, 0,
127, 0, 127, 0, 127,
63, 63, 62, 63, 35, 122,
48, 120, 48, 59, 48,
102, 48, 102, 48, 122,
38, 60, 38, 60, 38, 60,
38, 60, 38, 60, 38,
60, 38, 60, 38, 60,
38, 60, 0, 0, 0
]
class << self
attr_accessor :_markup_key_spans
private :_markup_key_spans, :_markup_key_spans=
end
self._markup_key_spans = [
0, 128, 128, 128, 128, 1, 6, 27,
27, 54, 27, 54, 23, 23, 23, 47,
1, 1, 1, 18, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 32, 128, 128, 128, 128,
1, 2, 88, 73, 12, 55, 55, 75,
23, 23, 23, 23, 23, 23, 23, 23,
23, 0
]
class << self
attr_accessor :_markup_index_offsets
private :_markup_index_offsets, :_markup_index_offsets=
end
self._markup_index_offsets = [
0, 0, 129, 258, 387, 516, 518, 525,
553, 581, 636, 664, 719, 743, 767, 791,
839, 841, 843, 845, 864, 866, 868, 870,
872, 874, 876, 878, 880, 882, 884, 886,
888, 890, 892, 894, 927, 1056, 1185, 1314,
1443, 1445, 1448, 1537, 1611, 1624, 1680, 1736,
1812, 1836, 1860, 1884, 1908, 1932, 1956, 1980,
2004, 2028
]
class << self
attr_accessor :_markup_indicies
private :_markup_indicies, :_markup_indicies=
end
self._markup_indicies = [
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 2, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 0, 0, 3,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 1, 1, 1, 1, 4,
1, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 1, 1, 1, 1, 0,
1, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 1, 1, 1, 1, 1,
0, 1, 1, 1, 1, 1, 1, 1,
1, 1, 6, 6, 6, 6, 6, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 6, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 5, 5,
7, 5, 5, 5, 5, 5, 5, 5,
5, 5, 5, 5, 1, 1, 1, 8,
1, 1, 5, 5, 5, 5, 5, 5,
5, 5, 5, 5, 5, 5, 5, 5,
5, 5, 5, 5, 5, 5, 5, 5,
5, 5, 5, 5, 1, 1, 1, 1,
5, 1, 5, 5, 5, 5, 5, 5,
5, 5, 5, 5, 5, 5, 5, 5,
5, 5, 5, 5, 5, 5, 5, 5,
5, 5, 5, 5, 1, 1, 1, 1,
1, 5, 1, 1, 1, 1, 1, 1,
1, 1, 1, 10, 10, 10, 10, 10,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 10, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 9,
9, 11, 9, 9, 9, 9, 9, 9,
9, 9, 9, 9, 9, 1, 1, 1,
12, 1, 1, 9, 9, 9, 9, 9,
9, 9, 9, 9, 9, 9, 9, 9,
9, 9, 9, 9, 9, 9, 9, 9,
9, 9, 9, 9, 9, 1, 1, 1,
1, 9, 1, 9, 9, 9, 9, 9,
9, 9, 9, 9, 9, 9, 9, 9,
9, 9, 9, 9, 9, 9, 9, 9,
9, 9, 9, 9, 9, 1, 1, 1,
1, 1, 9, 1, 1, 1, 1, 1,
1, 1, 1, 1, 14, 14, 14, 14,
14, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 14, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
13, 13, 15, 13, 13, 13, 13, 13,
13, 13, 13, 13, 13, 13, 1, 1,
16, 17, 1, 1, 13, 13, 13, 13,
13, 13, 13, 13, 13, 13, 13, 13,
13, 13, 13, 13, 13, 13, 13, 13,
13, 13, 13, 13, 13, 13, 1, 1,
1, 1, 13, 1, 13, 13, 13, 13,
13, 13, 13, 13, 13, 13, 13, 13,
13, 13, 13, 13, 13, 13, 13, 13,
13, 13, 13, 13, 13, 13, 1, 1,
1, 1, 1, 13, 12, 1, 18, 1,
1, 1, 1, 19, 1, 21, 20, 20,
20, 22, 20, 20, 20, 20, 20, 20,
20, 20, 20, 20, 20, 20, 20, 20,
20, 20, 20, 20, 20, 20, 20, 1,
20, 24, 23, 23, 23, 25, 23, 23,
23, 23, 23, 23, 23, 23, 23, 23,
23, 23, 23, 23, 23, 23, 23, 23,
23, 23, 23, 1, 23, 26, 26, 26,
26, 26, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 26, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 27, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 28, 1, 30, 29, 29, 29,
31, 29, 29, 29, 29, 29, 29, 29,
29, 29, 29, 29, 29, 29, 29, 29,
29, 29, 29, 29, 29, 29, 1, 29,
32, 32, 32, 32, 32, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 32,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 33, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 34, 1, 36,
21, 35, 35, 35, 35, 35, 35, 35,
35, 35, 35, 35, 35, 35, 35, 35,
35, 35, 35, 35, 35, 1, 35, 38,
24, 37, 37, 37, 37, 37, 37, 37,
37, 37, 37, 37, 37, 37, 37, 37,
37, 37, 37, 37, 37, 1, 37, 40,
30, 39, 39, 39, 39, 39, 39, 39,
39, 39, 39, 39, 39, 39, 39, 39,
39, 39, 39, 39, 39, 1, 39, 41,
42, 42, 42, 42, 42, 42, 42, 42,
42, 42, 42, 42, 42, 42, 42, 42,
42, 42, 42, 42, 42, 42, 43, 42,
42, 42, 42, 42, 42, 42, 42, 42,
42, 42, 42, 42, 42, 42, 42, 42,
42, 42, 42, 42, 42, 44, 42, 45,
42, 46, 45, 47, 45, 47, 45, 45,
45, 45, 45, 45, 45, 45, 45, 45,
45, 45, 45, 45, 45, 45, 48, 45,
49, 42, 50, 42, 51, 42, 52, 42,
53, 42, 54, 42, 55, 54, 56, 42,
57, 42, 58, 42, 59, 42, 60, 42,
61, 42, 62, 61, 63, 61, 64, 61,
61, 61, 61, 61, 61, 61, 61, 61,
61, 61, 61, 61, 61, 61, 61, 61,
61, 61, 61, 61, 61, 61, 61, 61,
61, 61, 61, 61, 61, 63, 61, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 65, 65, 1, 65,
65, 65, 65, 65, 65, 65, 65, 65,
65, 65, 1, 1, 1, 1, 1, 1,
65, 65, 65, 65, 65, 65, 65, 65,
65, 65, 65, 65, 65, 65, 65, 65,
65, 65, 65, 65, 65, 65, 65, 65,
65, 65, 1, 1, 1, 1, 65, 1,
65, 65, 65, 65, 65, 65, 65, 65,
65, 65, 65, 65, 65, 65, 65, 65,
65, 65, 65, 65, 65, 65, 65, 65,
65, 65, 1, 1, 1, 1, 1, 65,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 66, 66, 1,
66, 66, 66, 66, 66, 66, 66, 66,
66, 66, 66, 1, 1, 1, 67, 1,
1, 66, 66, 66, 66, 66, 66, 66,
66, 66, 66, 66, 66, 66, 66, 66,
66, 66, 66, 66, 66, 66, 66, 66,
66, 66, 66, 1, 1, 1, 1, 66,
1, 66, 66, 66, 66, 66, 66, 66,
66, 66, 66, 66, 66, 66, 66, 66,
66, 66, 66, 66, 66, 66, 66, 66,
66, 66, 66, 1, 1, 1, 1, 1,
66, 69, 69, 69, 69, 69, 69, 69,
69, 69, 69, 69, 69, 69, 69, 69,
69, 69, 69, 69, 69, 69, 69, 69,
69, 69, 69, 69, 69, 69, 69, 69,
69, 69, 69, 69, 69, 69, 69, 69,
69, 69, 69, 69, 69, 69, 68, 68,
69, 68, 68, 68, 68, 68, 68, 68,
68, 68, 68, 68, 69, 69, 69, 69,
69, 69, 68, 68, 68, 68, 68, 68,
68, 68, 68, 68, 68, 68, 68, 68,
68, 68, 68, 68, 68, 68, 68, 68,
68, 68, 68, 68, 69, 69, 69, 69,
68, 69, 68, 68, 68, 68, 68, 68,
68, 68, 68, 68, 68, 68, 68, 68,
68, 68, 68, 68, 68, 68, 68, 68,
68, 68, 68, 68, 69, 69, 69, 69,
69, 68, 69, 69, 69, 69, 69, 69,
69, 69, 69, 71, 71, 71, 71, 71,
69, 69, 69, 69, 69, 69, 69, 69,
69, 69, 69, 69, 69, 69, 69, 69,
69, 69, 71, 69, 69, 69, 69, 69,
69, 69, 69, 69, 69, 69, 69, 70,
70, 69, 70, 70, 70, 70, 70, 70,
70, 70, 70, 70, 70, 69, 69, 69,
69, 69, 69, 70, 70, 70, 70, 70,
70, 70, 70, 70, 70, 70, 70, 70,
70, 70, 70, 70, 70, 70, 70, 70,
70, 70, 70, 70, 70, 69, 69, 69,
69, 70, 69, 70, 70, 70, 70, 70,
70, 70, 70, 70, 70, 70, 70, 70,
70, 70, 70, 70, 70, 70, 70, 70,
70, 70, 70, 70, 70, 69, 69, 69,
69, 69, 70, 73, 72, 74, 73, 72,
76, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 77, 77, 77,
77, 77, 77, 77, 77, 77, 77, 75,
75, 75, 75, 75, 75, 75, 77, 77,
77, 77, 77, 77, 77, 77, 77, 77,
77, 77, 77, 77, 77, 77, 77, 77,
77, 77, 77, 77, 77, 77, 77, 77,
75, 75, 75, 75, 75, 75, 77, 77,
77, 77, 77, 77, 77, 77, 77, 77,
77, 77, 77, 77, 77, 77, 77, 77,
77, 77, 77, 77, 77, 77, 77, 77,
75, 78, 78, 78, 78, 78, 78, 78,
78, 78, 78, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 79, 75, 80, 80, 80, 80, 80,
80, 80, 80, 80, 80, 75, 81, 75,
82, 82, 82, 82, 82, 82, 82, 82,
82, 82, 75, 75, 75, 75, 75, 75,
75, 82, 82, 82, 82, 82, 82, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 82, 82, 82, 82, 82, 82, 75,
83, 83, 83, 83, 83, 83, 83, 83,
83, 83, 75, 84, 75, 75, 75, 75,
75, 83, 83, 83, 83, 83, 83, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 75, 75, 75, 75, 75, 75, 75,
75, 83, 83, 83, 83, 83, 83, 75,
85, 85, 85, 85, 85, 85, 85, 85,
85, 85, 75, 86, 75, 75, 75, 75,
75, 85, 85, 85, 85, 85, 85, 85,
85, 85, 85, 85, 85, 85, 85, 85,
85, 85, 85, 85, 85, 85, 85, 85,
85, 85, 85, 75, 75, 75, 75, 75,
75, 85, 85, 85, 85, 85, 85, 85,
85, 85, 85, 85, 85, 85, 85, 85,
85, 85, 85, 85, 85, 85, 85, 85,
85, 85, 85, 75, 88, 87, 87, 87,
87, 87, 87, 87, 87, 87, 87, 87,
87, 87, 87, 87, 87, 87, 87, 87,
87, 87, 89, 87, 91, 90, 90, 90,
90, 90, 90, 90, 90, 90, 90, 90,
90, 90, 90, 90, 90, 90, 90, 90,
90, 90, 92, 90, 94, 93, 93, 93,
93, 93, 93, 93, 93, 93, 93, 93,
93, 93, 93, 93, 93, 93, 93, 93,
93, 93, 95, 93, 97, 96, 96, 96,
96, 96, 96, 96, 96, 96, 96, 96,
96, 96, 96, 96, 96, 96, 96, 96,
96, 96, 98, 96, 100, 99, 99, 99,
99, 99, 99, 99, 99, 99, 99, 99,
99, 99, 99, 99, 99, 99, 99, 99,
99, 99, 101, 99, 103, 102, 102, 102,
102, 102, 102, 102, 102, 102, 102, 102,
102, 102, 102, 102, 102, 102, 102, 102,
102, 102, 104, 102, 106, 105, 105, 105,
105, 105, 105, 105, 105, 105, 105, 105,
105, 105, 105, 105, 105, 105, 105, 105,
105, 105, 107, 105, 109, 108, 108, 108,
108, 108, 108, 108, 108, 108, 108, 108,
108, 108, 108, 108, 108, 108, 108, 108,
108, 108, 110, 108, 112, 111, 111, 111,
111, 111, 111, 111, 111, 111, 111, 111,
111, 111, 111, 111, 111, 111, 111, 111,
111, 111, 113, 111, 42, 0
]
class << self
attr_accessor :_markup_trans_targs
private :_markup_trans_targs, :_markup_trans_targs=
end
self._markup_trans_targs = [
2, 0, 15, 36, 38, 2, 3, 5,
51, 4, 3, 5, 51, 4, 3, 5,
6, 51, 7, 12, 8, 11, 10, 8,
9, 10, 3, 5, 51, 8, 9, 10,
3, 5, 51, 13, 14, 13, 14, 13,
14, 16, 0, 20, 27, 17, 18, 19,
52, 21, 22, 23, 24, 25, 26, 53,
28, 29, 30, 31, 32, 33, 34, 35,
54, 37, 37, 55, 39, 0, 39, 40,
40, 41, 56, 0, 43, 47, 44, 45,
44, 57, 46, 46, 57, 47, 57, 49,
50, 1, 49, 50, 1, 49, 50, 1,
49, 50, 1, 49, 50, 1, 49, 50,
1, 49, 50, 1, 49, 50, 1, 49,
50, 1
]
class << self
attr_accessor :_markup_trans_actions
private :_markup_trans_actions, :_markup_trans_actions=
end
self._markup_trans_actions = [
2, 1, 0, 0, 0, 0, 3, 4,
3, 5, 0, 6, 0, 0, 7, 8,
9, 7, 0, 0, 10, 0, 11, 0,
12, 13, 14, 15, 14, 16, 17, 18,
19, 20, 19, 10, 11, 0, 13, 16,
18, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0,
0, 2, 0, 9, 2, 24, 0, 25,
0, 26, 0, 27, 0, 28, 28, 0,
0, 29, 28, 0, 30, 0, 31, 32,
33, 34, 0, 13, 36, 16, 18, 38,
40, 41, 42, 44, 45, 46, 48, 49,
50, 52, 53, 54, 56, 57, 58, 60,
61, 62
]
class << self
attr_accessor :_markup_eof_actions
private :_markup_eof_actions, :_markup_eof_actions=
end
self._markup_eof_actions = [
0, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 0,
0, 21, 21, 21, 0, 0, 0, 0,
0, 0, 22, 0, 0, 0, 0, 0,
0, 23, 23, 23, 1, 1, 24, 24,
24, 24, 27, 27, 27, 27, 27, 27,
0, 35, 37, 39, 43, 47, 51, 55,
59, 0
]
class << self
attr_accessor :markup_start
end
self.markup_start = 48;
class << self
attr_accessor :markup_first_final
end
self.markup_first_final = 48;
class << self
attr_accessor :markup_error
end
self.markup_error = 0;
class << self
attr_accessor :markup_en_parse_entity
end
self.markup_en_parse_entity = 42;
class << self
attr_accessor :markup_en_main
end
self.markup_en_main = 48;
# line 214 "markup.rl"
def self.parse_markup(buffer, delegate, entities)
data = buffer.read
encoding = buffer.encoding
bytes = data.bytes
p = 0
# Must set pe here or it gets incorrectly set to data.length
pe = eof = data.bytesize
stack = []
pcdata = nil
characters_begin = characters_end = nil
entity_begin = entity_end = nil
identifier_begin = identifier_end = nil
doctype_begin = doctype_end = nil
comment_begin = comment_end = nil
instruction_begin = instruction_end = nil
cdata_begin = cdata_end = nil
has_entities = has_value = false
# line 459 "markup.rb"
begin
p ||= 0
pe ||= data.length
cs = markup_start
top = 0
end
# line 236 "markup.rl"
# line 469 "markup.rb"
begin
testEof = false
_slen, _trans, _keys, _inds, _acts, _nacts = nil
_goto_level = 0
_resume = 10
_eof_trans = 15
_again = 20
_test_eof = 30
_out = 40
while true
if _goto_level <= 0
if p == pe
_goto_level = _test_eof
next
end
if cs == 0
_goto_level = _out
next
end
end
if _goto_level <= _resume
_keys = cs << 1
_inds = _markup_index_offsets[cs]
_slen = _markup_key_spans[cs]
_wide = ( bytes[p])
_trans = if ( _slen > 0 &&
_markup_trans_keys[_keys] <= _wide &&
_wide <= _markup_trans_keys[_keys + 1]
) then
_markup_indicies[ _inds + _wide - _markup_trans_keys[_keys] ]
else
_markup_indicies[ _inds + _slen ]
end
cs = _markup_trans_targs[_trans]
if _markup_trans_actions[_trans] != 0
case _markup_trans_actions[_trans]
when 2 then
# line 24 "markup.rl"
begin
identifier_begin = p
end
when 9 then
# line 28 "markup.rl"
begin
identifier_end = p
end
when 17 then
# line 37 "markup.rl"
begin
end
when 16 then
# line 49 "markup.rl"
begin
characters_begin = p
end
when 27 then
# line 59 "markup.rl"
begin
raise ParseError.new("could not parse entity", buffer, p)
end
when 28 then
# line 63 "markup.rl"
begin
entity_begin = p
end
when 26 then
# line 125 "markup.rl"
begin
end
when 24 then
# line 132 "markup.rl"
begin
raise ParseError.new("could not parse instruction", buffer, p)
end
when 6 then
# line 145 "markup.rl"
begin
self_closing = true
end
when 1 then
# line 185 "markup.rl"
begin
raise ParseError.new("could not parse tag", buffer, p)
end
when 18 then
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 25 then
# line 28 "markup.rl"
begin
identifier_end = p
end
# line 122 "markup.rl"
begin
end
when 3 then
# line 28 "markup.rl"
begin
identifier_end = p
end
# line 136 "markup.rl"
begin
self_closing = false
delegate.open_tag_begin(data.byteslice(identifier_begin...identifier_end), identifier_begin)
end
when 7 then
# line 28 "markup.rl"
begin
identifier_end = p
end
# line 162 "markup.rl"
begin
if has_value
pcdata = MarkupString.raw(pcdata) unless has_entities
value = pcdata
else
value = true
end
delegate.attribute(data.byteslice(identifier_begin...identifier_end), value)
end
when 10 then
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 49 "markup.rl"
begin
characters_begin = p
end
when 11 then
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 12 then
# line 53 "markup.rl"
begin
characters_end = p
pcdata << data.byteslice(characters_begin...characters_end)
end
# line 37 "markup.rl"
begin
end
when 13 then
# line 53 "markup.rl"
begin
characters_end = p
pcdata << data.byteslice(characters_begin...characters_end)
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 31 then
# line 67 "markup.rl"
begin
entity_end = p
name = data.byteslice(entity_begin...entity_end)
has_entities = true
pcdata << entities[name]
end
# line 8 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
top -= 1
cs = stack[top]
_goto_level = _again
next
end
end
when 30 then
# line 76 "markup.rl"
begin
entity_end = p
has_entities = true
pcdata << data.byteslice(entity_begin...entity_end).to_i(16)
end
# line 8 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
top -= 1
cs = stack[top]
_goto_level = _again
next
end
end
when 29 then
# line 83 "markup.rl"
begin
entity_end = p
has_entities = true
pcdata << data.byteslice(entity_begin...entity_end).to_i(10)
end
# line 8 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
top -= 1
cs = stack[top]
_goto_level = _again
next
end
end
when 5 then
# line 149 "markup.rl"
begin
has_value = false
pcdata = ""
end
# line 24 "markup.rl"
begin
identifier_begin = p
end
when 14 then
# line 154 "markup.rl"
begin
has_value = true
end
# line 162 "markup.rl"
begin
if has_value
pcdata = MarkupString.raw(pcdata) unless has_entities
value = pcdata
else
value = true
end
delegate.attribute(data.byteslice(identifier_begin...identifier_end), value)
end
when 19 then
# line 158 "markup.rl"
begin
has_value = true
end
# line 162 "markup.rl"
begin
if has_value
pcdata = MarkupString.raw(pcdata) unless has_entities
value = pcdata
else
value = true
end
delegate.attribute(data.byteslice(identifier_begin...identifier_end), value)
end
when 4 then
# line 28 "markup.rl"
begin
identifier_end = p
end
# line 136 "markup.rl"
begin
self_closing = false
delegate.open_tag_begin(data.byteslice(identifier_begin...identifier_end), identifier_begin)
end
# line 145 "markup.rl"
begin
self_closing = true
end
when 8 then
# line 28 "markup.rl"
begin
identifier_end = p
end
# line 162 "markup.rl"
begin
if has_value
pcdata = MarkupString.raw(pcdata) unless has_entities
value = pcdata
else
value = true
end
delegate.attribute(data.byteslice(identifier_begin...identifier_end), value)
end
# line 145 "markup.rl"
begin
self_closing = true
end
when 32 then
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 49 "markup.rl"
begin
characters_begin = p
end
when 33 then
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 15 then
# line 154 "markup.rl"
begin
has_value = true
end
# line 162 "markup.rl"
begin
if has_value
pcdata = MarkupString.raw(pcdata) unless has_entities
value = pcdata
else
value = true
end
delegate.attribute(data.byteslice(identifier_begin...identifier_end), value)
end
# line 145 "markup.rl"
begin
self_closing = true
end
when 20 then
# line 158 "markup.rl"
begin
has_value = true
end
# line 162 "markup.rl"
begin
if has_value
pcdata = MarkupString.raw(pcdata) unless has_entities
value = pcdata
else
value = true
end
delegate.attribute(data.byteslice(identifier_begin...identifier_end), value)
end
# line 145 "markup.rl"
begin
self_closing = true
end
when 48 then
# line 94 "markup.rl"
begin
doctype_end = p
delegate.doctype(data.byteslice(doctype_begin...doctype_end))
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 49 "markup.rl"
begin
characters_begin = p
end
when 49 then
# line 94 "markup.rl"
begin
doctype_end = p
delegate.doctype(data.byteslice(doctype_begin...doctype_end))
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 44 then
# line 108 "markup.rl"
begin
comment_end = p
delegate.comment(data.byteslice(comment_begin...comment_end))
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 49 "markup.rl"
begin
characters_begin = p
end
when 45 then
# line 108 "markup.rl"
begin
comment_end = p
delegate.comment(data.byteslice(comment_begin...comment_end))
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 60 then
# line 128 "markup.rl"
begin
delegate.instruction(data.byteslice(instruction_begin, p-instruction_begin))
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 49 "markup.rl"
begin
characters_begin = p
end
when 61 then
# line 128 "markup.rl"
begin
delegate.instruction(data.byteslice(instruction_begin, p-instruction_begin))
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 40 then
# line 174 "markup.rl"
begin
delegate.open_tag_end(self_closing)
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 49 "markup.rl"
begin
characters_begin = p
end
when 41 then
# line 174 "markup.rl"
begin
delegate.open_tag_end(self_closing)
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 56 then
# line 181 "markup.rl"
begin
delegate.close_tag(data.byteslice(identifier_begin...identifier_end), identifier_begin)
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 49 "markup.rl"
begin
characters_begin = p
end
when 57 then
# line 181 "markup.rl"
begin
delegate.close_tag(data.byteslice(identifier_begin...identifier_end), identifier_begin)
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 52 then
# line 193 "markup.rl"
begin
cdata_end = p
delegate.cdata(data.byteslice(cdata_begin...cdata_end))
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 49 "markup.rl"
begin
characters_begin = p
end
when 53 then
# line 193 "markup.rl"
begin
cdata_end = p
delegate.cdata(data.byteslice(cdata_begin...cdata_end))
end
# line 40 "markup.rl"
begin
end
# line 32 "markup.rl"
begin
pcdata = ""
has_entities = false
end
# line 10 "/home/samuel/Documents/ioquatix/trenni/parsers/trenni/entities.rl"
begin
begin
stack[top] = cs
top+= 1
cs = 42
_goto_level = _again
next
end
end
when 34 then
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
when 50 then
# line 94 "markup.rl"
begin
doctype_end = p
delegate.doctype(data.byteslice(doctype_begin...doctype_end))
end
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
when 46 then
# line 108 "markup.rl"
begin
comment_end = p
delegate.comment(data.byteslice(comment_begin...comment_end))
end
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
when 62 then
# line 128 "markup.rl"
begin
delegate.instruction(data.byteslice(instruction_begin, p-instruction_begin))
end
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
when 42 then
# line 174 "markup.rl"
begin
delegate.open_tag_end(self_closing)
end
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
when 58 then
# line 181 "markup.rl"
begin
delegate.close_tag(data.byteslice(identifier_begin...identifier_end), identifier_begin)
end
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
when 54 then
# line 193 "markup.rl"
begin
cdata_end = p
delegate.cdata(data.byteslice(cdata_begin...cdata_end))
end
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
when 38 then
# line 37 "markup.rl"
begin
end
# line 43 "markup.rl"
begin
pcdata = MarkupString.raw(pcdata) unless has_entities
delegate.text(pcdata)
end
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
when 36 then
# line 53 "markup.rl"
begin
characters_end = p
pcdata << data.byteslice(characters_begin...characters_end)
end
# line 37 "markup.rl"
begin
end
# line 43 "markup.rl"
begin
pcdata = MarkupString.raw(pcdata) unless has_entities
delegate.text(pcdata)
end
# line 142 "markup.rl"
begin
end
# line 178 "markup.rl"
begin
end
# line 118 "markup.rl"
begin
instruction_begin = p
end
# line 104 "markup.rl"
begin
comment_begin = p
end
# line 90 "markup.rl"
begin
doctype_begin = p
end
# line 189 "markup.rl"
begin
cdata_begin = p
end
# line 1529 "markup.rb"
end
end
end
if _goto_level <= _again
if cs == 0
_goto_level = _out
next
end
p += 1
if p != pe
_goto_level = _resume
next
end
end
if _goto_level <= _test_eof
if p == eof
case _markup_eof_actions[cs]
when 27 then
# line 59 "markup.rl"
begin
raise ParseError.new("could not parse entity", buffer, p)
end
when 47 then
# line 94 "markup.rl"
begin
doctype_end = p
delegate.doctype(data.byteslice(doctype_begin...doctype_end))
end
when 22 then
# line 100 "markup.rl"
begin
raise ParseError.new("could not parse doctype", buffer, p)
end
when 43 then
# line 108 "markup.rl"
begin
comment_end = p
delegate.comment(data.byteslice(comment_begin...comment_end))
end
when 21 then
# line 114 "markup.rl"
begin
raise ParseError.new("could not parse comment", buffer, p)
end
when 59 then
# line 128 "markup.rl"
begin
delegate.instruction(data.byteslice(instruction_begin, p-instruction_begin))
end
when 24 then
# line 132 "markup.rl"
begin
raise ParseError.new("could not parse instruction", buffer, p)
end
when 39 then
# line 174 "markup.rl"
begin
delegate.open_tag_end(self_closing)
end
when 55 then
# line 181 "markup.rl"
begin
delegate.close_tag(data.byteslice(identifier_begin...identifier_end), identifier_begin)
end
when 1 then
# line 185 "markup.rl"
begin
raise ParseError.new("could not parse tag", buffer, p)
end
when 51 then
# line 193 "markup.rl"
begin
cdata_end = p
delegate.cdata(data.byteslice(cdata_begin...cdata_end))
end
when 23 then
# line 199 "markup.rl"
begin
raise ParseError.new("could not parse cdata", buffer, p)
end
when 37 then
# line 37 "markup.rl"
begin
end
# line 43 "markup.rl"
begin
pcdata = MarkupString.raw(pcdata) unless has_entities
delegate.text(pcdata)
end
when 35 then
# line 53 "markup.rl"
begin
characters_end = p
pcdata << data.byteslice(characters_begin...characters_end)
end
# line 37 "markup.rl"
begin
end
# line 43 "markup.rl"
begin
pcdata = MarkupString.raw(pcdata) unless has_entities
delegate.text(pcdata)
end
# line 1656 "markup.rb"
end
end
end
if _goto_level <= _out
break
end
end
end
# line 237 "markup.rl"
if p != eof
raise ParseError.new("could not consume all input", buffer, p)
end
return nil
end
end
end