-
-
Notifications
You must be signed in to change notification settings - Fork 182
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support ABC and Enums #450
Conversation
Any progress on this? |
For most cases, the PR as it is works. But for a couple of edge cases (like ABC classes that redefine |
@mmckerns Since demand is high, do you think that we should pull this PR (since it works in most cases) and open another PR where I tackle the remaining cases, so that people can use this feature in dill 0.3.5? My only concern is that the issue concerning ABCs with |
I am updating the way |
Also, I'd rather not make mistakes and then have to backtrack and break things backward. It's better to be careful and a bit slow. |
In the process of trying to detect when it broke, I was able to find the bug. Now, the only case that I am aware of that this PR isn't working on is date enums. I think this will be ready for 0.3.6. |
@mmckerns I have reason to believe that, on the master branch, If you aren't done making the release, can we add that to the release? Although it is not that common, I am sure that someone will pickle a class with |
I'm done with changes and most of the testing, and will cut a PR to update the build before cutting the release. I haven't done the release yet, and may not until tomorrow. Go ahead and put the change into a PR, and I'll look at it. I can likely pull it before the release. |
@mmckerns Not urgent. There is no way to pickle enums that look like this without additional information: class AutoNumber(IntEnum):
def __new__(cls):
value = len(cls.__members__) + 1
obj = int.__new__(cls, value)
obj._value_ = value
return obj
class Color(AutoNumber):
red = ()
green = ()
blue = () The values assigned to the class attributes get updated with the enum value itself, so it is impossible to recover the constructor arguments. Should there be a hook or register function to define this new form of reduction, or should we just leave this feature as unsupported. cloudpickle doesn't support this either, but it generates the error during unpickling, which I find undesirable. Since most people are looking for the core functionality of this PR and other libraries in the same domain don't consider this to be a problem, I will open this PR and let you take a look at it after dill 0.3.5 is out. EDIT: This is now fixed. |
Thoughts about making this part of the API public so that others can register hooks for pickling custom metaclasses that are not supported by this PR, like Django models? |
I guess this PR has been "finished" for a while. The problem is that this PR tackles ABCs and Enums in the same PR because without a definite plan on how to incorporate both of them, it would have been hard to support both. But now, other PRs are leading to lots of merge conflicts and it might be better off to close this PR and reopen many smaller PRs that address smaller incomplete subsets of ABCs and Enums. It would help avoid bugs like #486 because it would be easier to merge individual pieces independent of others and not cause problems. If you haven't looked at this PR yet, that is the route I will take rather than creating another merge commit. |
Do you want me to try to manually merge this PR with master? |
Sure. You can give it a shot. |
It think I succeeded with the 3-way manual merge. It was easier than I thought. Opened a PR to your fork. |
Merge branch 'master' into enums
There were many problems with this PR due to its size. It began to become too hefty and difficult to keep up with master to the point that I just gave up. Because this feature was demanded by many people, they started to fork this branch and stop updating dill in order to pickle ABCs and enums. This means that I probably should keep backwards compatibility with older commits on this branch, to prevent people from getting upset. New additions to the Here is my plan. I will not keep this branch up to date with master. @mmckerns Does this seem like a good plan? This will require a large amount of work and I probably won't be able to put any significant dent in it until the summer. I believe that this is a more important task than #534, so I will look into this instead. There seem to be a lot of new additions in 3.11 and I need to read through them to understand what is possible and make sure I cover everything. A quick summary makes it seem like the only new features that need to be added (i.e., change how the enum class is pickled) are |
@anivegesana (this also a good note for @leogama): I've been hired in the past essentially to merge large unwieldy PRs. It can be a nasty task. Your instinct is correct in that small (the smaller the better) PRs are easy to merge. However, I strongly suggest you only pull off one or two small PRs at a time. Essentially, you want them as small as possible... and you want to also (1) propagate the changes back into this PR, and (2) not have too many small open PRs as it will become a management nightmare as each small PR has some small changes to it before it is merged. What you want ultimately is to get this PR to merge, incrementally through small PRs moving it closer to master. It will take time, so don't be in a rush. If you are most interested in this feature, then go for it. |
I am thinking about breaking it into 3-4 pieces: "special metaclass framework utilities" that will allow for the customization of how metaclasses are pickled, ABCs, pre-3.11 enums, and 3.11 enums (if new changes are significant). Let me know if a different breakdown is preferable. |
"special metaclass framework utilities": this is a good place to start... and to do in one or more PRs. |
_dict_from_dictproxy
with cloudpickle equivalent that doesn't save the members of the parent classesFixes #250, fixes #332, fixes #365
This PR was very large, so it was broken into pieces: