rubyx/lib/parser/composed.rb

57 lines
2.1 KiB
Ruby
Raw Normal View History

2014-04-27 16:30:32 +03:00
require_relative "basic_types"
2014-04-27 18:13:10 +03:00
require_relative "tokens"
require_relative "keywords"
2014-04-24 15:43:20 +03:00
module Parser
2014-04-27 18:13:10 +03:00
2014-04-29 16:22:12 +03:00
# obviously a work in progress !!
2014-04-27 18:13:10 +03:00
# We "compose" the parser from bits, divide and hopefully conquer
2014-04-27 16:30:32 +03:00
class Composed < Parslet::Parser
include BasicTypes
2014-04-27 18:13:10 +03:00
include Tokens
include Keywords
2014-04-27 18:13:10 +03:00
2014-04-29 16:22:12 +03:00
# a note about .maybe : .maybe is almost every respect the same as .repeat(0,1)
# so either 0, or 1, in other words maybe. Nice feature, but there are strings attached:
# a maybe removes the 0 a sequence (array) to a single (hash). Thus 2 transformations are needed
# More work than the prettiness is worth, so only use .maybe on something that does not need capturing
rule(:argument_list) {
2014-04-27 18:13:10 +03:00
left_parenthesis >>
2014-04-29 16:22:12 +03:00
((expression.as(:argument) >> (comma >> expression.as(:argument)).repeat(0)).repeat(0,1)).as(:argument_list) >>
2014-04-27 18:13:10 +03:00
right_parenthesis
2014-04-24 15:43:20 +03:00
}
rule(:function_call) { name.as(:function_call) >> argument_list }
2014-04-24 15:43:20 +03:00
rule(:assignment) { name.as(:asignee) >> equal_sign >> expression.as(:asigned) }
rule(:expression) { conditional | function_call | integer | string | (name >> space? >> equal_sign.absent?) }
2014-04-24 15:43:20 +03:00
2014-04-28 15:46:57 +03:00
def delimited_expressions( delimit )
( space? >> (delimit.absent? >> (assignment | expression)).repeat(1)).as(:expressions) >> delimit
2014-04-28 15:46:57 +03:00
end
rule(:conditional) {
keyword_if >> left_parenthesis >> expression.as(:conditional) >> right_parenthesis >>
2014-04-28 15:46:57 +03:00
delimited_expressions(keyword_else).as(:if_true) >>
delimited_expressions(keyword_end).as(:if_false)
2014-04-24 15:43:20 +03:00
}
2014-04-28 15:46:57 +03:00
rule(:expressions_else) { delimited_expressions(keyword_else) }
rule(:expressions_end) { delimited_expressions(keyword_end) }
rule(:function_definition) {
2014-04-28 15:46:57 +03:00
keyword_def >> name.as(:function_definition) >> parmeter_list >> expressions_end
2014-04-24 15:43:20 +03:00
}
rule(:parmeter_list) {
2014-04-27 18:13:10 +03:00
left_parenthesis >>
2014-04-29 16:22:12 +03:00
((name.as(:parmeter) >> (comma >> name.as(:parmeter)).repeat(0)).repeat(0,1)).as(:parmeter_list) >>
2014-04-27 18:13:10 +03:00
right_parenthesis
2014-04-24 15:43:20 +03:00
}
rule(:root){ function_definition | expression | assignment }
2014-04-24 15:43:20 +03:00
end
end