erm/vendor/github.com/creack/pty
Liam Galvin e60a0b0427 Initial commit 2021-07-30 23:29:20 +01:00
..
.gitignore Initial commit 2021-07-30 23:29:20 +01:00
Dockerfile.golang Initial commit 2021-07-30 23:29:20 +01:00
Dockerfile.riscv Initial commit 2021-07-30 23:29:20 +01:00
LICENSE Initial commit 2021-07-30 23:29:20 +01:00
README.md Initial commit 2021-07-30 23:29:20 +01:00
doc.go Initial commit 2021-07-30 23:29:20 +01:00
go.mod Initial commit 2021-07-30 23:29:20 +01:00
ioctl.go Initial commit 2021-07-30 23:29:20 +01:00
ioctl_bsd.go Initial commit 2021-07-30 23:29:20 +01:00
ioctl_solaris.go Initial commit 2021-07-30 23:29:20 +01:00
mktypes.bash Initial commit 2021-07-30 23:29:20 +01:00
pty_darwin.go Initial commit 2021-07-30 23:29:20 +01:00
pty_dragonfly.go Initial commit 2021-07-30 23:29:20 +01:00
pty_freebsd.go Initial commit 2021-07-30 23:29:20 +01:00
pty_linux.go Initial commit 2021-07-30 23:29:20 +01:00
pty_netbsd.go Initial commit 2021-07-30 23:29:20 +01:00
pty_openbsd.go Initial commit 2021-07-30 23:29:20 +01:00
pty_solaris.go Initial commit 2021-07-30 23:29:20 +01:00
pty_unsupported.go Initial commit 2021-07-30 23:29:20 +01:00
run.go Initial commit 2021-07-30 23:29:20 +01:00
test_crosscompile.sh Initial commit 2021-07-30 23:29:20 +01:00
util.go Initial commit 2021-07-30 23:29:20 +01:00
util_solaris.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_386.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_amd64.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_arm.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_arm64.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_dragonfly_amd64.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_freebsd_386.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_freebsd_amd64.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_freebsd_arm.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_freebsd_arm64.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_loongarchx.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_mipsx.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_netbsd_32bit_int.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_openbsd_32bit_int.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_ppc64.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_ppc64le.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_riscvx.go Initial commit 2021-07-30 23:29:20 +01:00
ztypes_s390x.go Initial commit 2021-07-30 23:29:20 +01:00

README.md

pty

Pty is a Go package for using unix pseudo-terminals.

Install

go get github.com/creack/pty

Examples

Note that those examples are for demonstration purpose only, to showcase how to use the library. They are not meant to be used in any kind of production environment.

Command

package main

import (
	"io"
	"os"
	"os/exec"

	"github.com/creack/pty"
)

func main() {
	c := exec.Command("grep", "--color=auto", "bar")
	f, err := pty.Start(c)
	if err != nil {
		panic(err)
	}

	go func() {
		f.Write([]byte("foo\n"))
		f.Write([]byte("bar\n"))
		f.Write([]byte("baz\n"))
		f.Write([]byte{4}) // EOT
	}()
	io.Copy(os.Stdout, f)
}

Shell

package main

import (
        "io"
        "log"
        "os"
        "os/exec"
        "os/signal"
        "syscall"

        "github.com/creack/pty"
        "golang.org/x/term"
)

func test() error {
        // Create arbitrary command.
        c := exec.Command("bash")

        // Start the command with a pty.
        ptmx, err := pty.Start(c)
        if err != nil {
                return err
        }
        // Make sure to close the pty at the end.
        defer func() { _ = ptmx.Close() }() // Best effort.

        // Handle pty size.
        ch := make(chan os.Signal, 1)
        signal.Notify(ch, syscall.SIGWINCH)
        go func() {
                for range ch {
                        if err := pty.InheritSize(os.Stdin, ptmx); err != nil {
                                log.Printf("error resizing pty: %s", err)
                        }
                }
        }()
        ch <- syscall.SIGWINCH // Initial resize.
        defer func() { signal.Stop(ch); close(ch) }() // Cleanup signals when done.

        // Set stdin in raw mode.
        oldState, err := term.MakeRaw(int(os.Stdin.Fd()))
        if err != nil {
                panic(err)
        }
        defer func() { _ = term.Restore(int(os.Stdin.Fd()), oldState) }() // Best effort.

        // Copy stdin to the pty and the pty to stdout.
        // NOTE: The goroutine will keep reading until the next keystroke before returning.
        go func() { _, _ = io.Copy(ptmx, os.Stdin) }()
        _, _ = io.Copy(os.Stdout, ptmx)

        return nil
}

func main() {
        if err := test(); err != nil {
                log.Fatal(err)
        }
}