forked from bmatcuk/go-vagrant
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcommand_port.go
49 lines (44 loc) · 1.46 KB
/
command_port.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
42
43
44
45
46
47
48
49
package vagrant
// PortCommand specifies the options and output of vagrant port. Note that
// the port command is unique in that the MachineName option is required if
// your Vagrantfile defines more than one VM!
type PortCommand struct {
BaseCommand
MachineNameArgument
PortResponse
}
// Port will return information about ports forwarded from the host to the
// guest machine. After setting options as appropriate, you must call Run()
// or Start() followed by Wait() to execute. Output will be in ForwardedPorts
// with any error in Error.
//
// This appears to be the only vagrant command that cannot handle multi-vm
// Vagrantfiles for some reason. If your Vagrantfile brings up multiple
// machines, you MUST specify which machine you are interested in by specifying
// the PortCommand.MachineName option!
func (client *VagrantClient) Port() *PortCommand {
return &PortCommand{
BaseCommand: newBaseCommand(client),
PortResponse: newPortResponse(),
}
}
func (cmd *PortCommand) init() error {
if cmd.MachineName != "" {
return cmd.BaseCommand.init(&cmd.PortResponse, "port", cmd.MachineName)
}
return cmd.BaseCommand.init(&cmd.PortResponse, "port")
}
// Run the command
func (cmd *PortCommand) 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 *PortCommand) Start() error {
if err := cmd.init(); err != nil {
return err
}
return cmd.BaseCommand.Start()
}