You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Hi, I just started using pyrsistent, but it's working great so far. Thanks for maintaining it.
Here's some code that I dislike.
@dataclass_json@dataclass(frozen=True)classFoo:
bar: Dict[str, str]
I dislike it because you might think that frozen=True means that you're in immutable-land, but it's actually quite possible to mutate objects of this type:
You can be disciplined, and have both an immutable dataclass and immutable field types:
@dataclass_json@dataclass(frozen=True)classFoo:
bar: PMap[str, str]
But it's easy to forget/miscommunicate and accidentally add a mutable field. That's not pyrsistent's problem, but maybe pyrsistent is in a good position to provide a solution:
@dataclass_json@dataclass_pyrsistent@dataclass(frozen=True)classFoo:
bar: Dict[str, str]
The decorator would translate the mutable container type to PMap (or PVector) and call freeze on Dicts (or Lists) upon initialization. If you provide a type that pyrsistent can't translate (like a non-pyrsistent-dataclass) then it could just fail with a nice message.
I've included dataclass_json in this request as an example of a library that:
does something similar
might appear in context with the proposed decorator
Thanks for considering it!
The text was updated successfully, but these errors were encountered:
Tighter integration with dataclasses through a decorator, like dataclass_json does, is a potentially very nice idea. Thanks for bringing it up!
In addition to turning the dicts and lists into their frozen counterparts I would also consider turning the whole class into a PClass (if possible in an elegant way). This could become an alternative way of specifying PClasses that would potentially play better with existing tooling for code completion, type checking, etc. than the current way does.
I'd be happy to discuss this further, review PRs, etc. if you want to work on this!
I checked back in on this issue because I ran into something that reminded me of it, so I anticipate it'll keep coming up.
I'd want to spend a bit more time with pyrsistent and immutable data in python in general before attempting such a contribution, so I'm not going to hop to it just yet. But in general--yeah that sounds great.
I may ping you for feedback on a draft PR in the future (though I'd love it if somebody beat me to it because I am not fast).
Hi, I just started using pyrsistent, but it's working great so far. Thanks for maintaining it.
Here's some code that I dislike.
I dislike it because you might think that
frozen=True
means that you're in immutable-land, but it's actually quite possible to mutate objects of this type:You can be disciplined, and have both an immutable dataclass and immutable field types:
But it's easy to forget/miscommunicate and accidentally add a mutable field. That's not pyrsistent's problem, but maybe pyrsistent is in a good position to provide a solution:
The decorator would translate the mutable container type to PMap (or PVector) and call
freeze
on Dicts (or Lists) upon initialization. If you provide a type that pyrsistent can't translate (like a non-pyrsistent-dataclass) then it could just fail with a nice message.I've included dataclass_json in this request as an example of a library that:
Thanks for considering it!
The text was updated successfully, but these errors were encountered: