forked from kschiess/parslet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
parser.rb
71 lines (66 loc) · 1.85 KB
/
parser.rb
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
# The base class for all your parsers. Use as follows:
#
# require 'parslet'
#
# class MyParser < Parslet::Parser
# rule(:a) { str('a').repeat }
# root(:a)
# end
#
# pp MyParser.new.parse('aaaa') # => 'aaaa'
# pp MyParser.new.parse('bbbb') # => Parslet::Atoms::ParseFailed:
# # Don't know what to do with bbbb at line 1 char 1.
#
# Parslet::Parser is also a grammar atom. This means that you can mix full
# fledged parsers freely with small parts of a different parser.
#
# Example:
# class ParserA < Parslet::Parser
# root :aaa
# rule(:aaa) { str('a').repeat(3,3) }
# end
# class ParserB < Parslet::Parser
# root :expression
# rule(:expression) { str('b') >> ParserA.new >> str('b') }
# end
#
# In the above example, ParserB would parse something like 'baaab'.
#
class Parslet::Parser < Parslet::Atoms::Base
include Parslet
class <<self # class methods
# Define the parsers #root function. This is the place where you start
# parsing; if you have a rule for 'file' that describes what should be
# in a file, this would be your root declaration:
#
# class Parser
# root :file
# rule(:file) { ... }
# end
#
# #root declares a 'parse' function that works just like the parse
# function that you can call on a simple parslet, taking a string as input
# and producing parse output.
#
# In a way, #root is a shorthand for:
#
# def parse(str)
# your_parser_root.parse(str)
# end
#
def root(name)
define_method(:root) do
self.send(name)
end
end
end
def try(source, context) # :nodoc:
root.try(source, context)
end
def error_tree # :nodoc:
root.error_tree
end
def to_s_inner(prec) # :nodoc:
root.to_s(prec)
end
end