Browse Source

simplify error creation

Darien Raymond 7 years ago
parent
commit
d55fbd7f8d
48 changed files with 208 additions and 87 deletions
  1. 3 1
      app/commander/errors.generated.go
  2. 3 1
      app/dispatcher/errors.generated.go
  3. 5 1
      app/dns/errors.generated.go
  4. 3 1
      app/log/command/errors.generated.go
  5. 5 1
      app/log/errors.generated.go
  6. 5 1
      app/policy/errors.generated.go
  7. 3 1
      app/proxyman/command/errors.generated.go
  8. 3 1
      app/proxyman/inbound/errors.generated.go
  9. 3 1
      app/proxyman/mux/errors.generated.go
  10. 3 1
      app/proxyman/outbound/errors.generated.go
  11. 5 1
      app/router/errors.generated.go
  12. 3 1
      app/stats/command/errors.generated.go
  13. 5 1
      app/stats/errors.generated.go
  14. 5 1
      common/buf/errors.generated.go
  15. 5 1
      common/crypto/errors.generated.go
  16. 5 1
      common/errors.generated.go
  17. 20 28
      common/errors/errorgen/main.go
  18. 17 10
      common/errors/errors.go
  19. 6 4
      common/errors/errors_test.go
  20. 5 1
      common/net/errors.generated.go
  21. 3 1
      common/platform/ctlcmd/errors.generated.go
  22. 5 1
      common/protocol/errors.generated.go
  23. 3 1
      common/protocol/tls/cert/errors.generated.go
  24. 5 1
      common/retry/errors.generated.go
  25. 5 1
      errors.generated.go
  26. 3 1
      main/confloader/external/errors.generated.go
  27. 5 1
      main/errors.generated.go
  28. 5 1
      main/json/errors.generated.go
  29. 3 1
      proxy/blackhole/errors.generated.go
  30. 3 1
      proxy/dokodemo/errors.generated.go
  31. 3 1
      proxy/freedom/errors.generated.go
  32. 5 1
      proxy/http/errors.generated.go
  33. 3 1
      proxy/mtproto/errors.generated.go
  34. 3 1
      proxy/shadowsocks/errors.generated.go
  35. 3 1
      proxy/socks/errors.generated.go
  36. 3 1
      proxy/vmess/encoding/errors.generated.go
  37. 3 1
      proxy/vmess/errors.generated.go
  38. 3 1
      proxy/vmess/inbound/errors.generated.go
  39. 3 1
      proxy/vmess/outbound/errors.generated.go
  40. 3 1
      transport/internet/domainsocket/errors.generated.go
  41. 3 1
      transport/internet/errors.generated.go
  42. 3 1
      transport/internet/headers/http/errors.generated.go
  43. 3 1
      transport/internet/http/errors.generated.go
  44. 3 1
      transport/internet/kcp/errors.generated.go
  45. 3 1
      transport/internet/tcp/errors.generated.go
  46. 3 1
      transport/internet/tls/errors.generated.go
  47. 3 1
      transport/internet/udp/errors.generated.go
  48. 3 1
      transport/internet/websocket/errors.generated.go

+ 3 - 1
app/commander/errors.generated.go

@@ -2,6 +2,8 @@ package commander
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("App", "Commander")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
app/dispatcher/errors.generated.go

@@ -2,6 +2,8 @@ package dispatcher
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("App", "Dispatcher")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 5 - 1
app/dns/errors.generated.go

@@ -2,4 +2,8 @@ package dns
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("App", "DNS") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 3 - 1
app/log/command/errors.generated.go

@@ -2,6 +2,8 @@ package command
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("App", "Log", "Command")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 5 - 1
app/log/errors.generated.go

@@ -2,4 +2,8 @@ package log
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("App", "Log") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 5 - 1
app/policy/errors.generated.go

@@ -2,4 +2,8 @@ package policy
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("App", "Policy") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 3 - 1
app/proxyman/command/errors.generated.go

@@ -2,6 +2,8 @@ package command
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("App", "Proxyman", "Command")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
app/proxyman/inbound/errors.generated.go

@@ -2,6 +2,8 @@ package inbound
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("App", "Proxyman", "Inbound")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
app/proxyman/mux/errors.generated.go

@@ -2,6 +2,8 @@ package mux
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("App", "Proxyman", "Mux")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
app/proxyman/outbound/errors.generated.go

@@ -2,6 +2,8 @@ package outbound
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("App", "Proxyman", "Outbound")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 5 - 1
app/router/errors.generated.go

@@ -2,4 +2,8 @@ package router
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("App", "Router") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 3 - 1
app/stats/command/errors.generated.go

@@ -2,6 +2,8 @@ package command
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("App", "Stats", "Command")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 5 - 1
app/stats/errors.generated.go

@@ -2,4 +2,8 @@ package stats
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("App", "Stats") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 5 - 1
common/buf/errors.generated.go

@@ -2,4 +2,8 @@ package buf
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Buf") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 5 - 1
common/crypto/errors.generated.go

@@ -2,4 +2,8 @@ package crypto
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Crypto") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 5 - 1
common/errors.generated.go

@@ -2,4 +2,8 @@ package common
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Common") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 20 - 28
common/errors/errorgen/main.go

@@ -3,47 +3,39 @@
 package main
 package main
 
 
 import (
 import (
-	"flag"
 	"fmt"
 	"fmt"
 	"log"
 	"log"
 	"os"
 	"os"
-	"strings"
-
-	"v2ray.com/core/common"
-)
-
-var (
-	pkg  = flag.String("pkg", "", "Target package")
-	path = flag.String("path", "", "Path")
+	"path/filepath"
 )
 )
 
 
-func main() {
-	flag.Parse()
-
-	if len(*pkg) == 0 {
-		panic("Package is not specified.")
-	}
-
-	if len(*path) == 0 {
-		panic("Path is not specified.")
+func getCurrentPkg() (string, error) {
+	path, err := os.Getwd()
+	if err != nil {
+		return "", err
 	}
 	}
+	return filepath.Base(path), nil
+}
 
 
-	paths := strings.Split(*path, ",")
-	for i := range paths {
-		paths[i] = "\"" + paths[i] + "\""
+func main() {
+	pkg, err := getCurrentPkg()
+	if err != nil {
+		log.Fatal("Failed to get current package: ", err.Error())
+		return
 	}
 	}
-	pathStr := strings.Join(paths, ", ")
 
 
 	file, err := os.OpenFile("errors.generated.go", os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0644)
 	file, err := os.OpenFile("errors.generated.go", os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0644)
 	if err != nil {
 	if err != nil {
 		log.Fatalf("Failed to generate errors.generated.go: %v", err)
 		log.Fatalf("Failed to generate errors.generated.go: %v", err)
+		return
 	}
 	}
 
 
-	common.Must2(fmt.Fprintln(file, "package", *pkg))
-	common.Must2(fmt.Fprintln(file, ""))
-	common.Must2(fmt.Fprintln(file, "import \"v2ray.com/core/common/errors\""))
-	common.Must2(fmt.Fprintln(file, ""))
-	common.Must2(fmt.Fprintln(file, "func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("+pathStr+") }"))
+	fmt.Fprintln(file, "package", pkg)
+	fmt.Fprintln(file, "")
+	fmt.Fprintln(file, "import \"v2ray.com/core/common/errors\"")
+	fmt.Fprintln(file, "")
+	fmt.Fprintln(file, "type errPathObjHolder struct {}")
+	fmt.Fprintln(file, "func newError(values ...interface{}) *errors.Error { return errors.New(values...).WithPathObj(errPathObjHolder{}) }")
 
 
-	common.Must(file.Close())
+	file.Close()
 }
 }

+ 17 - 10
common/errors/errors.go

@@ -3,7 +3,7 @@ package errors // import "v2ray.com/core/common/errors"
 
 
 import (
 import (
 	"os"
 	"os"
-	"strings"
+	"reflect"
 
 
 	"v2ray.com/core/common/log"
 	"v2ray.com/core/common/log"
 	"v2ray.com/core/common/serial"
 	"v2ray.com/core/common/serial"
@@ -20,21 +20,34 @@ type hasSeverity interface {
 
 
 // Error is an error object with underlying error.
 // Error is an error object with underlying error.
 type Error struct {
 type Error struct {
+	pathObj  interface{}
 	prefix   []interface{}
 	prefix   []interface{}
-	path     []string
 	message  []interface{}
 	message  []interface{}
 	inner    error
 	inner    error
 	severity log.Severity
 	severity log.Severity
 }
 }
 
 
+func (err *Error) WithPathObj(obj interface{}) *Error {
+	err.pathObj = obj
+	return err
+}
+
+func (err *Error) pkgPath() string {
+	if err.pathObj == nil {
+		return ""
+	}
+	return reflect.TypeOf(err.pathObj).PkgPath()
+}
+
 // Error implements error.Error().
 // Error implements error.Error().
 func (v *Error) Error() string {
 func (v *Error) Error() string {
 	msg := serial.Concat(v.message...)
 	msg := serial.Concat(v.message...)
 	if v.inner != nil {
 	if v.inner != nil {
 		msg += " > " + v.inner.Error()
 		msg += " > " + v.inner.Error()
 	}
 	}
-	if len(v.path) > 0 {
-		msg = strings.Join(v.path, "|") + ": " + msg
+	path := v.pkgPath()
+	if len(path) > 0 {
+		msg = path + ": " + msg
 	}
 	}
 
 
 	var prefix string
 	var prefix string
@@ -98,12 +111,6 @@ func (v *Error) AtError() *Error {
 	return v.atSeverity(log.Severity_Error)
 	return v.atSeverity(log.Severity_Error)
 }
 }
 
 
-// Path sets the path to the location where this error happens.
-func (v *Error) Path(path ...string) *Error {
-	v.path = path
-	return v
-}
-
 // String returns the string representation of this error.
 // String returns the string representation of this error.
 func (v *Error) String() string {
 func (v *Error) String() string {
 	return v.Error()
 	return v.Error()

+ 6 - 4
common/errors/errors_test.go

@@ -28,18 +28,20 @@ func TestError(t *testing.T) {
 	assert(err.Error(), HasSubstring, "EOF")
 	assert(err.Error(), HasSubstring, "EOF")
 }
 }
 
 
+type e struct{}
+
 func TestErrorMessage(t *testing.T) {
 func TestErrorMessage(t *testing.T) {
 	data := []struct {
 	data := []struct {
 		err error
 		err error
 		msg string
 		msg string
 	}{
 	}{
 		{
 		{
-			err: New("a").Base(New("b")).Path("c", "d", "e"),
-			msg: "c|d|e: a > b",
+			err: New("a").Base(New("b")).WithPathObj(e{}),
+			msg: "v2ray.com/core/common/errors_test: a > b",
 		},
 		},
 		{
 		{
-			err: New("a").Base(New("b").Path("c")).Path("d", "e"),
-			msg: "d|e: a > c: b",
+			err: New("a").Base(New("b").WithPathObj(e{})),
+			msg: "a > v2ray.com/core/common/errors_test: b",
 		},
 		},
 	}
 	}
 
 

+ 5 - 1
common/net/errors.generated.go

@@ -2,4 +2,8 @@ package net
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Net") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 3 - 1
common/platform/ctlcmd/errors.generated.go

@@ -2,6 +2,8 @@ package ctlcmd
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Command", "Platform", "CtlCmd")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 5 - 1
common/protocol/errors.generated.go

@@ -2,4 +2,8 @@ package protocol
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Protocol") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 3 - 1
common/protocol/tls/cert/errors.generated.go

@@ -2,6 +2,8 @@ package cert
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Protocol", "TLS", "Cert")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 5 - 1
common/retry/errors.generated.go

@@ -2,4 +2,8 @@ package retry
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Retry") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 5 - 1
errors.generated.go

@@ -2,4 +2,8 @@ package core
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Core") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 3 - 1
main/confloader/external/errors.generated.go

@@ -2,6 +2,8 @@ package external
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Main", "ConfLoader", "External")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 5 - 1
main/errors.generated.go

@@ -2,4 +2,8 @@ package main
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Main") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 5 - 1
main/json/errors.generated.go

@@ -2,4 +2,8 @@ package json
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Main", "Json") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 3 - 1
proxy/blackhole/errors.generated.go

@@ -2,6 +2,8 @@ package blackhole
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "Blackhole")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
proxy/dokodemo/errors.generated.go

@@ -2,6 +2,8 @@ package dokodemo
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "Dokodemo")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
proxy/freedom/errors.generated.go

@@ -2,6 +2,8 @@ package freedom
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "Freedom")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 5 - 1
proxy/http/errors.generated.go

@@ -2,4 +2,8 @@ package http
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
-func newError(values ...interface{}) *errors.Error { return errors.New(values...).Path("Proxy", "HTTP") }
+type errPathObjHolder struct{}
+
+func newError(values ...interface{}) *errors.Error {
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
+}

+ 3 - 1
proxy/mtproto/errors.generated.go

@@ -2,6 +2,8 @@ package mtproto
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "MTProto")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
proxy/shadowsocks/errors.generated.go

@@ -2,6 +2,8 @@ package shadowsocks
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "Shadowsocks")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
proxy/socks/errors.generated.go

@@ -2,6 +2,8 @@ package socks
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "Socks")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
proxy/vmess/encoding/errors.generated.go

@@ -2,6 +2,8 @@ package encoding
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "VMess", "Encoding")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
proxy/vmess/errors.generated.go

@@ -2,6 +2,8 @@ package vmess
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "VMess")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
proxy/vmess/inbound/errors.generated.go

@@ -2,6 +2,8 @@ package inbound
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "VMess", "Inbound")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
proxy/vmess/outbound/errors.generated.go

@@ -2,6 +2,8 @@ package outbound
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Proxy", "VMess", "Outbound")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/domainsocket/errors.generated.go

@@ -2,6 +2,8 @@ package domainsocket
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet", "DomainSocket")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/errors.generated.go

@@ -2,6 +2,8 @@ package internet
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/headers/http/errors.generated.go

@@ -2,6 +2,8 @@ package http
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet", "Headers", "HTTP")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/http/errors.generated.go

@@ -2,6 +2,8 @@ package http
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet", "HTTP")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/kcp/errors.generated.go

@@ -2,6 +2,8 @@ package kcp
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet", "mKCP")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/tcp/errors.generated.go

@@ -2,6 +2,8 @@ package tcp
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet", "TCP")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/tls/errors.generated.go

@@ -2,6 +2,8 @@ package tls
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet", "TLS")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/udp/errors.generated.go

@@ -2,6 +2,8 @@ package udp
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet", "UDP")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }

+ 3 - 1
transport/internet/websocket/errors.generated.go

@@ -2,6 +2,8 @@ package websocket
 
 
 import "v2ray.com/core/common/errors"
 import "v2ray.com/core/common/errors"
 
 
+type errPathObjHolder struct{}
+
 func newError(values ...interface{}) *errors.Error {
 func newError(values ...interface{}) *errors.Error {
-	return errors.New(values...).Path("Transport", "Internet", "WebSocket")
+	return errors.New(values...).WithPathObj(errPathObjHolder{})
 }
 }