Keta/ekg/Parse.py

76 lines
1.9 KiB
Python

# A Simple Parser For Ekg
import TokenLib
from TokenLib import Token
class Parser():
def __init__(self, source: str):
self.source = source
def parse(self, optional_source: str = "") -> [TokenLib.Token]:
# Assumes that the source is already balanced
# Variables used for determining if a block is being parsed/
# if an escape sequence is present
escaped = False
block_level = 0
temp_block = ""
token_list = []
if optional_source:
code = optional_source
else:
code = self.source
for char in code:
if escaped:
self.token_list.append(Token(TokenLib.ESCAPE, char))
escaped = False
elif char == "\\":
escaped = True
elif char == "[":
if block_level >= 1:
block_level += 1
temp_block += char
else:
block_level = 1
elif block_level:
if char == "]":
if block_level == 1:
token_list.append(Token(TokenLib.BLOCK,
self.parse(temp_block)))
block_level = 0
temp_block = ""
else:
temp_block += char
block_level -= 1
else:
temp_block += char
else:
token_list.append(Token(TokenLib.INSTRUCTION,
char))
if temp_block:
token_list.append(Token(TokenLib.BLOCK,
temp_block))
return token_list
if __name__ == "__main__":
source: str = "[P[DD+s]]S3"
parser: Parser = Parser(source)
tokens: [Token] = parser.parse()
for token in tokens:
print(token.get_data())