X7ROOT File Manager
Current Path:
/opt/golang/1.22.0/src/net
opt
/
golang
/
1.22.0
/
src
/
net
/
📁
..
📄
addrselect.go
(9.69 KB)
📄
addrselect_test.go
(8.5 KB)
📄
cgo_aix.go
(582 B)
📄
cgo_android.go
(272 B)
📄
cgo_bsd.go
(343 B)
📄
cgo_darwin.go
(298 B)
📄
cgo_linux.go
(642 B)
📄
cgo_netbsd.go
(276 B)
📄
cgo_openbsd.go
(276 B)
📄
cgo_resnew.go
(580 B)
📄
cgo_resold.go
(579 B)
📄
cgo_socknew.go
(753 B)
📄
cgo_sockold.go
(842 B)
📄
cgo_solaris.go
(343 B)
📄
cgo_stub.go
(1.33 KB)
📄
cgo_unix.go
(11.35 KB)
📄
cgo_unix_cgo.go
(2.24 KB)
📄
cgo_unix_cgo_darwin.go
(461 B)
📄
cgo_unix_cgo_res.go
(911 B)
📄
cgo_unix_cgo_resn.go
(998 B)
📄
cgo_unix_syscall.go
(2.99 KB)
📄
cgo_unix_test.go
(1.44 KB)
📄
conf.go
(15.63 KB)
📄
conf_test.go
(12.28 KB)
📄
conn_test.go
(1.82 KB)
📄
dial.go
(25.68 KB)
📄
dial_test.go
(30.14 KB)
📄
dial_unix_test.go
(2.77 KB)
📄
dnsclient.go
(5.65 KB)
📄
dnsclient_test.go
(1.51 KB)
📄
dnsclient_unix.go
(24.26 KB)
📄
dnsclient_unix_test.go
(69.13 KB)
📄
dnsconfig.go
(1.73 KB)
📄
dnsconfig_unix.go
(4.16 KB)
📄
dnsconfig_unix_test.go
(7.07 KB)
📄
dnsconfig_windows.go
(1.6 KB)
📄
dnsname_test.go
(1.96 KB)
📄
error_plan9.go
(224 B)
📄
error_plan9_test.go
(437 B)
📄
error_posix.go
(543 B)
📄
error_posix_test.go
(981 B)
📄
error_test.go
(20.32 KB)
📄
error_unix.go
(382 B)
📄
error_unix_test.go
(723 B)
📄
error_windows.go
(355 B)
📄
error_windows_test.go
(757 B)
📄
example_test.go
(8.45 KB)
📄
external_test.go
(4.05 KB)
📄
fd_fake.go
(3.79 KB)
📄
fd_js.go
(627 B)
📄
fd_plan9.go
(3.56 KB)
📄
fd_posix.go
(4.29 KB)
📄
fd_unix.go
(5.43 KB)
📄
fd_wasip1.go
(496 B)
📄
fd_windows.go
(6.14 KB)
📄
file.go
(1.69 KB)
📄
file_plan9.go
(2.72 KB)
📄
file_stub.go
(481 B)
📄
file_test.go
(6.43 KB)
📄
file_unix.go
(2.5 KB)
📄
file_unix_test.go
(2.07 KB)
📄
file_wasip1.go
(2.2 KB)
📄
file_wasip1_test.go
(3.76 KB)
📄
file_windows.go
(521 B)
📄
hook.go
(894 B)
📄
hook_plan9.go
(211 B)
📄
hook_unix.go
(658 B)
📄
hook_windows.go
(720 B)
📄
hosts.go
(3.48 KB)
📄
hosts_test.go
(5.6 KB)
📁
http
📄
interface.go
(7.26 KB)
📄
interface_aix.go
(4.46 KB)
📄
interface_bsd.go
(2.82 KB)
📄
interface_bsd_test.go
(1.44 KB)
📄
interface_bsdvar.go
(718 B)
📄
interface_darwin.go
(1.29 KB)
📄
interface_freebsd.go
(1.29 KB)
📄
interface_linux.go
(6.96 KB)
📄
interface_linux_test.go
(3.65 KB)
📄
interface_plan9.go
(4.71 KB)
📄
interface_solaris.go
(2.13 KB)
📄
interface_stub.go
(814 B)
📄
interface_test.go
(9.76 KB)
📄
interface_unix_test.go
(4.85 KB)
📄
interface_windows.go
(5.43 KB)
📁
internal
📄
ip.go
(13.88 KB)
📄
ip_test.go
(25.6 KB)
📄
iprawsock.go
(7.11 KB)
📄
iprawsock_plan9.go
(874 B)
📄
iprawsock_posix.go
(3.89 KB)
📄
iprawsock_test.go
(5.98 KB)
📄
ipsock.go
(9.05 KB)
📄
ipsock_plan9.go
(7.48 KB)
📄
ipsock_plan9_test.go
(645 B)
📄
ipsock_posix.go
(7.86 KB)
📄
ipsock_test.go
(6.81 KB)
📄
listen_test.go
(20.5 KB)
📄
lookup.go
(29.04 KB)
📄
lookup_plan9.go
(9.94 KB)
📄
lookup_test.go
(40.62 KB)
📄
lookup_unix.go
(3.35 KB)
📄
lookup_windows.go
(13.8 KB)
📄
lookup_windows_test.go
(8.93 KB)
📄
mac.go
(1.88 KB)
📄
mac_test.go
(3.26 KB)
📁
mail
📄
main_cloexec_test.go
(693 B)
📄
main_conf_test.go
(1.39 KB)
📄
main_noconf_test.go
(467 B)
📄
main_plan9_test.go
(392 B)
📄
main_posix_test.go
(1.37 KB)
📄
main_test.go
(7.53 KB)
📄
main_unix_test.go
(1.19 KB)
📄
main_wasm_test.go
(284 B)
📄
main_windows_test.go
(1 KB)
📄
mockserver_test.go
(10.77 KB)
📄
mptcpsock_linux.go
(3.96 KB)
📄
mptcpsock_linux_test.go
(4.06 KB)
📄
mptcpsock_stub.go
(542 B)
📄
net.go
(24.56 KB)
📄
net_fake.go
(26.36 KB)
📄
net_fake_test.go
(2.79 KB)
📄
net_test.go
(14 KB)
📄
net_windows_test.go
(16.28 KB)
📄
netcgo_off.go
(222 B)
📄
netcgo_on.go
(220 B)
📄
netgo_netcgo.go
(453 B)
📄
netgo_off.go
(220 B)
📄
netgo_on.go
(218 B)
📁
netip
📄
nss.go
(5.48 KB)
📄
nss_test.go
(3.4 KB)
📄
packetconn_test.go
(3.02 KB)
📄
parse.go
(6.04 KB)
📄
parse_test.go
(1.55 KB)
📄
pipe.go
(5.43 KB)
📄
pipe_test.go
(1.2 KB)
📄
platform_test.go
(4.33 KB)
📄
port.go
(1.46 KB)
📄
port_test.go
(1.34 KB)
📄
port_unix.go
(1.24 KB)
📄
protoconn_test.go
(7.44 KB)
📄
rawconn.go
(2.7 KB)
📄
rawconn_stub_test.go
(631 B)
📄
rawconn_test.go
(4.33 KB)
📄
rawconn_unix_test.go
(2.96 KB)
📄
rawconn_windows_test.go
(3.12 KB)
📄
resolverdialfunc_test.go
(8.25 KB)
📄
rlimit_js.go
(346 B)
📄
rlimit_unix.go
(1.1 KB)
📁
rpc
📄
sendfile_linux.go
(1.12 KB)
📄
sendfile_linux_test.go
(1.93 KB)
📄
sendfile_stub.go
(344 B)
📄
sendfile_test.go
(8.25 KB)
📄
sendfile_unix_alt.go
(2.04 KB)
📄
sendfile_windows.go
(1.02 KB)
📄
server_test.go
(11.67 KB)
📁
smtp
📄
sock_bsd.go
(918 B)
📄
sock_cloexec.go
(1.38 KB)
📄
sock_linux.go
(993 B)
📄
sock_linux_test.go
(575 B)
📄
sock_plan9.go
(262 B)
📄
sock_posix.go
(6.29 KB)
📄
sock_stub.go
(390 B)
📄
sock_windows.go
(802 B)
📄
sockaddr_posix.go
(1.45 KB)
📄
sockopt_aix.go
(1.43 KB)
📄
sockopt_bsd.go
(2.21 KB)
📄
sockopt_fake.go
(955 B)
📄
sockopt_linux.go
(1.25 KB)
📄
sockopt_plan9.go
(406 B)
📄
sockopt_posix.go
(2.13 KB)
📄
sockopt_solaris.go
(1.25 KB)
📄
sockopt_windows.go
(1.51 KB)
📄
sockoptip_bsdvar.go
(867 B)
📄
sockoptip_linux.go
(735 B)
📄
sockoptip_posix.go
(1.38 KB)
📄
sockoptip_stub.go
(769 B)
📄
sockoptip_windows.go
(786 B)
📄
splice_linux.go
(1.69 KB)
📄
splice_stub.go
(376 B)
📄
splice_test.go
(13.48 KB)
📄
sys_cloexec.go
(962 B)
📄
tcpsock.go
(11.75 KB)
📄
tcpsock_plan9.go
(2.18 KB)
📄
tcpsock_posix.go
(6.16 KB)
📄
tcpsock_test.go
(17.68 KB)
📄
tcpsock_unix_test.go
(2.34 KB)
📄
tcpsockopt_darwin.go
(770 B)
📄
tcpsockopt_dragonfly.go
(698 B)
📄
tcpsockopt_openbsd.go
(365 B)
📄
tcpsockopt_plan9.go
(525 B)
📄
tcpsockopt_posix.go
(442 B)
📄
tcpsockopt_solaris.go
(1.15 KB)
📄
tcpsockopt_stub.go
(399 B)
📄
tcpsockopt_unix.go
(722 B)
📄
tcpsockopt_windows.go
(741 B)
📁
testdata
📁
textproto
📄
timeout_test.go
(29.11 KB)
📄
udpsock.go
(11.83 KB)
📄
udpsock_plan9.go
(4.64 KB)
📄
udpsock_plan9_test.go
(1.31 KB)
📄
udpsock_posix.go
(7.53 KB)
📄
udpsock_test.go
(17.24 KB)
📄
unixsock.go
(10.12 KB)
📄
unixsock_linux_test.go
(2.29 KB)
📄
unixsock_plan9.go
(1.24 KB)
📄
unixsock_posix.go
(6.64 KB)
📄
unixsock_readmsg_cloexec.go
(654 B)
📄
unixsock_readmsg_cmsg_cloexec.go
(332 B)
📄
unixsock_readmsg_other.go
(275 B)
📄
unixsock_readmsg_test.go
(2.51 KB)
📄
unixsock_test.go
(10.64 KB)
📄
unixsock_windows_test.go
(2.03 KB)
📁
url
📄
write_unix_test.go
(1.61 KB)
📄
writev_test.go
(5.03 KB)
📄
writev_unix.go
(666 B)
Editing: conf.go
// Copyright 2015 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package net import ( "errors" "internal/bytealg" "internal/godebug" "io/fs" "os" "runtime" "sync" "syscall" ) // The net package's name resolution is rather complicated. // There are two main approaches, go and cgo. // The cgo resolver uses C functions like getaddrinfo. // The go resolver reads system files directly and // sends DNS packets directly to servers. // // The netgo build tag prefers the go resolver. // The netcgo build tag prefers the cgo resolver. // // The netgo build tag also prohibits the use of the cgo tool. // However, on Darwin, Plan 9, and Windows the cgo resolver is still available. // On those systems the cgo resolver does not require the cgo tool. // (The term "cgo resolver" was locked in by GODEBUG settings // at a time when the cgo resolver did require the cgo tool.) // // Adding netdns=go to GODEBUG will prefer the go resolver. // Adding netdns=cgo to GODEBUG will prefer the cgo resolver. // // The Resolver struct has a PreferGo field that user code // may set to prefer the go resolver. It is documented as being // equivalent to adding netdns=go to GODEBUG. // // When deciding which resolver to use, we first check the PreferGo field. // If that is not set, we check the GODEBUG setting. // If that is not set, we check the netgo or netcgo build tag. // If none of those are set, we normally prefer the go resolver by default. // However, if the cgo resolver is available, // there is a complex set of conditions for which we prefer the cgo resolver. // // Other files define the netGoBuildTag, netCgoBuildTag, and cgoAvailable // constants. // conf is used to determine name resolution configuration. type conf struct { netGo bool // prefer go approach, based on build tag and GODEBUG netCgo bool // prefer cgo approach, based on build tag and GODEBUG dnsDebugLevel int // from GODEBUG preferCgo bool // if no explicit preference, use cgo goos string // copy of runtime.GOOS, used for testing mdnsTest mdnsTest // assume /etc/mdns.allow exists, for testing } // mdnsTest is for testing only. type mdnsTest int const ( mdnsFromSystem mdnsTest = iota mdnsAssumeExists mdnsAssumeDoesNotExist ) var ( confOnce sync.Once // guards init of confVal via initConfVal confVal = &conf{goos: runtime.GOOS} ) // systemConf returns the machine's network configuration. func systemConf() *conf { confOnce.Do(initConfVal) return confVal } // initConfVal initializes confVal based on the environment // that will not change during program execution. func initConfVal() { dnsMode, debugLevel := goDebugNetDNS() confVal.netGo = netGoBuildTag || dnsMode == "go" confVal.netCgo = netCgoBuildTag || dnsMode == "cgo" confVal.dnsDebugLevel = debugLevel if confVal.dnsDebugLevel > 0 { defer func() { if confVal.dnsDebugLevel > 1 { println("go package net: confVal.netCgo =", confVal.netCgo, " netGo =", confVal.netGo) } switch { case confVal.netGo: if netGoBuildTag { println("go package net: built with netgo build tag; using Go's DNS resolver") } else { println("go package net: GODEBUG setting forcing use of Go's resolver") } case !cgoAvailable: println("go package net: cgo resolver not supported; using Go's DNS resolver") case confVal.netCgo || confVal.preferCgo: println("go package net: using cgo DNS resolver") default: println("go package net: dynamic selection of DNS resolver") } }() } // The remainder of this function sets preferCgo based on // conditions that will not change during program execution. // By default, prefer the go resolver. confVal.preferCgo = false // If the cgo resolver is not available, we can't prefer it. if !cgoAvailable { return } // Some operating systems always prefer the cgo resolver. if goosPrefersCgo() { confVal.preferCgo = true return } // The remaining checks are specific to Unix systems. switch runtime.GOOS { case "plan9", "windows", "js", "wasip1": return } // If any environment-specified resolver options are specified, // prefer the cgo resolver. // Note that LOCALDOMAIN can change behavior merely by being // specified with the empty string. _, localDomainDefined := syscall.Getenv("LOCALDOMAIN") if localDomainDefined || os.Getenv("RES_OPTIONS") != "" || os.Getenv("HOSTALIASES") != "" { confVal.preferCgo = true return } // OpenBSD apparently lets you override the location of resolv.conf // with ASR_CONFIG. If we notice that, defer to libc. if runtime.GOOS == "openbsd" && os.Getenv("ASR_CONFIG") != "" { confVal.preferCgo = true return } } // goosPrefersCgo reports whether the GOOS value passed in prefers // the cgo resolver. func goosPrefersCgo() bool { switch runtime.GOOS { // Historically on Windows and Plan 9 we prefer the // cgo resolver (which doesn't use the cgo tool) rather than // the go resolver. This is because originally these // systems did not support the go resolver. // Keep it this way for better compatibility. // Perhaps we can revisit this some day. case "windows", "plan9": return true // Darwin pops up annoying dialog boxes if programs try to // do their own DNS requests, so prefer cgo. case "darwin", "ios": return true // DNS requests don't work on Android, so prefer the cgo resolver. // Issue #10714. case "android": return true default: return false } } // mustUseGoResolver reports whether a DNS lookup of any sort is // required to use the go resolver. The provided Resolver is optional. // This will report true if the cgo resolver is not available. func (c *conf) mustUseGoResolver(r *Resolver) bool { if !cgoAvailable { return true } if runtime.GOOS == "plan9" { // TODO(bradfitz): for now we only permit use of the PreferGo // implementation when there's a non-nil Resolver with a // non-nil Dialer. This is a sign that they the code is trying // to use their DNS-speaking net.Conn (such as an in-memory // DNS cache) and they don't want to actually hit the network. // Once we add support for looking the default DNS servers // from plan9, though, then we can relax this. if r == nil || r.Dial == nil { return false } } return c.netGo || r.preferGo() } // addrLookupOrder determines which strategy to use to resolve addresses. // The provided Resolver is optional. nil means to not consider its options. // It also returns dnsConfig when it was used to determine the lookup order. func (c *conf) addrLookupOrder(r *Resolver, addr string) (ret hostLookupOrder, dnsConf *dnsConfig) { if c.dnsDebugLevel > 1 { defer func() { print("go package net: addrLookupOrder(", addr, ") = ", ret.String(), "\n") }() } return c.lookupOrder(r, "") } // hostLookupOrder determines which strategy to use to resolve hostname. // The provided Resolver is optional. nil means to not consider its options. // It also returns dnsConfig when it was used to determine the lookup order. func (c *conf) hostLookupOrder(r *Resolver, hostname string) (ret hostLookupOrder, dnsConf *dnsConfig) { if c.dnsDebugLevel > 1 { defer func() { print("go package net: hostLookupOrder(", hostname, ") = ", ret.String(), "\n") }() } return c.lookupOrder(r, hostname) } func (c *conf) lookupOrder(r *Resolver, hostname string) (ret hostLookupOrder, dnsConf *dnsConfig) { // fallbackOrder is the order we return if we can't figure it out. var fallbackOrder hostLookupOrder var canUseCgo bool if c.mustUseGoResolver(r) { // Go resolver was explicitly requested // or cgo resolver is not available. // Figure out the order below. fallbackOrder = hostLookupFilesDNS canUseCgo = false } else if c.netCgo { // Cgo resolver was explicitly requested. return hostLookupCgo, nil } else if c.preferCgo { // Given a choice, we prefer the cgo resolver. return hostLookupCgo, nil } else { // Neither resolver was explicitly requested // and we have no preference. if bytealg.IndexByteString(hostname, '\\') != -1 || bytealg.IndexByteString(hostname, '%') != -1 { // Don't deal with special form hostnames // with backslashes or '%'. return hostLookupCgo, nil } // If something is unrecognized, use cgo. fallbackOrder = hostLookupCgo canUseCgo = true } // On systems that don't use /etc/resolv.conf or /etc/nsswitch.conf, we are done. switch c.goos { case "windows", "plan9", "android", "ios": return fallbackOrder, nil } // Try to figure out the order to use for searches. // If we don't recognize something, use fallbackOrder. // That will use cgo unless the Go resolver was explicitly requested. // If we do figure out the order, return something other // than fallbackOrder to use the Go resolver with that order. dnsConf = getSystemDNSConfig() if canUseCgo && dnsConf.err != nil && !errors.Is(dnsConf.err, fs.ErrNotExist) && !errors.Is(dnsConf.err, fs.ErrPermission) { // We can't read the resolv.conf file, so use cgo if we can. return hostLookupCgo, dnsConf } if canUseCgo && dnsConf.unknownOpt { // We didn't recognize something in resolv.conf, // so use cgo if we can. return hostLookupCgo, dnsConf } // OpenBSD is unique and doesn't use nsswitch.conf. // It also doesn't support mDNS. if c.goos == "openbsd" { // OpenBSD's resolv.conf manpage says that a // non-existent resolv.conf means "lookup" defaults // to only "files", without DNS lookups. if errors.Is(dnsConf.err, fs.ErrNotExist) { return hostLookupFiles, dnsConf } lookup := dnsConf.lookup if len(lookup) == 0 { // https://www.openbsd.org/cgi-bin/man.cgi/OpenBSD-current/man5/resolv.conf.5 // "If the lookup keyword is not used in the // system's resolv.conf file then the assumed // order is 'bind file'" return hostLookupDNSFiles, dnsConf } if len(lookup) < 1 || len(lookup) > 2 { // We don't recognize this format. return fallbackOrder, dnsConf } switch lookup[0] { case "bind": if len(lookup) == 2 { if lookup[1] == "file" { return hostLookupDNSFiles, dnsConf } // Unrecognized. return fallbackOrder, dnsConf } return hostLookupDNS, dnsConf case "file": if len(lookup) == 2 { if lookup[1] == "bind" { return hostLookupFilesDNS, dnsConf } // Unrecognized. return fallbackOrder, dnsConf } return hostLookupFiles, dnsConf default: // Unrecognized. return fallbackOrder, dnsConf } // We always return before this point. // The code below is for non-OpenBSD. } // Canonicalize the hostname by removing any trailing dot. if stringsHasSuffix(hostname, ".") { hostname = hostname[:len(hostname)-1] } if canUseCgo && stringsHasSuffixFold(hostname, ".local") { // Per RFC 6762, the ".local" TLD is special. And // because Go's native resolver doesn't do mDNS or // similar local resolution mechanisms, assume that // libc might (via Avahi, etc) and use cgo. return hostLookupCgo, dnsConf } nss := getSystemNSS() srcs := nss.sources["hosts"] // If /etc/nsswitch.conf doesn't exist or doesn't specify any // sources for "hosts", assume Go's DNS will work fine. if errors.Is(nss.err, fs.ErrNotExist) || (nss.err == nil && len(srcs) == 0) { if canUseCgo && c.goos == "solaris" { // illumos defaults to // "nis [NOTFOUND=return] files", // which the go resolver doesn't support. return hostLookupCgo, dnsConf } return hostLookupFilesDNS, dnsConf } if nss.err != nil { // We failed to parse or open nsswitch.conf, so // we have nothing to base an order on. return fallbackOrder, dnsConf } var hasDNSSource bool var hasDNSSourceChecked bool var filesSource, dnsSource bool var first string for i, src := range srcs { if src.source == "files" || src.source == "dns" { if canUseCgo && !src.standardCriteria() { // non-standard; let libc deal with it. return hostLookupCgo, dnsConf } if src.source == "files" { filesSource = true } else { hasDNSSource = true hasDNSSourceChecked = true dnsSource = true } if first == "" { first = src.source } continue } if canUseCgo { switch { case hostname != "" && src.source == "myhostname": // Let the cgo resolver handle myhostname // if we are looking up the local hostname. if isLocalhost(hostname) || isGateway(hostname) || isOutbound(hostname) { return hostLookupCgo, dnsConf } hn, err := getHostname() if err != nil || stringsEqualFold(hostname, hn) { return hostLookupCgo, dnsConf } continue case hostname != "" && stringsHasPrefix(src.source, "mdns"): // e.g. "mdns4", "mdns4_minimal" // We already returned true before if it was *.local. // libc wouldn't have found a hit on this anyway. // We don't parse mdns.allow files. They're rare. If one // exists, it might list other TLDs (besides .local) or even // '*', so just let libc deal with it. var haveMDNSAllow bool switch c.mdnsTest { case mdnsFromSystem: _, err := os.Stat("/etc/mdns.allow") if err != nil && !errors.Is(err, fs.ErrNotExist) { // Let libc figure out what is going on. return hostLookupCgo, dnsConf } haveMDNSAllow = err == nil case mdnsAssumeExists: haveMDNSAllow = true case mdnsAssumeDoesNotExist: haveMDNSAllow = false } if haveMDNSAllow { return hostLookupCgo, dnsConf } continue default: // Some source we don't know how to deal with. return hostLookupCgo, dnsConf } } if !hasDNSSourceChecked { hasDNSSourceChecked = true for _, v := range srcs[i+1:] { if v.source == "dns" { hasDNSSource = true break } } } // If we saw a source we don't recognize, which can only // happen if we can't use the cgo resolver, treat it as DNS, // but only when there is no dns in all other sources. if !hasDNSSource { dnsSource = true if first == "" { first = "dns" } } } // Cases where Go can handle it without cgo and C thread overhead, // or where the Go resolver has been forced. switch { case filesSource && dnsSource: if first == "files" { return hostLookupFilesDNS, dnsConf } else { return hostLookupDNSFiles, dnsConf } case filesSource: return hostLookupFiles, dnsConf case dnsSource: return hostLookupDNS, dnsConf } // Something weird. Fallback to the default. return fallbackOrder, dnsConf } var netdns = godebug.New("netdns") // goDebugNetDNS parses the value of the GODEBUG "netdns" value. // The netdns value can be of the form: // // 1 // debug level 1 // 2 // debug level 2 // cgo // use cgo for DNS lookups // go // use go for DNS lookups // cgo+1 // use cgo for DNS lookups + debug level 1 // 1+cgo // same // cgo+2 // same, but debug level 2 // // etc. func goDebugNetDNS() (dnsMode string, debugLevel int) { goDebug := netdns.Value() parsePart := func(s string) { if s == "" { return } if '0' <= s[0] && s[0] <= '9' { debugLevel, _, _ = dtoi(s) } else { dnsMode = s } } if i := bytealg.IndexByteString(goDebug, '+'); i != -1 { parsePart(goDebug[:i]) parsePart(goDebug[i+1:]) return } parsePart(goDebug) return } // isLocalhost reports whether h should be considered a "localhost" // name for the myhostname NSS module. func isLocalhost(h string) bool { return stringsEqualFold(h, "localhost") || stringsEqualFold(h, "localhost.localdomain") || stringsHasSuffixFold(h, ".localhost") || stringsHasSuffixFold(h, ".localhost.localdomain") } // isGateway reports whether h should be considered a "gateway" // name for the myhostname NSS module. func isGateway(h string) bool { return stringsEqualFold(h, "_gateway") } // isOutbound reports whether h should be considered an "outbound" // name for the myhostname NSS module. func isOutbound(h string) bool { return stringsEqualFold(h, "_outbound") }
Upload File
Create Folder