Make gVisor optional

This commit is contained in:
世界 2022-09-15 11:19:31 +08:00
parent 057dd738a7
commit 0e80d729a3
No known key found for this signature in database
GPG key ID: CD109927C34A63C4
11 changed files with 23 additions and 26 deletions

View file

@ -1,4 +1,4 @@
//go:build !(no_gvisor || !(linux || windows || darwin))
//go:build with_gvisor
package tun
@ -22,6 +22,8 @@ import (
"gvisor.dev/gvisor/pkg/waiter"
)
const WithGVisor = true
const defaultNIC tcpip.NICID = 1
type GVisor struct {
@ -45,7 +47,7 @@ func NewGVisor(
) (Stack, error) {
gTun, isGTun := options.Tun.(GVisorTun)
if !isGTun {
return nil, ErrGVisorUnsupported
return nil, E.New("gVisor stack is unsupported on current platform")
}
return &GVisor{

View file

@ -1,4 +1,4 @@
//go:build !(no_gvisor || !(linux || windows || darwin))
//go:build with_gvisor
package tun

View file

@ -1,4 +1,4 @@
//go:build !(no_gvisor || !(linux || windows || darwin))
//go:build with_gvisor
package tun

View file

@ -1,9 +0,0 @@
//go:build !no_gvisor && !(linux || windows || darwin)
package tun
func NewGVisor(
options StackOptions,
) (Stack, error) {
return nil, ErrGVisorUnsupported
}

View file

@ -1,7 +1,13 @@
//go:build no_gvisor
//go:build !with_gvisor
package tun
import E "github.com/sagernet/sing/common/exceptions"
const WithGVisor = false
var ErrGVisorNotIncluded = E.New(`gVisor is not included in this build, rebuild with -tags with_gvisor`)
func NewGVisor(
options StackOptions,
) (Stack, error) {

View file

@ -1,4 +1,4 @@
//go:build !(no_gvisor || !(linux || windows || darwin))
//go:build with_gvisor
package tun

View file

@ -2,8 +2,10 @@
package tun
import E "github.com/sagernet/sing/common/exceptions"
func NewLWIP(
options StackOptions,
) (Stack, error) {
return nil, ErrLWIPNotIncluded
return nil, E.New(`LWIP is not included in this build, rebuild with -tags with_lwip`)
}

View file

@ -8,12 +8,6 @@ import (
"github.com/sagernet/sing/common/logger"
)
var (
ErrGVisorNotIncluded = E.New("gVisor is disabled in current build, try build without -tags `no_gvisor`")
ErrGVisorUnsupported = E.New("gVisor stack is unsupported on current platform")
ErrLWIPNotIncluded = E.New("LWIP stack is disabled in current build, try build with -tags `with_lwip` and CGO_ENABLED=1")
)
type Stack interface {
Start() error
Close() error
@ -37,7 +31,9 @@ func NewStack(
options StackOptions,
) (Stack, error) {
switch stack {
case "gvisor", "":
case "":
return NewSystem(options)
case "gvisor":
return NewGVisor(options)
case "system":
return NewSystem(options)

View file

@ -1,4 +1,4 @@
//go:build !no_gvisor && darwin
//go:build with_gvisor && darwin
package tun

View file

@ -1,4 +1,4 @@
//go:build !no_gvisor && linux
//go:build with_gvisor && linux
package tun

View file

@ -1,4 +1,4 @@
//go:build !no_gvisor && windows
//go:build with_gvisor && windows
package tun