(add comments and docstrings to namespace.py for clarity)

branch-yixin
yixin 2 months ago
parent b4d46a2542
commit eff398104d

@ -16,131 +16,136 @@
# ============================================================================
"""Define the namespace of parse."""
import builtins
from mindspore import log as logger
import builtins # 导入内置模块builtins
from mindspore import log as logger # 从mindspore库导入log模块并重命名为logger
class Namespace:
"""
Base class of namespace for resolve variables.
基类用于解析变量命名空间
Args:
name (str): The namespace's name.
dicts (dict): A list of dict containing the namespace's variable.
name (str): 命名空间的名称
dicts (dict): 包含命名空间变量的字典列表
"""
def __init__(self, name, *dicts):
self.name = name
self.dicts = dicts
self.name = name # 初始化命名空间名称
self.dicts = dicts # 初始化包含变量的字典列表
def __contains__(self, name):
# 检查命名空间中是否包含指定名称的变量
for d in self.dicts:
if name in d:
return True
return False
def __getitem__(self, name):
# 获取命名空间中指定名称的变量
for d in self.dicts:
if name in d:
return d[name]
raise NameError(name)
raise NameError(name) # 如果未找到抛出NameError
def __repr__(self):
# 返回命名空间的字符串表示
return f'Namespace:{self.name}'
class CellNamespace(Namespace):
"""
Namespace for Cell object.
Cell对象的命名空间
Args:
name (str): Valid module name, it can be imported.
name (str): 可导入的有效模块名称
"""
def __init__(self, name):
mod_dict = vars(__import__(name, fromlist=['_']))
builtins_dict = vars(builtins)
super().__init__(name, mod_dict, builtins_dict)
mod_dict = vars(__import__(name, fromlist=['_'])) # 导入模块并获取其变量字典
builtins_dict = vars(builtins) # 获取内置模块的变量字典
super().__init__(name, mod_dict, builtins_dict) # 调用父类初始化
def __getstate__(self):
# 获取对象的状态,用于序列化
return (self.name,)
def __setstate__(self, state):
# 设置对象的状态,用于反序列化
name, = state
mod_dict = vars(__import__(name, fromlist=['_']))
builtins_dict = vars(builtins)
super().__init__(name, mod_dict, builtins_dict)
mod_dict = vars(__import__(name, fromlist=['_'])) # 重新导入模块
builtins_dict = vars(builtins) # 重新获取内置模块字典
super().__init__(name, mod_dict, builtins_dict) # 重新初始化父类
class ClosureNamespace(Namespace):
"""
Namespace for function closure.
函数闭包的命名空间
Args:
fn (Function): A python function.
fn (Function): 一个Python函数
"""
def __init__(self, fn):
name = f'{fn.__module__}..<{fn.__name__}>'
names = fn.__code__.co_freevars
cells = fn.__closure__
ns = dict(zip(names, cells or ()))
super().__init__(name, ns)
name = f'{fn.__module__}..<{fn.__name__}>' # 构造命名空间名称
names = fn.__code__.co_freevars # 获取函数的自由变量名称
cells = fn.__closure__ # 获取函数的闭包
ns = dict(zip(names, cells or ())) # 构造命名空间字典
super().__init__(name, ns) # 调用父类初始化
def __getitem__(self, name):
# 获取命名空间中指定名称的变量
d, = self.dicts
try:
return d[name].cell_contents
return d[name].cell_contents # 返回闭包内容
except ValueError:
raise UnboundLocalError(name)
raise UnboundLocalError(name) # 如果未找到抛出UnboundLocalError
class ClassMemberNamespace(Namespace):
"""
Namespace of a class's closure.
类闭包的命名空间
Args:
obj (Object): A python class object.
obj (Object): 一个Python类对象
"""
def __init__(self, obj):
self.__class_member_namespace__ = True
label = f'{obj.__module__}..<{obj.__class__.__name__}::{id(obj)}>'
super().__init__(label, obj)
self.__class_member_namespace__ = True # 标记为类成员命名空间
label = f'{obj.__module__}..<{obj.__class__.__name__}::{id(obj)}>' # 构造命名空间标签
super().__init__(label, obj) # 调用父类初始化
def __getitem__(self, name):
# 获取命名空间中指定名称的变量
d, = self.dicts
if name == "self":
return d
return d # 如果名称是self返回对象本身
if name == "namespace":
return self
return self # 如果名称是namespace返回命名空间对象
try:
if hasattr(d, name):
return getattr(d, name)
return d.__dict__[name]
return getattr(d, name) # 如果对象有该属性,返回属性值
return d.__dict__[name] # 否则从对象字典中获取
except ValueError:
raise UnboundLocalError(name)
raise UnboundLocalError(name) # 如果未找到抛出UnboundLocalError
except KeyError:
logger.info(f"'{d.__class__.__name__ }' object has no attribute or method: '{name}', so will return None.")
raise AttributeError(name)
raise AttributeError(name) # 如果未找到属性记录日志并抛出AttributeError
class ClassAttrNamespace(Namespace):
"""
Namespace of a class.
类的命名空间
Args:
obj (Object): A python class object.
obj (Object): 一个Python类对象
"""
def __init__(self, obj):
name = f'{obj.__module__}..<{obj.__class__.__name__}::{id(obj)}>'
super().__init__(name, obj)
name = f'{obj.__module__}..<{obj.__class__.__name__}::{id(obj)}>' # 构造命名空间名称
super().__init__(name, obj) # 调用父类初始化
def __getattr__(self, name):
# 获取命名空间中指定名称的属性
d, = self.dicts
try:
if hasattr(d, name):
return getattr(d, name)
return d.__dict__[name]
return getattr(d, name) # 如果对象有该属性,返回属性值
return d.__dict__[name] # 否则从对象字典中获取
except ValueError:
raise UnboundLocalError(name)
raise UnboundLocalError(name) # 如果未找到抛出UnboundLocalError
except KeyError:
logger.info(f"'{d.__class__.__name__ }' object has no attribute or method: '{name}', so will return None.")
raise AttributeError(name)
raise AttributeError(name) # 如果未找到属性记录日志并抛出AttributeError

Loading…
Cancel
Save