Skip to content

Commit

Permalink
coreunix: fix Add() docs regarding pinning
Browse files Browse the repository at this point in the history
License: MIT
Signed-off-by: Lars Gierth <larsg@systemli.org>
  • Loading branch information
Lars Gierth committed Dec 16, 2016
1 parent e2ba43c commit 3b10b44
Showing 1 changed file with 7 additions and 3 deletions.
10 changes: 7 additions & 3 deletions core/coreunix/add.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@ import (

var log = logging.Logger("coreunix")

// TODO The Pin/GC locks in this file are wonky. Need to have a really close look.

// how many bytes of progress to wait before sending a progress update message
const progressReaderIncrement = 1024 * 256

Expand Down Expand Up @@ -114,7 +116,7 @@ func (adder *Adder) SetMfsRoot(r *mfs.Root) {
adder.mr = r
}

// Perform the actual add & pin locally, outputting results to reader
// Constructs a node from reader's data, and adds it. Doesn't pin.
func (adder Adder) add(reader io.Reader) (node.Node, error) {
chnk, err := chunk.FromString(reader, adder.Chunker)
if err != nil {
Expand Down Expand Up @@ -251,12 +253,14 @@ func (adder *Adder) outputDirs(path string, fsn mfs.FSNode) error {
}
}

// Add builds a merkledag from the a reader, pinning all objects to the local
// datastore. Returns a key representing the root node.
// Builds a merkledag node from a reader, adds it to the blockstore,
// and returns the key representing that node.
// If you want to pin it, use NewAdder() and Adder.PinRoot().
func Add(n *core.IpfsNode, r io.Reader) (string, error) {
return AddWithContext(n.Context(), n, r)
}

// Same as Add(), but with a custom context.
func AddWithContext(ctx context.Context, n *core.IpfsNode, r io.Reader) (string, error) {
defer n.Blockstore.PinLock().Unlock()

Expand Down

0 comments on commit 3b10b44

Please sign in to comment.