import collections
+def consume_newlines(index, tokens):
+ while index < len(tokens) and tokens[index].type == 'newline':
+ index += 1
+
+ return True, index, None
+
def _or_parser(*parsers):
def result_parser(index, tokens):
failure = (False, index, None)
],
)
+# TODO We don't need to wrap this type
FurParenthesizedExpression = collections.namedtuple(
'FurParenthesizedExpression',
[
'addition_level',
)(index, tokens)
-def _equality_level_expression_parser(index, tokens):
+def _comparison_level_expression_parser(index, tokens):
return _left_recursive_infix_operator_parser(
- lambda token: token.type == 'equality_level_operator',
+ lambda token: token.type == 'comparison_level_operator',
_addition_level_expression_parser,
- 'equality_level',
+ 'comparison_level',
)(index, tokens)
def _and_level_expression_parser(index, tokens):
return _left_recursive_infix_operator_parser(
lambda token: token.type == 'symbol' and token.match == 'and',
- _equality_level_expression_parser,
+ _comparison_level_expression_parser,
'and_level',
)(index, tokens)
],
)
+FurExpressionStatement = collections.namedtuple(
+ 'FurExpressionStatement',
+ [
+ 'expression',
+ ],
+)
+
FurAssignmentStatement = collections.namedtuple(
'FurAssignmentStatement',
[
_expression_parser = _or_level_expression_parser
+def _expression_statement_parser(index, tokens):
+ failure = (False, index, None)
+
+ success, index, expression = _expression_parser(index, tokens)
+
+ if not success:
+ return failure
+
+ return (True, index, FurExpressionStatement(expression=expression))
+
def _assignment_statement_parser(index, tokens):
# TODO Use a FurSymbolExpression for the target? Maybe this is actually not a good idea
failure = (False, index, None)
return True, index, FurAssignmentStatement(target=target, expression=expression)
def _statement_parser(index, tokens):
- # TODO It would be good to include newlines in the parsing of this because it removes the ambiguity between "function(argument)" (one statement) and "function\n(argument)" (two statements)
+ _, index, _ = consume_newlines(index, tokens)
+
+ if index == len(tokens):
+ return (False, index, None)
+
return _or_parser(
_assignment_statement_parser,
- _expression_parser,
+ _expression_statement_parser,
)(index, tokens)
def _program_formatter(statement_list):