Refactored sheerka execution flow + Enhanced log management
This commit is contained in:
+26
-8
@@ -1,5 +1,7 @@
|
||||
from dataclasses import dataclass
|
||||
from core.tokenizer import TokenKind, Keywords
|
||||
from core.sheerka_logger import get_logger
|
||||
import logging
|
||||
|
||||
|
||||
@dataclass()
|
||||
@@ -34,9 +36,13 @@ class UnexpectedTokenErrorNode(ErrorNode):
|
||||
|
||||
|
||||
class BaseParser:
|
||||
PREFIX = "Parsers:"
|
||||
PREFIX = "parsers."
|
||||
|
||||
def __init__(self, name):
|
||||
self.log = get_logger("parsers." + self.__class__.__name__)
|
||||
self.init_log = get_logger("init." + self.PREFIX + self.__class__.__name__)
|
||||
self.verbose_log = get_logger("verbose." + self.PREFIX + self.__class__.__name__)
|
||||
|
||||
self.name = self.PREFIX + name
|
||||
self.has_error = False
|
||||
self.error_sink = []
|
||||
@@ -52,6 +58,25 @@ class BaseParser:
|
||||
def parse(self, context, text):
|
||||
pass
|
||||
|
||||
def log_result(self, context, source, ret):
|
||||
if not self.log.isEnabledFor(logging.DEBUG):
|
||||
return
|
||||
|
||||
if ret.status:
|
||||
value = context.return_value_to_str(ret)
|
||||
context.log(self.log, f"Recognized '{source}' as {value}", self.name)
|
||||
else:
|
||||
context.log(self.log, f"Failed to recognize '{source}'", self.name)
|
||||
|
||||
def log_multiple_results(self, context, source, list_of_ret):
|
||||
if not self.log.isEnabledFor(logging.DEBUG):
|
||||
return
|
||||
|
||||
context.log(self.log, f"Recognized '{source}' as multiple concepts", self.name)
|
||||
for r in list_of_ret:
|
||||
value = context.return_value_to_str(r)
|
||||
context.log(self.log, f" Recognized '{value}'", self.name)
|
||||
|
||||
@staticmethod
|
||||
def get_text_from_tokens(tokens):
|
||||
if tokens is None:
|
||||
@@ -65,10 +90,3 @@ class BaseParser:
|
||||
value = Keywords(token.value).value if token.type == TokenKind.KEYWORD else token.value
|
||||
res += value
|
||||
return res
|
||||
|
||||
@staticmethod
|
||||
def log_result(log, text, ret):
|
||||
if ret.status:
|
||||
log.debug(f"Recognized '{text}' as {ret.value}")
|
||||
else:
|
||||
log.debug(f"Failed to recognize '{text}'")
|
||||
|
||||
Reference in New Issue
Block a user