本文整理匯總了Golang中github.com/codegangsta/cli.Context.exec方法的典型用法代碼示例。如果您正苦於以下問題:Golang Context.exec方法的具體用法?Golang Context.exec怎麽用?Golang Context.exec使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/codegangsta/cli.Context
的用法示例。
在下文中一共展示了Context.exec方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: run
func (rax *RaxCloud) run(ctx *cli.Context, eng *engine.Engine) (err error) {
if err = rax.configure(ctx); err == nil {
if _, name, err := rax.findTargetHost(); err == nil {
if name == "" {
rax.createHost(DASS_TARGET_PREFIX + RandomString()[:12])
}
} else {
return err
}
eng.Register("create", func(job *engine.Job) (status engine.Status) {
if ctx, err := rax.getHostContext(); err == nil {
defer ctx.Close()
return ctx.exec(job, func(client HttpClient) (status engine.Status) {
path := "/containers/create"
config := runconfig.ContainerConfigFromJob(job)
if data, err := json.Marshal(config); err != nil {
return job.Errorf("marshaling failure : %v", err)
} else if resp, err := client.Post(path, string(data)); err != nil {
return job.Error(err)
} else {
var container struct {
Id string
Warnings []string
}
if body, err := ioutil.ReadAll(resp.Body); err != nil {
return job.Errorf("Failed to copy response body: %v", err)
} else if err := json.Unmarshal([]byte(body), &container); err != nil {
return job.Errorf("Failed to read container info from body: %v", err)
} else {
job.Printf("%s\n", container.Id)
}
}
return engine.StatusOK
})
} else {
return job.Errorf("Failed to create host context: %v", err)
}
})
eng.Register("container_delete", func(job *engine.Job) (status engine.Status) {
if ctx, err := rax.getHostContext(); err == nil {
defer ctx.Close()
return ctx.exec(job, func(client HttpClient) (status engine.Status) {
path := fmt.Sprintf("/containers/%s?force=%s", job.Args[0], url.QueryEscape(job.Getenv("forceRemove")))
if _, err := client.Delete(path, ""); err != nil {
return job.Error(err)
}
return engine.StatusOK
})
} else {
return job.Errorf("Failed to create host context: %v", err)
}
})
eng.Register("containers", func(job *engine.Job) (status engine.Status) {
if ctx, err := rax.getHostContext(); err == nil {
defer ctx.Close()
return ctx.exec(job, func(client HttpClient) (status engine.Status) {
path := fmt.Sprintf("/containers/json?all=%s&limit=%s",
url.QueryEscape(job.Getenv("all")), url.QueryEscape(job.Getenv("limit")))
if resp, err := client.Get(path, ""); err != nil {
return job.Error(err)
} else {
created := engine.NewTable("Created", 0)
if body, err := ioutil.ReadAll(resp.Body); err != nil {
return job.Errorf("Failed to copy response body: %v", err)
} else if created.ReadListFrom(body); err != nil {
return job.Errorf("Failed to read list from body: %v", err)
} else {
created.WriteListTo(job.Stdout)
}
}
return engine.StatusOK
})
} else {
return job.Errorf("Failed to create host context: %v", err)
}
})
eng.Register("version", func(job *engine.Job) (status engine.Status) {
if ctx, err := rax.getHostContext(); err == nil {
defer ctx.Close()
return ctx.exec(job, func(client HttpClient) (status engine.Status) {
path := "/version"
if resp, err := client.Get(path, ""); err != nil {
return job.Errorf("Failed call %s(path:%s): %v", job.Name, path, err)
//.........這裏部分代碼省略.........