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
The existing approach of adding multiple tileset helpers (e.g., hg.cooler, hg.bigwig, etc.) to the hg.server facilitates the creation and addition of tilesets. Although this method is works "fine", it has some potential drawbacks and I'm not thrilled with the inconsistency of the API.
Issues
Confusing Usage / Naming Around Tilesets
Our present system exports all tileset helpers from a top-level flat namespace for convenience. However, it fails to distinguish "tilesets" from other API components associated with view configuration such as hg.view or hg.track. For context, this caused confusion in a code snippet I shared at ISMB conference, where the similar functions of hg.remote and hg.cooler were unclear.
A potential solution could involve grouping tilesets under a separate namespace like hg.tilesets.cooler, but I also see drawbacks in this approach (beyond being more verbose – see next).
Limited Scalability and Extensibility
We aim to simplify the implementation of custom tilesets, however, the current system further convolutes that folks actually have control over the server due to the differences in the API. The tileset helpers hide the server, but if you want a custom tileset you need to find the server. E.g.,
Additionally adding nice tileset helpers requires making changes to higlass-python. I think the best user experience would be to let someone pip install custom-tileset and this now works like our builtin tilesets.
Ideas
I'm been mulling over what a plugin-system / registry for tilesets could look like. I think ideally the end-user API could look something like:
importhiglassashgtileset=hg.server.add("./data.mcool", type="cooler")
tileset=hg.server.add(df, type="my-custom-pandas-tileset") # auto-detected from from a pip-installclassCustomTileset: ...
hg.server.add(CustomTileset(...)) # no type needed because it implements the tileset protocol
You could imagine a registry of tileset helpers per server instance that know how to handle an object:
The server is not a detail we can really hide, so I'd prefer a more explicit API like the first proposal. With the alternative one, most users would be surprised that simply creating a tileset is having server manipulation side effects behind the scenes.
Motivation
The existing approach of adding multiple tileset helpers (e.g.,
hg.cooler
,hg.bigwig
, etc.) to thehg.server
facilitates the creation and addition of tilesets. Although this method is works "fine", it has some potential drawbacks and I'm not thrilled with the inconsistency of the API.Issues
Confusing Usage / Naming Around Tilesets
Our present system exports all tileset helpers from a top-level flat namespace for convenience. However, it fails to distinguish "tilesets" from other API components associated with view configuration such as
hg.view
orhg.track
. For context, this caused confusion in a code snippet I shared at ISMB conference, where the similar functions ofhg.remote
andhg.cooler
were unclear.A potential solution could involve grouping tilesets under a separate namespace like
hg.tilesets.cooler
, but I also see drawbacks in this approach (beyond being more verbose – see next).Limited Scalability and Extensibility
We aim to simplify the implementation of custom tilesets, however, the current system further convolutes that folks actually have control over the server due to the differences in the API. The tileset helpers hide the server, but if you want a custom tileset you need to find the server. E.g.,
Additionally adding nice tileset helpers requires making changes to
higlass-python
. I think the best user experience would be to let someonepip install custom-tileset
and this now works like our builtin tilesets.Ideas
I'm been mulling over what a plugin-system / registry for tilesets could look like. I think ideally the end-user API could look something like:
You could imagine a registry of tileset helpers per server instance that know how to handle an object:
And then plugins could register themselves for the
hg.server
:The text was updated successfully, but these errors were encountered: