mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
96ce3a194a
This patch creates a new cli package that allows to combine both client and daemon commands (there is only one daemon command: docker daemon). The `-d` and `--daemon` top-level flags are deprecated and a special message is added to prompt the user to use `docker daemon`. Providing top-level daemon-specific flags for client commands result in an error message prompting the user to use `docker daemon`. This patch does not break any old but correct usages. This also makes `-d` and `--daemon` flags, as well as the `daemon` command illegal in client-only binaries. Signed-off-by: Tibor Vass <tibor@docker.com>
42 lines
913 B
Go
42 lines
913 B
Go
package client
|
|
|
|
import (
|
|
"io"
|
|
"os"
|
|
|
|
Cli "github.com/docker/docker/cli"
|
|
flag "github.com/docker/docker/pkg/mflag"
|
|
)
|
|
|
|
// CmdLoad loads an image from a tar archive.
|
|
//
|
|
// The tar archive is read from STDIN by default, or from a tar archive file.
|
|
//
|
|
// Usage: docker load [OPTIONS]
|
|
func (cli *DockerCli) CmdLoad(args ...string) error {
|
|
cmd := Cli.Subcmd("load", nil, "Load an image from a tar archive or STDIN", true)
|
|
infile := cmd.String([]string{"i", "-input"}, "", "Read from a tar archive file, instead of STDIN")
|
|
cmd.Require(flag.Exact, 0)
|
|
|
|
cmd.ParseFlags(args, true)
|
|
|
|
var (
|
|
input io.Reader = cli.in
|
|
err error
|
|
)
|
|
if *infile != "" {
|
|
input, err = os.Open(*infile)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
sopts := &streamOpts{
|
|
rawTerminal: true,
|
|
in: input,
|
|
out: cli.out,
|
|
}
|
|
if _, err := cli.stream("POST", "/images/load", sopts); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|