-
-
Notifications
You must be signed in to change notification settings - Fork 366
Parametrize Array with v2/v3 metadata #3304
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
base: main
Are you sure you want to change the base?
Conversation
Codecov Report❌ Patch coverage is Additional details and impacted files@@ Coverage Diff @@
## main #3304 +/- ##
==========================================
+ Coverage 61.86% 61.93% +0.06%
==========================================
Files 85 86 +1
Lines 10112 10129 +17
==========================================
+ Hits 6256 6273 +17
Misses 3856 3856
🚀 New features to boost your workflow:
|
53da48a
to
d9e50d2
Compare
bbabb9b
to
a168b6c
Compare
9c3938f
to
2807003
Compare
2807003
to
5e56f56
Compare
from zarr.core.array import Array, AsyncArray | ||
from zarr.core.metadata.v2 import ArrayV2Metadata | ||
from zarr.core.metadata.v3 import ArrayV3Metadata |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
these imports will prevent zarr.core.array
from using anything defined in zarr.types
, is that intentional?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(outside of a type-checking context, I mean)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thinking more about this, I think as long as everything in zarr.types
is imported exclusively in if TYPE_CHECKING
blocks, then there's no risk of circular imports. we would only have circular imports if we tried to work with types as values outside of type-checking, for example using get_args(ZarrFormat)
. We can always avoid this by defining a typed constant value somewhere else in the codebase.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I certinaly didn't think about this! So neither intentional or unintentional. I'm not sure I see a better solution, but open to suggestions.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What was the problem that necessitated defining type aliases in the top-level types
file? I wonder if there's another way to solve that. This is my only concern about this PR btw, we can get it in soon after this is resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think there wasn't a problem, and this was a choice 😄 - the circular import mess seems a good reason to move these out and next to the array/group classes. Might be a little while until I find time, so someone else is very free to finish this PR off if I don't get there first.
I think these changes are good, as they make it easier to track the v2-ness of v3-ness of the But since this PR changes the cc @zarr-developers/core-devs |
2a34f73
to
6e33956
Compare
ping @zarr-developers/core-devs |
It has been a longstanding bugbear of mine that there's no easy way to specify a v2 or v3 array type. This especially came up in the context of #3257, which deals specifically with v2/v3 arrays.
This PR ads type parametrization to the
Array
class.After this PR, there is lots of improvements to adding overloads to functions and methods that could be made, but to keep review easier I'd like to leave that for a follow up PR.