TypeError: unhashable type: 'dict' upon loading serde-pickle's outputs in Python
Calandiel opened this issue · 4 comments
I believe it happens when structs are used as keys in hash maps and hash sets.
They seem to be turned into dictionaries of their own (which is fair enough) but having them as keys in Python doesn't really work.
Perhaps one could serialize them to frozensets instead? Or issue a warning if the user tries serializing something that won't deserialize in Python.
Hm, good point. This is hard - I'm not sure if serializing structs differently only when they are dict keys / set items is feasible or even wanted...
Certainly depends on the intended use case of the library.
If it's outputs are supposed to be loadable in Python, the way it works now is quite a significant limitation.
If having two different serialization patterns isn't possible, perhaps serializing structs to frozensets would be a good compromise?
But that gives up mutability on Python side for structs that arent keys, so it wouldn't be ideal either.
Perhaps a different option would be to have two serializers, one which targets dictionaries and one which targets frozen sets?
Just throwing ideas, I'm not sure myself what would be the best way to handle it from end users perspective.
It's no problem to add a different serializing mode, since 1.0 we have the SerOptions struct that can be extended with new features.
However, it's not clear to me how the alternate representation would look with named fields. Can you make a suggestion?
Named tuples are hashable in Python, they might be a good candidate instead of dictionaries.