diff --git a/src/pkg/net/fd.go b/src/pkg/net/fd.go index befcd554fe7..17598af4663 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 8d7e7ba3285..91d498a3da6 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