From: Rob Pike Date: Fri, 19 Jun 2009 23:03:59 +0000 (-0700) Subject: make IP address available X-Git-Tag: weekly.2009-11-06~1366 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=efc4088ccd5434f1536f46e7fdab48e2fc3565ed;p=gostls13.git make IP address available R=rsc DELTA=30 (30 added, 0 deleted, 0 changed) OCL=30536 CL=30536 --- diff --git a/src/pkg/net/fd.go b/src/pkg/net/fd.go index befcd554fe..17598af466 100644 --- a/src/pkg/net/fd.go +++ b/src/pkg/net/fd.go @@ -436,3 +436,13 @@ func (fd *netFD) addr() string { addr, err1 := sockaddrToString(sa); return addr; } + +func (fd *netFD) remoteAddr() string { + sa, err := syscall.Getpeername(fd.fd); + if err != 0 { + return ""; + } + // TODO(rsc): woud like to say err not err1 but 6g complains + addr, err1 := sockaddrToString(sa); + return addr; +} diff --git a/src/pkg/net/net.go b/src/pkg/net/net.go index 8d7e7ba328..91d498a3da 100644 --- a/src/pkg/net/net.go +++ b/src/pkg/net/net.go @@ -33,6 +33,12 @@ type Conn interface { // Close closes the connection. Close() os.Error; + // LocalAddr returns the local network address. + LocalAddr() string; + + // RemoteAddr returns the remote network address. + RemoteAddr() string; + // For packet-based protocols such as UDP, // ReadFrom reads the next packet from the network, // returning the number of bytes read and the remote @@ -318,6 +324,20 @@ type connBase struct { raddr string; } +func (c *connBase) LocalAddr() string { + if c == nil { + return "" + } + return c.fd.addr(); +} + +func (c *connBase) RemoteAddr() string { + if c == nil { + return "" + } + return c.fd.remoteAddr(); +} + func (c *connBase) File() *os.File { if c == nil { return nil