data:image/s3,"s3://crabby-images/7874a/7874acd7457a240b65658339893de2732efbb79b" alt=""
Howdy y'all! Picking up on PEP 681, and more specifically this post: https://mail.python.org/archives/list/typing-sig@python.org/thread/5XZQK7GVI... I'm interested to hear thoughts on how a PEP to add this functionality would be received. My usage doesn't come from attrs (but shares the problem-space) in that our library defines dataclasses that clients instantiate (which all happen to be frozen and only contain immutable types). Currently to be type-compliant without mypy plugins, we have to define __init__ and do the conversion inside it. Example: @dataclass(frozen=True) class MyData: values: tuple[int, ...] number_map: FrozenOrderedDict[str, int] # a frozen dict, essentially def __init__(self, values: Iterable[int], number_map: Mapping[str, int]): ... However this has a few drawbacks: - Extremely verbose: certainly not as ideal as `values: tuple[int, ...] = my_field(..., converter=tuple)` without the init method - Prone to overload explosion: dicts have an overloaded init with 2 unary-constructors. To be most correct, we'd need to overload our init with each possible cross-product of value unary constructors I think this is in the spirit of attrs' converter field, and I don't feel like forcing our clients to convert is really in the spirit of Python. Additionally, I agree with Jelle Zijlstra in https://mail.python.org/archives/list/typing-sig@python.org/message/7SDEVKQH... that support for this should used typed-converters (instead of using Any, as suggested elsewhere). So far, I can think of a few complexities to document, but otherwise would love to hear if this feature is prohibitively difficult or just doesn't fit. Challenges: - Overloaded converters (such as dict's __init__): Would need to overload the dataclass __init__, and generate a cross-product of overloads if multiple converters - Converters accepting varargs: The type-checker needs to treat the callable's possible first arg as the lone arg (and not error on variable arg functions, again consider dict's constructor) - Generic converters (such as the value `tuple`): There's no great way for Python users pre Py 3.9 to use built-in generics as converters, however users could roll their own converter easily. In Py 3.9+, `tuple[int]` should work at type-checking-time and at runtime. (Whether it would work "out of the box" at type-check-time is up for debate) Thanks for your time and thoughts!