From 7e9b5ad967d1d330518521c18c166b3e556368dc Mon Sep 17 00:00:00 2001 From: Xiaodong Liu Date: Thu, 28 May 2020 18:29:21 +0800 Subject: [PATCH] solve the undefined: unix.Dup2 compile error on mips64le error in detail: ../internal/remote/output_interceptor_unix.go:41:2: undefined: unix.Dup2 ../internal/remote/output_interceptor_unix.go:42:2: undefined: unix.Dup2 there is Dup2 syscall only on amd64, other arch is Dup3 instead. Signed-off-by: Xiaodong Liu --- internal/remote/output_interceptor_unix.go | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/internal/remote/output_interceptor_unix.go b/internal/remote/output_interceptor_unix.go index 774967db66..5f23dad3e8 100644 --- a/internal/remote/output_interceptor_unix.go +++ b/internal/remote/output_interceptor_unix.go @@ -6,6 +6,7 @@ import ( "errors" "io/ioutil" "os" + "runtime" "github.com/nxadm/tail" "golang.org/x/sys/unix" @@ -38,8 +39,14 @@ func (interceptor *outputInterceptor) StartInterceptingOutput() error { // This might call Dup3 if the dup2 syscall is not available, e.g. on // linux/arm64 or linux/riscv64 - unix.Dup2(int(interceptor.redirectFile.Fd()), 1) - unix.Dup2(int(interceptor.redirectFile.Fd()), 2) + switch { + case runtime.GOOS == "linux" && runtime.GOARCH == "amd64": + unix.Dup2(int(interceptor.redirectFile.Fd()), 1) + unix.Dup2(int(interceptor.redirectFile.Fd()), 2) + default: + unix.Dup3(int(interceptor.redirectFile.Fd()), 1, 0) + unix.Dup3(int(interceptor.redirectFile.Fd()), 2, 0) + } if interceptor.streamTarget != nil { interceptor.tailer, _ = tail.TailFile(interceptor.redirectFile.Name(), tail.Config{Follow: true})