This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2021-08-17
Channels
- # announcements (13)
- # beginners (56)
- # brompton (1)
- # cider (2)
- # cljsrn (10)
- # clojure (369)
- # clojure-australia (4)
- # clojure-boston (1)
- # clojure-europe (28)
- # clojure-nl (1)
- # clojure-spec (1)
- # clojure-uk (18)
- # clojurescript (26)
- # data-science (2)
- # datahike (4)
- # datalog (2)
- # datasplash (6)
- # datomic (9)
- # events (1)
- # kaocha (4)
- # macro (1)
- # malli (22)
- # meander (40)
- # membrane (30)
- # music (1)
- # nbb (3)
- # news-and-articles (3)
- # off-topic (12)
- # practicalli (1)
- # re-frame (19)
- # remote-jobs (1)
- # sci (22)
- # shadow-cljs (15)
- # spacemacs (4)
- # tools-deps (40)
- # xtdb (26)
There's like this project: https://github.com/dolthub/dolt. Maybe it can be useful, at least as an inspiration?
So... by virtue of datahike being implemented via a persistent data structure (the hitchiker tree), it's already possible to do things like fork and clone (with structural sharing)., So if that's your interest, we're already there. Merging is the real kicker, and frankly I'm a little skeptical about in relation to dolt, given the scant documentation about it in the README. Conflict free merging implies a CRDT structure, which corresponds with constraints around the kinds of things you can express in the data-language, and imparts a heavy toll in terms of how you model things. Dolt seems too "easy" for me to expect that it would always have the desired results. That having been said, @whilo has thought a lot about this and how deal with merging and resolving conflicts (e.g. https://arxiv.org/pdf/1508.05545.pdf), and I think it's an ultimate goal to incorporate this kind of functionality into datahike (though lower priority presently than things like performance, datomic parity, front-end support, etc).
So is it possible to implement datahike on top of git? Maybe; maybe even probably (though I think the question is with how much work). The real question is what would it get you, and I think the answer is not much given that the project is already headed towards some of the same potential value propositions in more principled (and likely performant) ways.
I could obviously be misunderstanding any number of things here, so please let me know if that's the case, but hopefully this helps a bit.