首頁 >後端開發 >Golang >如何讓我的程式在 Linux 和 macOS 中偽裝成 TTY?

如何讓我的程式在 Linux 和 macOS 中偽裝成 TTY?

Linda Hamilton
Linda Hamilton原創
2024-12-14 06:11:11721瀏覽

How Can I Make My Program Pretend to Be a TTY in Linux and macOS?

假裝成為TTY:深入研究

程式設計中遇到的常見挑戰之一是處理歧視輸入來源的程式(如stdin)基於它們是終端機(TTY) 還是管道。為了解決這個問題,您可能需要讓您的程式假裝成 TTY。在本文中,我們將探討如何使用獨立的二進位程式在 Linux 和 macOS 中實現這一目標,主要專注於 Go。

假裝成 TTY 的關鍵思想是創建一個偽終端(也稱為偽終端)。稱為 pty)。 pty 是一個虛擬終端,其行為類似於常規終端,但它實際上是作為一對文件描述符實現的。這些檔案描述符之一用於從 pty 讀取輸入,而另一個用於將輸出寫入其中。

以下 Go 程式碼提供如何建立 pty並在其中運行命令的範例,捕獲其輸出:

package main

import (
    "io"
    "log"
    "os"
    "os/exec"
    "runtime"
)

func main() {
    // Get the current operating system.
    osName := runtime.GOOS

    // Create a master pty.
    master, err := os.OpenFile("/dev/ptmx", os.O_RDWR, 0)
    if err != nil {
        log.Fatal(err)
    }

    // Get the slave pty name.
    slaveName, err := ptsname(master)
    if err != nil {
        log.Fatal(err)
    }

    // Fork a child process.
    child, err := os.ForkExec("/bin/sh", []string{"sh", "-c", "ls -la"}, nil, slaveName, master, master)
    if err != nil {
        log.Fatal(err)
    }

    // Close the master pty.
    master.Close()

    // Read output from the slave pty.
    buf := make([]byte, 1024)
    for {
        n, err := os.Read(child, buf)
        if err == io.EOF {
            break
        }
        if err != nil {
            log.Fatal(err)
        }
        if osName == "linux" {
            // Remove carriage return (CR) characters.
            buf = buf[:n-1]
        }
        os.Stdout.Write(buf)
    }

    // Wait for the child process to exit.
    child.Wait()
}

可以使用以下命令將此程式碼編譯為獨立的二進位檔案:

go build -o ttypretend main.go

一次編譯完成後,可以如下執行程式:

./ttypretend

並且會輸出目前目錄的內容。

以上是如何讓我的程式在 Linux 和 macOS 中偽裝成 TTY?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn