Module for all Alias types. Alias types are types that handle to conversion for other types.
All builtin types (int, str, float, etc...) have a corresponding Alias type.
Alias
Parent class for all aliases. Stores references to all
known alias types and handles resolving them. Additionally,
it provides a convenience wrapper for alias types by implementing
a custom cls.__convert__()
that calls cls.convert()
for non-parameterized
types and cls.g_convert()
for generic types.
Source code in /home/sean/sourcecode/arc/arc/types/aliases.py
| class Alias:
"""Parent class for all aliases. Stores references to all
known alias types and handles resolving them. Additionally,
it provides a convenience wrapper for alias types by implementing
a custom `cls.__convert__()` that calls `cls.convert()` for non-parameterized
types and `cls.g_convert()` for generic types.
"""
aliases: dict[Annotation, type[TypeProtocol]] = {}
alias_for: t.ClassVar[AliasFor | tuple[AliasFor]] = None # type: ignore
name: t.ClassVar[t.Optional[str]] = None
convert: t.Callable[..., t.Any]
g_convert: t.Callable[..., t.Any]
@classmethod
def __convert__(cls, value: str, typ: TypeInfo[T]) -> T:
if cls.name:
typ.name = cls.name
if not typ.sub_types:
obj = api.dispatch_args(cls.convert, value, typ)
else:
obj = api.dispatch_args(cls.g_convert, value, typ)
return obj
def __init_subclass__(cls, of: t.Optional[AliasFor | tuple[AliasFor]] = None):
if of:
cls.alias_for = of
if isinstance(cls.alias_for, tuple):
aliases = cls.alias_for
else:
aliases = (cls.alias_for,)
for alias in aliases:
Alias.aliases[alias] = cls # type: ignore
@classmethod
def resolve(cls, annotation: Annotation) -> type[TypeProtocol]:
"""Handles resolving alias types"""
if safe.issubclass(annotation, TypeProtocol):
return t.cast(type[TypeProtocol], annotation)
elif annotation in cls.aliases:
# Type is a key
# We perform this check once before hand
# because some typing types don't have
# the mro() method
return cls.aliases[annotation]
else:
assert isinstance(annotation, type), f"{annotation} is not a type"
# Type is a subclass of a key
for parent in annotation.mro():
if parent in cls.aliases:
return cls.aliases[parent]
name = colorize(annotation.__name__, fg.YELLOW)
raise TypeError(
f"{name} is not a valid type. "
f"Please ensure that {name} conforms to the custom type protocol "
f"or that there is a alias type registered for it: "
"https://arc.seancollings.dev/usage/parameters/types/custom-types"
)
|
resolve(annotation)
classmethod
Handles resolving alias types
Source code in /home/sean/sourcecode/arc/arc/types/aliases.py
| @classmethod
def resolve(cls, annotation: Annotation) -> type[TypeProtocol]:
"""Handles resolving alias types"""
if safe.issubclass(annotation, TypeProtocol):
return t.cast(type[TypeProtocol], annotation)
elif annotation in cls.aliases:
# Type is a key
# We perform this check once before hand
# because some typing types don't have
# the mro() method
return cls.aliases[annotation]
else:
assert isinstance(annotation, type), f"{annotation} is not a type"
# Type is a subclass of a key
for parent in annotation.mro():
if parent in cls.aliases:
return cls.aliases[parent]
name = colorize(annotation.__name__, fg.YELLOW)
raise TypeError(
f"{name} is not a valid type. "
f"Please ensure that {name} conforms to the custom type protocol "
f"or that there is a alias type registered for it: "
"https://arc.seancollings.dev/usage/parameters/types/custom-types"
)
|