|
|
@ -43,25 +43,26 @@ type buildOptions struct {
|
|
|
|
contextPath string
|
|
|
|
contextPath string
|
|
|
|
dockerfileName string
|
|
|
|
dockerfileName string
|
|
|
|
|
|
|
|
|
|
|
|
allow []string
|
|
|
|
allow []string
|
|
|
|
buildArgs []string
|
|
|
|
buildArgs []string
|
|
|
|
cacheFrom []string
|
|
|
|
cacheFrom []string
|
|
|
|
cacheTo []string
|
|
|
|
cacheTo []string
|
|
|
|
cgroupParent string
|
|
|
|
cgroupParent string
|
|
|
|
contexts []string
|
|
|
|
contexts []string
|
|
|
|
extraHosts []string
|
|
|
|
extraHosts []string
|
|
|
|
imageIDFile string
|
|
|
|
imageIDFile string
|
|
|
|
labels []string
|
|
|
|
labels []string
|
|
|
|
networkMode string
|
|
|
|
networkMode string
|
|
|
|
outputs []string
|
|
|
|
noCacheFilter []string
|
|
|
|
platforms []string
|
|
|
|
outputs []string
|
|
|
|
quiet bool
|
|
|
|
platforms []string
|
|
|
|
secrets []string
|
|
|
|
quiet bool
|
|
|
|
shmSize dockeropts.MemBytes
|
|
|
|
secrets []string
|
|
|
|
ssh []string
|
|
|
|
shmSize dockeropts.MemBytes
|
|
|
|
tags []string
|
|
|
|
ssh []string
|
|
|
|
target string
|
|
|
|
tags []string
|
|
|
|
ulimits *dockeropts.UlimitOpt
|
|
|
|
target string
|
|
|
|
|
|
|
|
ulimits *dockeropts.UlimitOpt
|
|
|
|
commonOptions
|
|
|
|
commonOptions
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -99,6 +100,10 @@ func runBuild(dockerCli command.Cli, in buildOptions) (err error) {
|
|
|
|
pull = *in.pull
|
|
|
|
pull = *in.pull
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if noCache && len(in.noCacheFilter) > 0 {
|
|
|
|
|
|
|
|
return errors.Errorf("--no-cache and --no-cache-filter cannot currently be used together")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if in.quiet && in.progress != "auto" && in.progress != "quiet" {
|
|
|
|
if in.quiet && in.progress != "auto" && in.progress != "quiet" {
|
|
|
|
return errors.Errorf("progress=%s and quiet cannot be used together", in.progress)
|
|
|
|
return errors.Errorf("progress=%s and quiet cannot be used together", in.progress)
|
|
|
|
} else if in.quiet {
|
|
|
|
} else if in.quiet {
|
|
|
@ -117,17 +122,18 @@ func runBuild(dockerCli command.Cli, in buildOptions) (err error) {
|
|
|
|
InStream: os.Stdin,
|
|
|
|
InStream: os.Stdin,
|
|
|
|
NamedContexts: contexts,
|
|
|
|
NamedContexts: contexts,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
BuildArgs: listToMap(in.buildArgs, true),
|
|
|
|
BuildArgs: listToMap(in.buildArgs, true),
|
|
|
|
ExtraHosts: in.extraHosts,
|
|
|
|
ExtraHosts: in.extraHosts,
|
|
|
|
ImageIDFile: in.imageIDFile,
|
|
|
|
ImageIDFile: in.imageIDFile,
|
|
|
|
Labels: listToMap(in.labels, false),
|
|
|
|
Labels: listToMap(in.labels, false),
|
|
|
|
NetworkMode: in.networkMode,
|
|
|
|
NetworkMode: in.networkMode,
|
|
|
|
NoCache: noCache,
|
|
|
|
NoCache: noCache,
|
|
|
|
Pull: pull,
|
|
|
|
NoCacheFilter: in.noCacheFilter,
|
|
|
|
ShmSize: in.shmSize,
|
|
|
|
Pull: pull,
|
|
|
|
Tags: in.tags,
|
|
|
|
ShmSize: in.shmSize,
|
|
|
|
Target: in.target,
|
|
|
|
Tags: in.tags,
|
|
|
|
Ulimits: in.ulimits,
|
|
|
|
Target: in.target,
|
|
|
|
|
|
|
|
Ulimits: in.ulimits,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
platforms, err := platformutil.Parse(in.platforms)
|
|
|
|
platforms, err := platformutil.Parse(in.platforms)
|
|
|
@ -360,6 +366,8 @@ func buildCmd(dockerCli command.Cli, rootOpts *rootOptions) *cobra.Command {
|
|
|
|
|
|
|
|
|
|
|
|
flags.StringVar(&options.networkMode, "network", "default", `Set the networking mode for the "RUN" instructions during build`)
|
|
|
|
flags.StringVar(&options.networkMode, "network", "default", `Set the networking mode for the "RUN" instructions during build`)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
flags.StringArrayVar(&options.noCacheFilter, "no-cache-filter", []string{}, "Do not cache specified stages")
|
|
|
|
|
|
|
|
|
|
|
|
flags.StringArrayVarP(&options.outputs, "output", "o", []string{}, `Output destination (format: "type=local,dest=path")`)
|
|
|
|
flags.StringArrayVarP(&options.outputs, "output", "o", []string{}, `Output destination (format: "type=local,dest=path")`)
|
|
|
|
|
|
|
|
|
|
|
|
flags.StringArrayVar(&options.platforms, "platform", platformsDefault, "Set target platform for build")
|
|
|
|
flags.StringArrayVar(&options.platforms, "platform", platformsDefault, "Set target platform for build")
|
|
|
|