From da120d3c079f0909d82de0d021d9b2d572806049 Mon Sep 17 00:00:00 2001 From: Mitchell Hashimoto Date: Tue, 5 Nov 2013 21:43:20 -0800 Subject: [PATCH] builder/qemu: remove constructor, more Go-like --- builder/qemu/builder.go | 6 ++++-- builder/qemu/driver.go | 22 ++++++---------------- 2 files changed, 10 insertions(+), 18 deletions(-) diff --git a/builder/qemu/builder.go b/builder/qemu/builder.go index 31d851963..83169f38e 100644 --- a/builder/qemu/builder.go +++ b/builder/qemu/builder.go @@ -469,8 +469,10 @@ func (b *Builder) newDriver() (Driver, error) { } log.Printf("Qemu path: %s, Qemu Image page: %s", qemuPath, qemuImgPath) - driver := &QemuDriver{} - driver.Initialize(qemuPath, qemuImgPath) + driver := &QemuDriver{ + QemuPath: qemuPath, + QemuImgPath: qemuImgPath, + } if err := driver.Verify(); err != nil { return nil, err diff --git a/builder/qemu/driver.go b/builder/qemu/driver.go index 7aa74f80f..f233faa1a 100644 --- a/builder/qemu/driver.go +++ b/builder/qemu/driver.go @@ -20,11 +20,6 @@ type DriverCancelCallback func(state multistep.StateBag) bool // A driver is able to talk to qemu-system-x86_64 and perform certain // operations with it. type Driver interface { - // Initializes the driver with the given values: - // Arguments: qemuPath - string value for the qemu-system-x86_64 executable - // qemuImgPath - string value for the qemu-img executable - Initialize(string, string) - // Stop stops a running machine, forcefully. Stop() error @@ -47,19 +42,14 @@ type Driver interface { } type QemuDriver struct { - qemuPath string - qemuImgPath string + QemuPath string + QemuImgPath string vmCmd *exec.Cmd vmEndCh <-chan int lock sync.Mutex } -func (d *QemuDriver) Initialize(qemuPath string, qemuImgPath string) { - d.qemuPath = qemuPath - d.qemuImgPath = qemuImgPath -} - func (d *QemuDriver) Stop() error { d.lock.Lock() defer d.lock.Unlock() @@ -84,8 +74,8 @@ func (d *QemuDriver) Qemu(qemuArgs ...string) error { stdout_r, stdout_w := io.Pipe() stderr_r, stderr_w := io.Pipe() - log.Printf("Executing %s: %#v", d.qemuPath, qemuArgs) - cmd := exec.Command(d.qemuPath, qemuArgs...) + log.Printf("Executing %s: %#v", d.QemuPath, qemuArgs) + cmd := exec.Command(d.QemuPath, qemuArgs...) cmd.Stdout = stdout_w cmd.Stderr = stderr_w @@ -154,7 +144,7 @@ func (d *QemuDriver) QemuImg(args ...string) error { var stdout, stderr bytes.Buffer log.Printf("Executing qemu-img: %#v", args) - cmd := exec.Command(d.qemuImgPath, args...) + cmd := exec.Command(d.QemuImgPath, args...) cmd.Stdout = &stdout cmd.Stderr = &stderr err := cmd.Run() @@ -179,7 +169,7 @@ func (d *QemuDriver) Verify() error { func (d *QemuDriver) Version() (string, error) { var stdout bytes.Buffer - cmd := exec.Command(d.qemuPath, "-version") + cmd := exec.Command(d.QemuPath, "-version") cmd.Stdout = &stdout if err := cmd.Run(); err != nil { return "", err