Merge pull request #3890 from yoctocloud/floppy

unbreak glob pattern in floppy_files
This commit is contained in:
Rickard von Essen 2016-11-21 20:56:38 +01:00 committed by GitHub
commit b8c09fd2a1
8 changed files with 32 additions and 16 deletions

View File

@ -3,6 +3,8 @@ package common
import ( import (
"fmt" "fmt"
"os" "os"
"path/filepath"
"strings"
"github.com/mitchellh/packer/template/interpolate" "github.com/mitchellh/packer/template/interpolate"
) )
@ -14,13 +16,19 @@ type FloppyConfig struct {
func (c *FloppyConfig) Prepare(ctx *interpolate.Context) []error { func (c *FloppyConfig) Prepare(ctx *interpolate.Context) []error {
var errs []error var errs []error
var err error
if c.FloppyFiles == nil { if c.FloppyFiles == nil {
c.FloppyFiles = make([]string, 0) c.FloppyFiles = make([]string, 0)
} }
for _, path := range c.FloppyFiles { for _, path := range c.FloppyFiles {
if _, err := os.Stat(path); err != nil { if strings.IndexAny(path, "*?[") >= 0 {
_, err = filepath.Glob(path)
} else {
_, err = os.Stat(path)
}
if err != nil {
errs = append(errs, fmt.Errorf("Bad Floppy disk file '%s': %s", path, err)) errs = append(errs, fmt.Errorf("Bad Floppy disk file '%s': %s", path, err))
} }
} }
@ -30,7 +38,12 @@ func (c *FloppyConfig) Prepare(ctx *interpolate.Context) []error {
} }
for _, path := range c.FloppyDirectories { for _, path := range c.FloppyDirectories {
if _, err := os.Stat(path); err != nil { if strings.IndexAny(path, "*?[") >= 0 {
_, err = filepath.Glob(path)
} else {
_, err = os.Stat(path)
}
if err != nil {
errs = append(errs, fmt.Errorf("Bad Floppy disk directory '%s': %s", path, err)) errs = append(errs, fmt.Errorf("Bad Floppy disk directory '%s': %s", path, err))
} }
} }

View File

@ -79,12 +79,15 @@ builder.
five seconds and one minute 30 seconds, respectively. If this isn't five seconds and one minute 30 seconds, respectively. If this isn't
specified, the default is 10 seconds. specified, the default is 10 seconds.
- `floppy_files` (array of strings) - A list of files to put onto a floppy - `floppy_files` (array of strings) - A list of files to place onto a floppy
disk that is attached when the VM is booted for the first time. This is most disk that is attached when the VM is booted. This is most useful for
useful for unattended Windows installs, which look for an `Autounattend.xml` unattended Windows installs, which look for an `Autounattend.xml` file on
file on removable media. By default no floppy will be attached. The files removable media. By default, no floppy will be attached. All files listed in
listed in this configuration will all be put into the root directory of the this setting get placed into the root directory of the floppy and the floppy
floppy disk; sub-directories are not supported. is attached as the first floppy device. Currently, no support exists for
creating sub-directories on the floppy. Wildcard characters (\*, ?,
and \[\]) are allowed. Directory names are also allowed, which will add all
the files found in the directory to the floppy.
- `floppy_dirs` (array of strings) - A list of directories to place onto - `floppy_dirs` (array of strings) - A list of directories to place onto
the floppy disk recursively. This is similar to the `floppy_files` option the floppy disk recursively. This is similar to the `floppy_files` option

View File

@ -153,7 +153,7 @@ builder.
- `floppy_dirs` (array of strings) - A list of directories to place onto - `floppy_dirs` (array of strings) - A list of directories to place onto
the floppy disk recursively. This is similar to the `floppy_files` option the floppy disk recursively. This is similar to the `floppy_files` option
except that the directory structure is preserved. This is useful for when except that the directory structure is preserved. This is useful for when
your floppy disk includes drivers or if you just want to organize its your floppy disk includes drivers or if you just want to organize it's
contents as a hierarchy. Wildcard characters (\*, ?, and \[\]) are allowed. contents as a hierarchy. Wildcard characters (\*, ?, and \[\]) are allowed.
- `format` (string) - Either "ovf" or "ova", this specifies the output format - `format` (string) - Either "ovf" or "ova", this specifies the output format