Skip to content

Commit

Permalink
Don't leak epoll/kqueue fd on error (#10)
Browse files Browse the repository at this point in the history
  • Loading branch information
tklauser authored Jun 22, 2022
1 parent d8fcbea commit 9e10037
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 0 deletions.
1 change: 1 addition & 0 deletions cancelreader_bsd.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ func NewReader(reader io.Reader) (CancelReader, error) {

r.cancelSignalReader, r.cancelSignalWriter, err = os.Pipe()
if err != nil {
_ = unix.Close(kQueue)
return nil, err
}

Expand Down
3 changes: 3 additions & 0 deletions cancelreader_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ func NewReader(reader io.Reader) (CancelReader, error) {

r.cancelSignalReader, r.cancelSignalWriter, err = os.Pipe()
if err != nil {
_ = unix.Close(epoll)
return nil, err
}

Expand All @@ -45,6 +46,7 @@ func NewReader(reader io.Reader) (CancelReader, error) {
Fd: int32(file.Fd()),
})
if err != nil {
_ = unix.Close(epoll)
return nil, fmt.Errorf("add reader to epoll interrest list")
}

Expand All @@ -53,6 +55,7 @@ func NewReader(reader io.Reader) (CancelReader, error) {
Fd: int32(r.cancelSignalReader.Fd()),
})
if err != nil {
_ = unix.Close(epoll)
return nil, fmt.Errorf("add reader to epoll interrest list")
}

Expand Down

0 comments on commit 9e10037

Please sign in to comment.