forked from bmatcuk/go-vagrant
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcommand_status.go
41 lines (36 loc) · 1.06 KB
/
command_status.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
package vagrant
// StatusCommand specifies options and output from vagrant status
type StatusCommand struct {
BaseCommand
MachineNameArgument
StatusResponse
}
// Status will return the status of vagrant machines. After setting options as
// appropriate, you must call Run() or Start() followed by Wait() to execute.
// Output will be in Status and any error will be in Error.
func (client *VagrantClient) Status() *StatusCommand {
return &StatusCommand{
BaseCommand: newBaseCommand(client),
StatusResponse: newStatusResponse(),
}
}
func (cmd *StatusCommand) init() error {
if cmd.MachineName != "" {
return cmd.BaseCommand.init(&cmd.StatusResponse, "status", cmd.MachineName)
}
return cmd.BaseCommand.init(&cmd.StatusResponse, "status")
}
// Run the command
func (cmd *StatusCommand) Run() error {
if err := cmd.Start(); err != nil {
return err
}
return cmd.Wait()
}
// Start the command. You must call Wait() to complete execution.
func (cmd *StatusCommand) Start() error {
if err := cmd.init(); err != nil {
return err
}
return cmd.BaseCommand.Start()
}