Skip to content

Commit

Permalink
Fix ioloop groutine leaks bug. (chzyer#136)
Browse files Browse the repository at this point in the history
* Fix ioloop groutine leaks bug.

* fix func (o *Operation) ioloop()  L:125 hangs
  • Loading branch information
nxsre authored and chzyer committed Dec 8, 2017
1 parent 40d6036 commit f6d7a1f
Show file tree
Hide file tree
Showing 5 changed files with 19 additions and 9 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.vscode/*
2 changes: 1 addition & 1 deletion operation.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ func NewOperation(t *Terminal, cfg *Config) *Operation {
t: t,
buf: NewRuneBuffer(t, cfg.Prompt, cfg, width),
outchan: make(chan []rune),
errchan: make(chan error),
errchan: make(chan error, 1),
}
op.w = op.buf.w
op.SetConfig(cfg)
Expand Down
3 changes: 2 additions & 1 deletion readline.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ type Config struct {

FuncGetWidth func() int

Stdin io.Reader
Stdin io.ReadCloser
StdinWriter io.Writer
Stdout io.Writer
Stderr io.Writer
Expand Down Expand Up @@ -274,6 +274,7 @@ func (i *Instance) Close() error {
if err := i.Terminal.Close(); err != nil {
return err
}
i.Config.Stdin.Close()
i.Operation.Close()
return nil
}
Expand Down
3 changes: 2 additions & 1 deletion remote.go
Original file line number Diff line number Diff line change
Expand Up @@ -189,11 +189,12 @@ loop:
}
}

func (r *RemoteSvr) Close() {
func (r *RemoteSvr) Close() error {
if atomic.CompareAndSwapInt32(&r.closed, 0, 1) {
close(r.stopChan)
r.conn.Close()
}
return nil
}

func (r *RemoteSvr) readLoop(buf *bufio.Reader) {
Expand Down
19 changes: 13 additions & 6 deletions std.go
Original file line number Diff line number Diff line change
Expand Up @@ -137,22 +137,20 @@ func (c *CancelableStdin) Close() error {
type FillableStdin struct {
sync.Mutex
stdin io.Reader
stdinBuffer io.Reader
stdinBuffer io.ReadCloser
buf []byte
bufErr error
}

// NewFillableStdin gives you FillableStdin
func NewFillableStdin(stdin io.Reader) (io.Reader, io.Writer) {

func NewFillableStdin(stdin io.Reader) (io.ReadCloser, io.Writer) {
r, w := io.Pipe()
s := &FillableStdin{
stdinBuffer: r,
stdin: stdin,
}
s.ioloop()
return s, w

}

func (s *FillableStdin) ioloop() {
Expand All @@ -161,6 +159,11 @@ func (s *FillableStdin) ioloop() {
bufR := make([]byte, 100)
var n int
n, s.bufErr = s.stdinBuffer.Read(bufR)
if s.bufErr != nil {
if s.bufErr == io.ErrClosedPipe {
break
}
}
s.Lock()
s.buf = append(s.buf, bufR[:n]...)
s.Unlock()
Expand All @@ -184,7 +187,11 @@ func (s *FillableStdin) Read(p []byte) (n int, err error) {
return n, cerr
}
s.Unlock()
n, err = s.stdin.Read(p)
return n, err
}

return s.stdin.Read(p)

func (s *FillableStdin) Close() error {
s.stdinBuffer.Close()
return nil
}

0 comments on commit f6d7a1f

Please sign in to comment.