mirror of
https://github.com/golang/go
synced 2024-10-04 15:11:20 -06:00
2a0fc9e70e
This reverts commit 6f7961da28
.
Russ suggests changing the frozon syscall package and obviously it's a
better solution. Perhaps he will also let me know the way how to get the
project owners to agree later.
Fixes #11492.
Change-Id: I98f9f366b72b85db54b4acfc3a604b62fb6d783c
Reviewed-on: https://go-review.googlesource.com/11854
Run-TryBot: Mikio Hara <mikioh.mikioh@gmail.com>
Reviewed-by: Rob Pike <r@golang.org>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
49 lines
1.6 KiB
Go
49 lines
1.6 KiB
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 "os"
|
|
|
|
type fileAddr string
|
|
|
|
func (fileAddr) Network() string { return "file+net" }
|
|
func (f fileAddr) String() string { return string(f) }
|
|
|
|
// FileConn returns a copy of the network connection corresponding to
|
|
// the open file f.
|
|
// It is the caller's responsibility to close f when finished.
|
|
// Closing c does not affect f, and closing f does not affect c.
|
|
func FileConn(f *os.File) (c Conn, err error) {
|
|
c, err = fileConn(f)
|
|
if err != nil {
|
|
err = &OpError{Op: "file", Net: "file+net", Source: nil, Addr: fileAddr(f.Name()), Err: err}
|
|
}
|
|
return
|
|
}
|
|
|
|
// FileListener returns a copy of the network listener corresponding
|
|
// to the open file f.
|
|
// It is the caller's responsibility to close ln when finished.
|
|
// Closing ln does not affect f, and closing f does not affect ln.
|
|
func FileListener(f *os.File) (ln Listener, err error) {
|
|
ln, err = fileListener(f)
|
|
if err != nil {
|
|
err = &OpError{Op: "file", Net: "file+net", Source: nil, Addr: fileAddr(f.Name()), Err: err}
|
|
}
|
|
return
|
|
}
|
|
|
|
// FilePacketConn returns a copy of the packet network connection
|
|
// corresponding to the open file f.
|
|
// It is the caller's responsibility to close f when finished.
|
|
// Closing c does not affect f, and closing f does not affect c.
|
|
func FilePacketConn(f *os.File) (c PacketConn, err error) {
|
|
c, err = filePacketConn(f)
|
|
if err != nil {
|
|
err = &OpError{Op: "file", Net: "file+net", Source: nil, Addr: fileAddr(f.Name()), Err: err}
|
|
}
|
|
return
|
|
}
|