elvish/pkg/eval/vals/pipe.go

56 lines
1.2 KiB
Go
Raw Normal View History

2018-02-15 17:14:05 +08:00
package vals
import (
"fmt"
"os"
2021-05-04 05:17:46 +08:00
"src.elv.sh/pkg/persistent/hash"
)
// Pipe wraps a pair of pointers to os.File that are the two ends of the same
// pipe.
type Pipe struct {
ReadEnd, WriteEnd *os.File
}
var _ PseudoStructMap = Pipe{}
// NewPipe creates a new Pipe value.
func NewPipe(r, w *os.File) Pipe {
return Pipe{r, w}
}
2019-04-20 01:05:19 +08:00
// Kind returns "pipe".
func (Pipe) Kind() string {
return "pipe"
}
2019-04-20 01:05:19 +08:00
// Equal compares based on the equality of the two consistuent files.
func (p Pipe) Equal(rhs interface{}) bool {
2019-04-20 01:05:19 +08:00
q, ok := rhs.(Pipe)
if !ok {
return false
}
return Equal(p.ReadEnd, q.ReadEnd) && Equal(p.WriteEnd, q.WriteEnd)
}
2021-08-22 00:47:28 +08:00
// Hash calculates the hash based on the two constituent files.
func (p Pipe) Hash() uint32 {
2019-04-20 01:05:19 +08:00
return hash.DJB(Hash(p.ReadEnd), Hash(p.WriteEnd))
}
2019-04-20 01:05:19 +08:00
// Repr writes an opaque representation containing the FDs of the two
// constituent files.
func (p Pipe) Repr(int) string {
return fmt.Sprintf("<pipe{%v %v}>", p.ReadEnd.Fd(), p.WriteEnd.Fd())
}
// Fields returns fields of the Pipe value.
func (p Pipe) Fields() StructMap {
return pipeFields{p.ReadEnd, p.WriteEnd}
}
type pipeFields struct{ R, W *os.File }
func (pipeFields) IsStructMap() {}