Commit 121dfb10 authored by Matt Bell's avatar Matt Bell

core/commands: Fixed progress bar line clear race condition in 'add'

parent 2363cb63
package commands package commands
import ( import (
"bytes"
"errors" "errors"
"fmt" "fmt"
"io" "io"
...@@ -108,9 +107,13 @@ remains to be implemented. ...@@ -108,9 +107,13 @@ remains to be implemented.
res.SetError(u.ErrCast(), cmds.ErrNormal) res.SetError(u.ErrCast(), cmds.ErrNormal)
return return
} }
res.SetOutput(nil)
wrapperChan := make(chan interface{}) quiet, _, err := res.Request().Option("quiet").Bool()
res.SetOutput((<-chan interface{})(wrapperChan)) if err != nil {
res.SetError(u.ErrCast(), cmds.ErrNormal)
return
}
size := int64(0) size := int64(0)
s, found := res.Request().Values()["size"] s, found := res.Request().Values()["size"]
...@@ -138,7 +141,6 @@ remains to be implemented. ...@@ -138,7 +141,6 @@ remains to be implemented.
bar.Update() bar.Update()
} }
go func() {
lastFile := "" lastFile := ""
var totalProgress, prevFiles, lastBytes int64 var totalProgress, prevFiles, lastBytes int64
...@@ -149,7 +151,11 @@ remains to be implemented. ...@@ -149,7 +151,11 @@ remains to be implemented.
// clear progress bar line before we print "added x" output // clear progress bar line before we print "added x" output
fmt.Fprintf(os.Stderr, "\r%s\r", strings.Repeat(" ", terminalWidth)) fmt.Fprintf(os.Stderr, "\r%s\r", strings.Repeat(" ", terminalWidth))
} }
wrapperChan <- output if quiet {
fmt.Printf("%s\n", output.Hash)
} else {
fmt.Printf("added %s %s\n", output.Hash, output.Name)
}
} else { } else {
log.Debugf("add progress: %v %v\n", output.Name, output.Bytes) log.Debugf("add progress: %v %v\n", output.Name, output.Bytes)
...@@ -174,42 +180,6 @@ remains to be implemented. ...@@ -174,42 +180,6 @@ remains to be implemented.
bar.Update() bar.Update()
} }
} }
close(wrapperChan)
}()
},
Marshalers: cmds.MarshalerMap{
cmds.Text: func(res cmds.Response) (io.Reader, error) {
outChan, ok := res.Output().(<-chan interface{})
if !ok {
return nil, u.ErrCast()
}
quiet, _, err := res.Request().Option("quiet").Bool()
if err != nil {
return nil, err
}
marshal := func(v interface{}) (io.Reader, error) {
obj, ok := v.(*AddedObject)
if !ok {
return nil, u.ErrCast()
}
var buf bytes.Buffer
if quiet {
buf.WriteString(fmt.Sprintf("%s\n", obj.Hash))
} else {
buf.WriteString(fmt.Sprintf("added %s %s\n", obj.Hash, obj.Name))
}
return &buf, nil
}
return &cmds.ChannelMarshaler{
Channel: outChan,
Marshaler: marshal,
}, nil
},
}, },
Type: AddedObject{}, Type: AddedObject{},
} }
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment