Skip to content

Commit

Permalink
Compatibility for py3.6 - py3.10 (apache#56)
Browse files Browse the repository at this point in the history
  • Loading branch information
junrushao authored Jun 28, 2022
1 parent e555bef commit 964c92a
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 36 deletions.
12 changes: 8 additions & 4 deletions python/tvm/script/parse/diagnostics.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,15 +33,19 @@ def __init__(self, source: Source):
self.ctx = diagnostics.DiagnosticContext(mod, diagnostics.get_renderer())

def _emit(self, node: doc.AST, message: str, level: diagnostics.DiagnosticLevel) -> None:
lineno = node.lineno
col_offset = node.col_offset
end_lineno = node.end_lineno or lineno
end_col_offset = node.end_col_offset or col_offset
self.ctx.emit(
diagnostics.Diagnostic(
level=level,
span=Span(
source_name=SourceName(self.source.source_name),
line=node.lineno,
end_line=node.end_lineno,
column=node.col_offset + 1,
end_column=node.end_col_offset + 1,
line=lineno,
end_line=end_lineno,
column=col_offset + 1,
end_column=end_col_offset + 1,
),
message=message,
)
Expand Down
95 changes: 63 additions & 32 deletions python/tvm/script/parse/doc.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import ast
import inspect
import sys
import typing
from collections import defaultdict

Expand Down Expand Up @@ -96,38 +97,6 @@ def to_doc(node):
return func(node)


def _register_default():
class DefaultTranslator:
def __init__(self, doc_cls, func, fields):
self.doc_cls = doc_cls # getattr(doc, name)
self.func = func
self.fields = fields

def __call__(self, node):
kv = {attr: self.func(getattr(node, attr, None)) for attr in self.fields}
return self.doc_cls(**kv)

Registry._inst = Registry() # pylint: disable=protected-access
for cls_name in dir(doc):
doc_cls = getattr(doc, cls_name)
if inspect.isclass(doc_cls) and issubclass(doc_cls, doc.AST):
assert "." not in cls_name
register_to_doc(cls_name)(
DefaultTranslator(
getattr(doc, cls_name),
to_doc,
doc_cls._FIELDS, # pylint: disable=protected-access
)
)
register_from_doc(cls_name)(
DefaultTranslator(
getattr(ast, cls_name),
from_doc,
doc_cls._FIELDS, # pylint: disable=protected-access
)
)


def parse(
source,
filename="<unknown>",
Expand Down Expand Up @@ -198,4 +167,66 @@ def generic_visit(self, node: doc.AST) -> doc.AST:
return node.__class__(**kv)


def _register_default():
class DefaultTranslator:
def __init__(self, doc_cls, func, fields):
self.doc_cls = doc_cls # getattr(doc, name)
self.func = func
self.fields = fields

def __call__(self, node):
kv = {attr: self.func(getattr(node, attr, None)) for attr in self.fields}
return self.doc_cls(**kv)

Registry._inst = Registry() # pylint: disable=protected-access
for cls_name in dir(doc):
doc_cls = getattr(doc, cls_name)
if not hasattr(ast, cls_name):
continue
if inspect.isclass(doc_cls) and issubclass(doc_cls, doc.AST):
assert "." not in cls_name
register_to_doc(cls_name)(
DefaultTranslator(
getattr(doc, cls_name),
to_doc,
doc_cls._FIELDS, # pylint: disable=protected-access
)
)
register_from_doc(cls_name)(
DefaultTranslator(
getattr(ast, cls_name),
from_doc,
doc_cls._FIELDS, # pylint: disable=protected-access
)
)


def _register_constant_handling():
version = sys.version_info.major, sys.version_info.minor
if version != (3, 6) and version != (3, 7):
pass

def as_constant(f) -> doc.Constant:
def to_doc_func(x: ast.AST) -> doc.Constant:
return doc.Constant(
value=getattr(x, f) if isinstance(f, str) else f(x),
kind=None,
s=None,
n=None,
lineno=x.lineno,
col_offset=x.col_offset,
end_lineno=x.lineno,
end_col_offset=x.col_offset,
)

return to_doc_func

register_to_doc("Str")(as_constant("s"))
register_to_doc("NameConstant")(as_constant("value"))
register_to_doc("Num")(as_constant("n"))
register_to_doc("Bytes")(as_constant("s"))
register_to_doc("Ellipsis")(as_constant(lambda _: ...))


_register_default()
_register_constant_handling()

0 comments on commit 964c92a

Please sign in to comment.