only echo when the output pauses in shell-pipe
This commit is contained in:
parent
db8f535b61
commit
dd6a85f480
45
app.go
45
app.go
@ -136,6 +136,12 @@ func (app *app) loop() {
|
|||||||
clientChan := app.ui.readExpr()
|
clientChan := app.ui.readExpr()
|
||||||
serverChan := readExpr()
|
serverChan := readExpr()
|
||||||
|
|
||||||
|
for _, path := range gConfigPaths {
|
||||||
|
if _, err := os.Stat(path); !os.IsNotExist(err) {
|
||||||
|
app.readFile(path)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if gCommand != "" {
|
if gCommand != "" {
|
||||||
p := newParser(strings.NewReader(gCommand))
|
p := newParser(strings.NewReader(gCommand))
|
||||||
if e := p.parseExpr(); e != nil {
|
if e := p.parseExpr(); e != nil {
|
||||||
@ -336,22 +342,41 @@ func (app *app) runShell(s string, args []string, prefix string) {
|
|||||||
|
|
||||||
switch prefix {
|
switch prefix {
|
||||||
case "%":
|
case "%":
|
||||||
go func() {
|
app.cmd = cmd
|
||||||
app.cmd = cmd
|
app.cmdOutBuf = nil
|
||||||
app.cmdOutBuf = nil
|
app.ui.msg = ""
|
||||||
app.ui.msg = ""
|
app.ui.cmdPrefix = ">"
|
||||||
app.ui.cmdPrefix = ">"
|
|
||||||
|
|
||||||
reader := bufio.NewReader(out)
|
reader := bufio.NewReader(out)
|
||||||
|
bytes := make(chan byte, 1000)
|
||||||
|
|
||||||
|
go func() {
|
||||||
for {
|
for {
|
||||||
b, err := reader.ReadByte()
|
b, err := reader.ReadByte()
|
||||||
if err == io.EOF {
|
if err == io.EOF {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
app.cmdOutBuf = append(app.cmdOutBuf, b)
|
bytes <- b
|
||||||
app.ui.exprChan <- &callExpr{"echo", []string{string(app.cmdOutBuf)}, 1}
|
}
|
||||||
if b == '\n' || b == '\r' {
|
close(bytes)
|
||||||
app.cmdOutBuf = nil
|
}()
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
loop:
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case b, ok := <-bytes:
|
||||||
|
switch {
|
||||||
|
case !ok:
|
||||||
|
break loop
|
||||||
|
case b == '\n' || b == '\r':
|
||||||
|
app.ui.exprChan <- &callExpr{"echo", []string{string(app.cmdOutBuf)}, 1}
|
||||||
|
app.cmdOutBuf = nil
|
||||||
|
default:
|
||||||
|
app.cmdOutBuf = append(app.cmdOutBuf, b)
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
app.ui.exprChan <- &callExpr{"echo", []string{string(app.cmdOutBuf)}, 1}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -33,12 +33,6 @@ func run() {
|
|||||||
|
|
||||||
app := newApp()
|
app := newApp()
|
||||||
|
|
||||||
for _, path := range gConfigPaths {
|
|
||||||
if _, err := os.Stat(path); !os.IsNotExist(err) {
|
|
||||||
app.readFile(path)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := app.nav.readMarks(); err != nil {
|
if err := app.nav.readMarks(); err != nil {
|
||||||
app.ui.printf("reading marks file: %s", err)
|
app.ui.printf("reading marks file: %s", err)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user