mirror of
https://github.com/SagerNet/sing-box.git
synced 2025-01-08 09:01:18 +00:00
platform: Add stderr redirect
This commit is contained in:
parent
55afaa87da
commit
f2749bc29d
|
@ -63,7 +63,7 @@ func (s *CommandServer) handleLogConn(conn net.Conn) error {
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case <-ctx.Done():
|
case <-ctx.Done():
|
||||||
return ctx.Err()
|
return nil
|
||||||
case message := <-subscription:
|
case message := <-subscription:
|
||||||
err = writeLog(conn, []byte(message))
|
err = writeLog(conn, []byte(message))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
29
experimental/libbox/log.go
Normal file
29
experimental/libbox/log.go
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
//go:build darwin || linux
|
||||||
|
|
||||||
|
package libbox
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"golang.org/x/sys/unix"
|
||||||
|
)
|
||||||
|
|
||||||
|
var stderrFile *os.File
|
||||||
|
|
||||||
|
func RedirectStderr(path string) error {
|
||||||
|
if stats, err := os.Stat(path); err == nil && stats.Size() > 0 {
|
||||||
|
_ = os.Rename(path, path+".old")
|
||||||
|
}
|
||||||
|
outputFile, err := os.Create(path)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = unix.Dup2(int(outputFile.Fd()), int(os.Stderr.Fd()))
|
||||||
|
if err != nil {
|
||||||
|
outputFile.Close()
|
||||||
|
os.Remove(outputFile.Name())
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
stderrFile = outputFile
|
||||||
|
return nil
|
||||||
|
}
|
Loading…
Reference in a new issue