|  | // Copyright 2017 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 testpty is a simple pseudo-terminal package for Unix systems, | 
|  | // implemented by calling C functions via cgo. | 
|  | package testpty | 
|  |  | 
|  | import ( | 
|  | "errors" | 
|  | "fmt" | 
|  | "os" | 
|  | ) | 
|  |  | 
|  | type PtyError struct { | 
|  | FuncName    string | 
|  | ErrorString string | 
|  | Errno       error | 
|  | } | 
|  |  | 
|  | func ptyError(name string, err error) *PtyError { | 
|  | return &PtyError{name, err.Error(), err} | 
|  | } | 
|  |  | 
|  | func (e *PtyError) Error() string { | 
|  | return fmt.Sprintf("%s: %s", e.FuncName, e.ErrorString) | 
|  | } | 
|  |  | 
|  | func (e *PtyError) Unwrap() error { return e.Errno } | 
|  |  | 
|  | var ErrNotSupported = errors.New("testpty.Open not implemented on this platform") | 
|  |  | 
|  | // Open returns a control pty and the name of the linked process tty. | 
|  | // | 
|  | // If Open is not implemented on this platform, it returns ErrNotSupported. | 
|  | func Open() (pty *os.File, processTTY string, err error) { | 
|  | return open() | 
|  | } |