making grammar look more like ruby
This commit is contained in:
@ -6,7 +6,6 @@ module Parser
|
||||
include Parslet
|
||||
rule(:space) { match('\s').repeat(1) }
|
||||
rule(:space?) { space.maybe }
|
||||
rule(:name) { match('[a-z]').repeat(1).as(:name) >> space? }
|
||||
rule(:double_quote){ str('"') }
|
||||
rule(:minus) { str('-') }
|
||||
rule(:plus) { str('+') }
|
||||
@ -16,17 +15,22 @@ module Parser
|
||||
rule(:exponent) { (str('e')| str('E')) }
|
||||
rule(:escaped_character) { str('\\') >> (match('["\\\\/bfnrt]') | (str('u') >> hexdigit.repeat(4,4))) }
|
||||
|
||||
rule(:true) { str('true').as(:true) }
|
||||
rule(:false) { str('false').as(:false) }
|
||||
rule(:nil) { str('null').as(:nil) }
|
||||
rule(:true) { str('true').as(:true) >> space?}
|
||||
rule(:false) { str('false').as(:false) >> space?}
|
||||
rule(:nil) { str('null').as(:nil) >> space?}
|
||||
|
||||
# identifier must start with lower case
|
||||
rule(:name) { (match['a-z'] >> match['a-zA-Z0-9'].repeat).as(:name) >> space? }
|
||||
|
||||
#anything in double quotes
|
||||
rule(:string){
|
||||
double_quote >> (escaped_character | double_quote.absent? >> any ).repeat.as(:string) >> double_quote
|
||||
double_quote >>
|
||||
(escaped_character | double_quote.absent? >> any ).repeat.as(:string) >>
|
||||
double_quote >> space?
|
||||
}
|
||||
rule(:integer) { sign.maybe >> digit.repeat(1).as(:integer) >> space? }
|
||||
|
||||
rule(:float) { integer >> dot >> integer >>
|
||||
(exponent >> sign.maybe >> digit.repeat).maybe}
|
||||
(exponent >> sign.maybe >> digit.repeat).maybe >> space?}
|
||||
end
|
||||
end
|
@ -27,17 +27,23 @@ module Parser
|
||||
|
||||
rule(:expression) { conditional | function_call | integer | name }
|
||||
|
||||
def delimited_expressions( delimit )
|
||||
((delimit.absent? >> expression).repeat(1)).as(:expressions) >> delimit
|
||||
end
|
||||
|
||||
rule(:conditional) {
|
||||
keyword_if >> left_parenthesis >> expression.as(:conditional) >> right_parenthesis >>
|
||||
block.as(:if_true) >>
|
||||
keyword_else >>
|
||||
block.as(:if_false)
|
||||
delimited_expressions(keyword_else).as(:if_true) >>
|
||||
delimited_expressions(keyword_end).as(:if_false)
|
||||
}
|
||||
|
||||
rule(:block) { left_brace >> expression.as(:block) >> right_brace }
|
||||
rule(:expressions_else) { delimited_expressions(keyword_else) }
|
||||
rule(:expressions_end) { delimited_expressions(keyword_end) }
|
||||
|
||||
# rule(:expressions_end) { ((keyword_end.absent? >> expression).repeat(1)).as(:expressions) >> keyword_end }
|
||||
|
||||
rule(:function_definition) {
|
||||
keyword_def >> name.as(:function_definition) >> parmeter_list >> block
|
||||
keyword_def >> name.as(:function_definition) >> parmeter_list >> expressions_end
|
||||
}
|
||||
|
||||
rule(:parmeter_list) {
|
||||
@ -45,6 +51,6 @@ module Parser
|
||||
((name.as(:parmeter) >> (comma >> name.as(:parmeter)).repeat(0)).maybe).as(:parmeter_list) >>
|
||||
right_parenthesis
|
||||
}
|
||||
rule(:root){ function_definition.repeat(0) >> expression | expression | argument_list }
|
||||
rule(:root){ function_definition | expression }
|
||||
end
|
||||
end
|
||||
|
@ -4,6 +4,6 @@ module Parser
|
||||
rule(:keyword_if) { str('if') >> space? }
|
||||
rule(:keyword_else) { str('else') >> space? }
|
||||
rule(:keyword_def) { str('def') >> space? }
|
||||
|
||||
rule(:keyword_end) { str('end') >> space? }
|
||||
end
|
||||
end
|
Reference in New Issue
Block a user