Commit e44fa1ab authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

post-processor/vagrant: Ability to specify Vagrantfile template

parent e0ab81ae
...@@ -16,11 +16,10 @@ var builtins = map[string]string{ ...@@ -16,11 +16,10 @@ var builtins = map[string]string{
type Config struct { type Config struct {
OutputPath string `mapstructure:"output"` OutputPath string `mapstructure:"output"`
} }
type PostProcessor struct { type PostProcessor struct {
config Config config Config
premade map[string]packer.PostProcessor premade map[string]packer.PostProcessor
} }
......
...@@ -12,7 +12,8 @@ import ( ...@@ -12,7 +12,8 @@ import (
) )
type VBoxBoxConfig struct { type VBoxBoxConfig struct {
OutputPath string `mapstructure:"output"` OutputPath string `mapstructure:"output"`
VagrantfileTemplate string `mapstructure:"vagrantfile_template"`
} }
type VBoxVagrantfileTemplate struct { type VBoxVagrantfileTemplate struct {
...@@ -70,7 +71,23 @@ func (p *VBoxBoxPostProcessor) PostProcess(ui packer.Ui, artifact packer.Artifac ...@@ -70,7 +71,23 @@ func (p *VBoxBoxPostProcessor) PostProcess(ui packer.Ui, artifact packer.Artifac
} }
defer vf.Close() defer vf.Close()
t := template.Must(template.New("vagrantfile").Parse(defaultVBoxVagrantfile)) vagrantfileContents := defaultVBoxVagrantfile
if p.config.VagrantfileTemplate != "" {
f, err := os.Open(p.config.VagrantfileTemplate)
if err != nil {
return nil, err
}
defer f.Close()
contents, err := ioutil.ReadAll(f)
if err != nil {
return nil, err
}
vagrantfileContents = string(contents)
}
t := template.Must(template.New("vagrantfile").Parse(vagrantfileContents))
t.Execute(vf, tplData) t.Execute(vf, tplData)
vf.Close() vf.Close()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment