issues: 672912921
This data as json
| id | node_id | number | title | user | state | locked | assignee | milestone | comments | created_at | updated_at | closed_at | author_association | active_lock_reason | draft | pull_request | body | reactions | performed_via_github_app | state_reason | repo | type | 
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 672912921 | MDU6SXNzdWU2NzI5MTI5MjE= | 4309 | Flexible Backend - AbstractDataStore definition | 35919497 | closed | 0 | 6 | 2020-08-04T16:14:16Z | 2021-03-09T01:04:00Z | 2021-03-09T01:04:00Z | COLLABORATOR | I just want to do a small recap of the current proposals for the class AbstractDataStore refactor discussed with @shoyer, @jhamman, and @alexamici. Proposal 1: Store returns: - xr.Variables with the list of filters to apply to every variable - dataset attributes - encodings Xarray applies to every variable only the filters selected by the backend before building the xr.Dataset. Proposal 2: Store returns: - xr.Variables with all needed filters applied (configured by xarray), - dataset attributes - encodings Xarray builds the xr.Dataset Proposal 3: Store returns: - xr.Dataset Before going on I'd like to collect pros and cons. For my understanding: Proposal 1 pros: - the backend is free to decide which representation to provide. - more control on the backend (? not necessary true, the backend can decide to apply all the filters internally and provide xarray and empty list of filters to be applied) - enable / disable filters logic would be in xarray. - all the filters (applied by xarray) should have a similar interface. - maybe registered filters could be used by other backends cons: - confusing backend-xarray interface. - more difficult to define interfaces. More conflicts (registered filters with the same name...) - need more structure to define this interface, more code to maintain. Proposal 2 pros: - interface backend-xarray is clearer / backend and xarray have well different defined tasks. - interface would be minimal and easier to implement - no intermediate representations - less code to maintain cons:
- less control on filters.
- more complex explicit definition of the interface (every filter must understand what  The minimal interface would be something like that:
 Proposal 3 pros w.r.t. porposal 2: - decode_coordinates is done by the backend as the other filters. cons? Any suggestions? | {
    "url": "https://api.github.com/repos/pydata/xarray/issues/4309/reactions",
    "total_count": 0,
    "+1": 0,
    "-1": 0,
    "laugh": 0,
    "hooray": 0,
    "confused": 0,
    "heart": 0,
    "rocket": 0,
    "eyes": 0
} | completed | 13221727 | issue |