1. ホーム
  2. go

[解決済み] 終了コードを取得する - Go

2023-06-28 16:13:47

質問

os/exec パッケージを使用しています。 http://golang.org/pkg/os/exec/ を使用してオペレーティングシステムでコマンドを実行していますが、終了コードを取得する方法が見つからないようです。私は出力を読むことができるけれども

ie。

package main

import(
    "os/exec"
    "bytes"
    "fmt"
    "log"
    )

func main() {
    cmd := exec.Command("somecommand", "parameter")
    var out bytes.Buffer
    cmd.Stdout = &out
    if err := cmd.Run() ; err != nil {
        //log.Fatal( cmd.ProcessState.Success() )
        log.Fatal( err )
    }
    fmt.Printf("%q\n", out.String() )
}

どのように解決するのですか?

終了コードが0なのか、それ以外なのかを判断するのは簡単です。最初のケースでは cmd.Wait() は nil を返します (パイプのセットアップ中に他のエラーがない限り)。

残念ながら、エラー時の終了コードを取得するためのプラットフォームに依存しない方法はありません。これがAPIの一部でない理由でもあります。以下のスニペットはLinuxで動作しますが、他のプラットフォームではテストしていません。

package main

import "os/exec"
import "log"
import "syscall"

func main() {
    cmd := exec.Command("git", "blub")

    if err := cmd.Start(); err != nil {
        log.Fatalf("cmd.Start: %v", err)
    }

    if err := cmd.Wait(); err != nil {
        if exiterr, ok := err.(*exec.ExitError); ok {
            // The program has exited with an exit code != 0

            // This works on both Unix and Windows. Although package
            // syscall is generally platform dependent, WaitStatus is
            // defined for both Unix and Windows and in both cases has
            // an ExitStatus() method with the same signature.
            if status, ok := exiterr.Sys().(syscall.WaitStatus); ok {
                log.Printf("Exit Status: %d", status.ExitStatus())
            }
        } else {
            log.Fatalf("cmd.Wait: %v", err)
        }
    }
}

ただ フォロー アピ ドキュメント で詳細を確認できます :)