|
@@ -3,16 +3,9 @@ package daemon
|
|
import (
|
|
import (
|
|
"fmt"
|
|
"fmt"
|
|
"io"
|
|
"io"
|
|
-
|
|
|
|
- "github.com/docker/docker/engine"
|
|
|
|
)
|
|
)
|
|
|
|
|
|
-func (daemon *Daemon) ContainerExport(job *engine.Job) error {
|
|
|
|
- if len(job.Args) != 1 {
|
|
|
|
- return fmt.Errorf("Usage: %s container_id", job.Name)
|
|
|
|
- }
|
|
|
|
- name := job.Args[0]
|
|
|
|
-
|
|
|
|
|
|
+func (daemon *Daemon) ContainerExport(name string, out io.Writer) error {
|
|
container, err := daemon.Get(name)
|
|
container, err := daemon.Get(name)
|
|
if err != nil {
|
|
if err != nil {
|
|
return err
|
|
return err
|
|
@@ -25,7 +18,7 @@ func (daemon *Daemon) ContainerExport(job *engine.Job) error {
|
|
defer data.Close()
|
|
defer data.Close()
|
|
|
|
|
|
// Stream the entire contents of the container (basically a volatile snapshot)
|
|
// Stream the entire contents of the container (basically a volatile snapshot)
|
|
- if _, err := io.Copy(job.Stdout, data); err != nil {
|
|
|
|
|
|
+ if _, err := io.Copy(out, data); err != nil {
|
|
return fmt.Errorf("%s: %s", name, err)
|
|
return fmt.Errorf("%s: %s", name, err)
|
|
}
|
|
}
|
|
// FIXME: factor job-specific LogEvent to engine.Job.Run()
|
|
// FIXME: factor job-specific LogEvent to engine.Job.Run()
|