本文整理匯總了Golang中os/exec.Cmd.Stderr方法的典型用法代碼示例。如果您正苦於以下問題:Golang Cmd.Stderr方法的具體用法?Golang Cmd.Stderr怎麽用?Golang Cmd.Stderr使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類os/exec.Cmd
的用法示例。
在下文中一共展示了Cmd.Stderr方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: ExecBin
func (w *Worker) ExecBin(binPath string, args []string, maxRunTime int64) (string, error) {
var cmd *exec.Cmd
var stdout bytes.Buffer
var stderr bytes.Buffer
var err error
if len(args) == 0 {
cmd = exec.Command(binPath)
} else {
cmd = exec.Command(binPath, args...)
}
cmd.Stdout = &stdout
cmd.Stderr = &stderr
cmd.Start() // attention!
err, _ = w.CmdRunWithTimeout(cmd,
time.Duration(maxRunTime)*time.Second,
)
if err != nil {
return "", err
}
if len(stderr.String()) != 0 {
errMsg := strings.TrimRight(stderr.String(), "\n")
return "", errors.NewError(errMsg)
}
return strings.TrimRight(stdout.String(), "\n"), nil
}
示例2: runCmd
func runCmd(cmd *exec.Cmd) error {
if buildX {
dir := ""
if cmd.Dir != "" {
dir = "PWD=" + cmd.Dir + " "
}
env := strings.Join(cmd.Env, " ")
if env != "" {
env += " "
}
printcmd("%s%s%s", dir, env, strings.Join(cmd.Args, " "))
}
buf := new(bytes.Buffer)
buf.WriteByte('\n')
if buildV {
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
} else {
cmd.Stdout = buf
cmd.Stderr = buf
}
if !buildN {
cmd.Env = environ(cmd.Env)
if err := cmd.Run(); err != nil {
return fmt.Errorf("%s failed: %v%s", strings.Join(cmd.Args, " "), err, buf)
}
}
return nil
}
示例3: CloneRepo
func (r *AssetRoot) CloneRepo() error {
var cmd *exec.Cmd
repoHash := md5.Sum([]byte(r.GitRepo))
if err := os.MkdirAll(".gitrepos", os.ModePerm); err != nil {
return err
}
cloneDir := filepath.Join(".gitrepos", fmt.Sprintf("%x", repoHash))
r.Path = filepath.Join(cloneDir, r.Path)
if _, err := os.Stat(cloneDir); err != nil {
cmd = exec.Command("git", "clone", r.GitRepo, "--branch", r.GitBranch, cloneDir)
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
if err := cmd.Run(); err != nil {
return err
}
}
if r.GitRef == "" {
return nil
}
cmd = exec.Command("bash", "-c", strings.Join([]string{
"cd", cloneDir, "&&", "git", "checkout", r.GitRef,
"&&", "cd", "../../",
}, " "))
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
return cmd.Run()
}
示例4: finishRunning
func finishRunning(stepName string, cmd *exec.Cmd) bool {
log.Printf("Running: %v", stepName)
stdout, stderr := bytes.NewBuffer(nil), bytes.NewBuffer(nil)
if *verbose {
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
} else {
cmd.Stdout = stdout
cmd.Stderr = stderr
}
done := make(chan struct{})
defer close(done)
go func() {
for {
select {
case <-done:
return
case s := <-signals:
cmd.Process.Signal(s)
}
}
}()
if err := cmd.Run(); err != nil {
log.Printf("Error running %v: %v", stepName, err)
if !*verbose {
fmt.Printf("stdout:\n------\n%v\n------\n", string(stdout.Bytes()))
fmt.Printf("stderr:\n------\n%v\n------\n", string(stderr.Bytes()))
}
return false
}
return true
}
示例5: runPlayer
func runPlayer(command string, msgPath string) (*exec.Cmd, io.WriteCloser, io.ReadCloser, error) {
if argv := strings.Fields(command); len(argv) == 0 {
return nil, nil, nil, os.ErrInvalid
} else if name, err := exec.LookPath(argv[0]); err != nil {
return nil, nil, nil, err
} else if dir, err := os.Getwd(); err != nil {
return nil, nil, nil, err
} else {
cmd := exec.Cmd{Path: name, Args: argv, Dir: dir}
if stdin, err := cmd.StdinPipe(); err != nil {
return nil, nil, nil, err
} else if stdout, err := cmd.StdoutPipe(); err != nil {
return nil, nil, nil, err
} else {
if msgPath == "-" {
cmd.Stderr = os.Stderr
} else if msgPath != "" {
if w, err := os.Create(msgPath); err != nil {
// Connect to stderr instead
fmt.Fprintln(os.Stderr, err)
cmd.Stderr = os.Stderr
} else {
cmd.Stderr = w
}
}
if err := cmd.Start(); err != nil {
return nil, nil, nil, err
}
return &cmd, stdin, stdout, nil
}
}
}
示例6: AppendStderrWriter
func AppendStderrWriter(cmd *exec.Cmd, writer io.Writer) {
if cmd.Stderr == nil {
cmd.Stderr = writer
} else {
cmd.Stderr = io.MultiWriter(cmd.Stderr, writer)
}
}
示例7: Build
func (r *AgRecipe) Build(ctx *types.BuildContext) error {
log.Info("Building the_silver_searcher")
srcdir := r.UnpackedDir(ctx, r.Info())
var cmd *exec.Cmd
// Run autotools
cmd = exec.Command("autoreconf", "-i")
cmd.Dir = srcdir
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
if err := cmd.Run(); err != nil {
log.WithField("err", err).Error("Could not run autotools")
return err
}
log.Infof("Running ./configure")
cmd = exec.Command(
"./configure",
"--host="+ctx.CrossPrefix,
"--build=i686",
"PKG_CONFIG=/bin/true",
)
cmd.Dir = srcdir
cmd.Env = ctx.Env.
Append("CC", ctx.StaticFlags).
Set("CFLAGS", "-fPIC "+ctx.StaticFlags).
Set("PCRE_LIBS", ctx.DependencyEnv["pcre"]["LDFLAGS"]).
Set("PCRE_CFLAGS", ctx.DependencyEnv["pcre"]["CFLAGS"]).
Set("LZMA_LIBS", ctx.DependencyEnv["lzma"]["LDFLAGS"]).
Set("LZMA_CFLAGS", ctx.DependencyEnv["lzma"]["CFLAGS"]).
Set("ZLIB_LIBS", ctx.DependencyEnv["zlib"]["LDFLAGS"]).
Set("ZLIB_CFLAGS", ctx.DependencyEnv["zlib"]["CFLAGS"]).
AsSlice()
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stdout
if err := cmd.Run(); err != nil {
log.WithField("err", err).Error("Could not run configure")
return err
}
cmd = exec.Command("make")
cmd.Dir = srcdir
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stdout
if err := cmd.Run(); err != nil {
log.WithField("err", err).Error("Could not run make")
return err
}
log.Info("Finished building the_silver_searcher")
return nil
}
示例8: spawn
func spawn(cmd *exec.Cmd, ttySpec *garden.TTYSpec, stdout io.Writer, stderr io.Writer) (process, io.WriteCloser, error) {
var stdin io.WriteCloser
var err error
var processPty *os.File
if ttySpec != nil {
pty, tty, err := pty.Open()
if err != nil {
return nil, nil, err
}
// close our end of the tty after the process has spawned
defer tty.Close()
processPty = pty
stdin = pty
windowColumns := 80
windowRows := 24
if ttySpec.WindowSize != nil {
windowColumns = ttySpec.WindowSize.Columns
windowRows = ttySpec.WindowSize.Rows
}
ptyutil.SetWinSize(pty, windowColumns, windowRows)
cmd.Stdin = tty
cmd.Stdout = tty
cmd.Stderr = tty
go io.Copy(stdout, pty)
} else {
stdin, err = cmd.StdinPipe()
if err != nil {
return nil, nil, err
}
cmd.Stdout = stdout
cmd.Stderr = stderr
}
err = cmd.Start()
if err != nil {
return nil, nil, err
}
return &groupProcess{
process: cmd.Process,
processPty: processPty,
}, stdin, nil
}
示例9: Build
func (r *PvRecipe) Build(ctx *types.BuildContext) error {
log.Info("Building pv")
srcdir := r.UnpackedDir(ctx, r.Info())
var cmd *exec.Cmd
// 1. Configure
log.Infof("Running ./configure")
cmd = exec.Command(
"./configure",
"--host="+ctx.CrossPrefix,
"--build=i686",
)
cmd.Dir = srcdir
cmd.Env = ctx.Env.
Append("CC", ctx.StaticFlags).
Set("CFLAGS", ctx.StaticFlags).
AsSlice()
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stdout
if err := cmd.Run(); err != nil {
log.WithField("err", err).Error("Could not run configure")
return err
}
// 2. Fix linker in Makefile
cmd = exec.Command(
"sed",
"-i",
fmt.Sprintf("/^CC =/a LD = %s", ctx.Env.Get("LD")),
filepath.Join(srcdir, "Makefile"),
)
if err := cmd.Run(); err != nil {
log.WithField("err", err).Error("Could not patch Makefile")
return err
}
// 3. Run build
cmd = exec.Command("make")
cmd.Dir = srcdir
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stdout
if err := cmd.Run(); err != nil {
log.WithField("err", err).Error("Could not run make")
return err
}
log.Info("Finished building pv")
return nil
}
示例10: cloneRepo
func cloneRepo(name, location string) error {
src := "https://github.com/eris-ltd/" + name
var c *exec.Cmd
// if the .git directory exists within ~/.eris/services (or w/e)
// then pull rather than clone.
if _, err := os.Stat(filepath.Join(location, ".git")); !os.IsNotExist(err) {
logger.Debugf("The location exists. Attempting to pull instead.\n")
if err := pullRepo(location); err != nil {
return err
} else {
return nil
}
}
// if the ~/.eris/services (or w/e) directory exists, but it does
// not have a .git directory (caught above), then init the dir
// and pull the repo.
if _, err := os.Stat(location); !os.IsNotExist(err) {
c = exec.Command("git", "init", location)
c.Stdout = config.GlobalConfig.Writer
c.Stderr = config.GlobalConfig.ErrorWriter
if e2 := c.Run(); e2 != nil {
return e2
}
c = exec.Command("git", "remote", "add", "origin", src)
if e3 := c.Run(); e3 != nil {
return e3
}
if err := pullRepo(location); err != nil {
return err
} else {
return nil
}
// if no ~/.eris services (or w/e) directory exists, then it will
// simply clone in the directory.
} else {
c = exec.Command("git", "clone", src, location)
c.Stdout = config.GlobalConfig.Writer
c.Stderr = config.GlobalConfig.ErrorWriter
if err := c.Run(); err != nil {
return err
}
}
return nil
}
示例11: tee
func (r *RealCommandRunner) tee(cmd *exec.Cmd) {
if cmd.Stderr == nil {
cmd.Stderr = os.Stderr
} else if cmd.Stderr != nil {
cmd.Stderr = io.MultiWriter(cmd.Stderr, os.Stderr)
}
if cmd.Stdout == nil {
cmd.Stdout = os.Stderr
} else if cmd.Stdout != nil {
cmd.Stdout = io.MultiWriter(cmd.Stdout, os.Stderr)
}
}
示例12: RunCmd
// RunCmd runs c (which is assumed to be something short-lived, like a
// camput or camget command), capturing its stdout for return, and
// also capturing its stderr, just in the case of errors.
// If there's an error, the return error fully describes the command and
// all output.
func RunCmd(c *exec.Cmd) (output string, err error) {
var stdout, stderr bytes.Buffer
if testing.Verbose() {
c.Stderr = io.MultiWriter(os.Stderr, &stderr)
c.Stdout = io.MultiWriter(os.Stdout, &stdout)
} else {
c.Stderr = &stderr
c.Stdout = &stdout
}
err = c.Run()
if err != nil {
return "", fmt.Errorf("Error running command %+v: Stdout:\n%s\nStderr:\n%s\n", c, stdout.String(), stderr.String())
}
return stdout.String(), nil
}
示例13: dividedOutput
// dividedOutput runs the command and returns its standard output and standard error.
func dividedOutput(c *exec.Cmd) (stdout []byte, stderr []byte, err error) {
var outb, errb bytes.Buffer
c.Stdout = &outb
c.Stderr = &errb
err = c.Run()
return outb.Bytes(), errb.Bytes(), err
}
示例14: writeGitRepositoryArchive
func writeGitRepositoryArchive(w io.Writer, path string, ref GitCommitRef) error {
var cmd *exec.Cmd
// TODO: Stream as tar with gzip
if ref == EmptyGitCommitRef {
cmd = exec.Command("/usr/bin/git", "archive", "--format", "zip", "master")
} else {
cmd = exec.Command("/usr/bin/git", "archive", "--format", "zip", string(ref))
}
cmd.Env = []string{}
cmd.Dir = path
var stderr bytes.Buffer
cmd.Stderr = utils.LimitWriter(&stderr, 20*1024)
stdout, err := cmd.StdoutPipe()
if err != nil {
return err
}
if err := cmd.Start(); err != nil {
return err
}
io.Copy(w, stdout)
if err := cmd.Wait(); err != nil {
return errors.New(fmt.Sprintf("Failed to archive repository: %s\n", err.Error()) + stderr.String())
}
return nil
}
示例15: install
func (a *AutoInstOptions) install() {
sfx := ""
if a.InstallSuffix != "" {
sfx = a.InstallSuffix
}
osArchSfx := osArch + sfx
if a.Env == nil {
a.Env = map[string]string{}
}
roots := []string{}
if p := a.Env["GOROOT"]; p != "" {
roots = append(roots, filepath.Join(p, "pkg", osArchSfx))
}
for _, p := range pathList(a.Env["GOPATH"]) {
roots = append(roots, filepath.Join(p, "pkg", osArchSfx))
}
if len(roots) == 0 {
return
}
archiveOk := func(fn string) bool {
for _, root := range roots {
_, err := os.Stat(filepath.Join(root, fn))
if err == nil {
return true
}
}
return false
}
el := envSlice(a.Env)
installed := []string{}
for path, fn := range a.imports() {
if !archiveOk(fn) {
var cmd *exec.Cmd
if sfx == "" {
cmd = exec.Command("go", "install", path)
} else {
cmd = exec.Command("go", "install", "-installsuffix", sfx, path)
}
cmd.Env = el
cmd.Stderr = ioutil.Discard
cmd.Stdout = ioutil.Discard
cmd.Run()
if archiveOk(fn) {
installed = append(installed, path)
}
}
}
if len(installed) > 0 {
postMessage("auto-installed: %v", strings.Join(installed, ", "))
}
}