mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-02-20 23:47:21 -05:00
fix error detection for pipeline
This commit is contained in:
parent
ccafce3c9b
commit
48e825567a
@ -3,6 +3,7 @@ package buf
|
|||||||
import (
|
import (
|
||||||
"io"
|
"io"
|
||||||
"net"
|
"net"
|
||||||
|
"os"
|
||||||
|
|
||||||
"v2ray.com/core/common"
|
"v2ray.com/core/common"
|
||||||
"v2ray.com/core/common/errors"
|
"v2ray.com/core/common/errors"
|
||||||
@ -22,7 +23,7 @@ func ReadAllToMultiBuffer(reader io.Reader) (MultiBuffer, error) {
|
|||||||
mb.Append(b)
|
mb.Append(b)
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if errors.Cause(err) == io.EOF {
|
if errors.Cause(err) == io.EOF || errors.Cause(err) == os.ErrClosed {
|
||||||
return mb, nil
|
return mb, nil
|
||||||
}
|
}
|
||||||
mb.Release()
|
mb.Release()
|
||||||
|
@ -3,6 +3,7 @@ package errors // import "v2ray.com/core/common/errors"
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"v2ray.com/core/common/log"
|
"v2ray.com/core/common/log"
|
||||||
@ -162,12 +163,27 @@ func Cause(err error) error {
|
|||||||
if err == nil {
|
if err == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
L:
|
||||||
for {
|
for {
|
||||||
inner, ok := err.(hasInnerError)
|
switch inner := err.(type) {
|
||||||
if !ok || inner.Inner() == nil {
|
case hasInnerError:
|
||||||
break
|
if inner.Inner() == nil {
|
||||||
|
break L
|
||||||
}
|
}
|
||||||
err = inner.Inner()
|
err = inner.Inner()
|
||||||
|
case *os.PathError:
|
||||||
|
if inner.Err == nil {
|
||||||
|
break L
|
||||||
|
}
|
||||||
|
err = inner.Err
|
||||||
|
case *os.SyscallError:
|
||||||
|
if inner.Err == nil {
|
||||||
|
break L
|
||||||
|
}
|
||||||
|
err = inner.Err
|
||||||
|
default:
|
||||||
|
break L
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@ import (
|
|||||||
func Run(args []string, input io.Reader) (buf.MultiBuffer, error) {
|
func Run(args []string, input io.Reader) (buf.MultiBuffer, error) {
|
||||||
v2ctl := platform.GetToolLocation("v2ctl")
|
v2ctl := platform.GetToolLocation("v2ctl")
|
||||||
if _, err := os.Stat(v2ctl); err != nil {
|
if _, err := os.Stat(v2ctl); err != nil {
|
||||||
return nil, err
|
return nil, newError("v2ctl doesn't exist").Base(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
errBuffer := &buf.MultiBuffer{}
|
errBuffer := &buf.MultiBuffer{}
|
||||||
@ -30,19 +30,19 @@ func Run(args []string, input io.Reader) (buf.MultiBuffer, error) {
|
|||||||
|
|
||||||
stdoutReader, err := cmd.StdoutPipe()
|
stdoutReader, err := cmd.StdoutPipe()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, newError("failed to get stdout from v2ctl").Base(err)
|
||||||
}
|
}
|
||||||
defer stdoutReader.Close()
|
defer stdoutReader.Close()
|
||||||
|
|
||||||
if err := cmd.Start(); err != nil {
|
if err := cmd.Start(); err != nil {
|
||||||
return nil, err
|
return nil, newError("failed to start v2ctl").Base(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
var content buf.MultiBuffer
|
var content buf.MultiBuffer
|
||||||
loadTask := func() error {
|
loadTask := func() error {
|
||||||
c, err := buf.ReadAllToMultiBuffer(stdoutReader)
|
c, err := buf.ReadAllToMultiBuffer(stdoutReader)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return newError("failed to read config").Base(err)
|
||||||
}
|
}
|
||||||
content = c
|
content = c
|
||||||
return nil
|
return nil
|
||||||
|
Loading…
x
Reference in New Issue
Block a user