# line 1 "markup.rl" # Copyright, 2016, by Samuel G. D. Williams. # # 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