- 25 Jan, 2018 1 commit
-
-
Steven Allen authored
-
- 16 Nov, 2017 4 commits
-
-
Steven Allen authored
I considered (well, implemented then threw it away) allowing contexts on all calls to Batch (Add, Commit, etc). However, really, you should treat a batch as a single large "operation". I also went down the road of generalizing batches to sessions. However, it became immediately obvious that permitting add *and* remove *and* fetch would require a lot of bookkeeping and that you'd lose a lot of performance. So, we'll do that separately.
-
Steven Allen authored
We'll need these for slower/remote datastores.
-
Steven Allen authored
-
Steven Allen authored
The caller can just call `node.Cid()` and returning CIDs from `AddMany` requires allocation.
-
- 15 Nov, 2017 1 commit
-
-
Steven Allen authored
1. Add is already idempotent. This makes remove match. 2. Generally, all we care about is that the node no longer exists in the DAG. If two callers remove a node at the same time, they should both succeed. Currently, we *ignore* the result of Remove in go-ipfs. IMO, it would be better to let errors be *errors* and only return an error if something goes wrong. 3. This can be significantly faster. It allows us to batch/queue removes (as long as we guarantee that they'll eventually happen). 4. This matches how most databases/key-value stores operate. An alternative would be to return `(deleted bool, err error)` but then we don't get the speedup.
-
- 16 Oct, 2017 1 commit
-
-
Steven Allen authored
-