TL;博士; - 通常 Parsletas
用于repeat
捕获匹配数组;除了所有匹配都是原始字符串的特殊情况,在这种情况下,它将它们连接起来并返回结果字符串。
在您的代码中,repeat
不知道它将捕获的类型,因为没有任何类型,因此它返回空数组。
在这个例子中......空数组似乎是正确的选择。
require 'parslet'
class Parser < Parslet::Parser
rule(:quote) { str('"') }
rule(:escape_char) { str('\\') }
def quoted(term)
quote >> term >> quote
end
rule(:string) {
quoted( (escape_char >> any | quote.absent? >> any).as(:char).repeat.as(:string) )
}
end
puts Parser.new.string.parse('""').inspect # => {:string=>[]}
puts Parser.new.string.parse('"test"').inspect
# => {:string=>[{:char=>"t"@1}, {:char=>"e"@2}, {:char=>"s"@3}, {:char=>"t"@4}]}
当子节点只是字符串时,Parslet 将其连接成一个字符串。当集合中没有元素时,它默认为空集合而不是空字符串。
maybe
是不同的。
来自http://kschiess.github.io/parslet/parser.html # Repetition and its Special Cases
这些都映射到 Parslet::Atoms::Repetition。请注意#maybe的这个小转折:
str('foo').maybe.as(:f).parse('') # => {:f=>nil}
str('foo').repeat(0,1).as(:f)。 parse('') # => {:f=>[]}
'nil' - #maybe 的值为 nil。这迎合了 foo.maybe 要么给我 foo 要么什么都不给我的直觉,而不是一个空数组。但随心所欲!