-
Notifications
You must be signed in to change notification settings - Fork 22
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
Consider making Replica and DependencyMap traits #403
Comments
There are some constraints on the data format that might make such usage difficult:
That said, I'm interested in what you have in mind. A concrete case for storing task data in a different backend would help to clarify where these interfaces need to be changed. Note also #372 is going to happen soon, and will modify the TC API pretty substantially. |
I'll try to Create an example, it might take some time though |
I will try to implement most of the system straight into SurrealDB to showcase the possibilities. Of course it might sometimes be better to use dedicated code for this but i think creating as much funtionality as possible, straight in the db shows the ideas better. Also was thinking of trying out using BerkleyDB or rocksDB etc for the storage layer just to see if there is difference in the performance |
Sounds good! |
It might make more sense to create a struct that implements the The set of methods provided in Let's see if this bug branches in either of those directions: creating a new storage backend using SurrealDB; or modifying the |
There's some discussion in #472 of making it possible to express filter expressions in a way that the storage backend could, optionally, interpret for the caller. I think that covers part of what is proposed here, but dependency maps are not mentioned. I'll add a note about that, and close this issue in favor of that discussion. |
As some DBMSs (like SurrealDB) might be able to represent for example dependencies straight from the DB it might be a good idea to abstract the
Replica
andDependencyMap
to traits so that they can be given other Solutions than the way Rust implementation handles calculating dependencies, it might be a good idea to make Traits for these.In some cases this might help as Well with bindings to other languages/platforms
The text was updated successfully, but these errors were encountered: