|
|
@ -88,11 +88,12 @@ type Inputs struct {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
type DriverInfo struct {
|
|
|
|
type DriverInfo struct {
|
|
|
|
Driver driver.Driver
|
|
|
|
Driver driver.Driver
|
|
|
|
Name string
|
|
|
|
Name string
|
|
|
|
Platform []specs.Platform
|
|
|
|
Platform []specs.Platform
|
|
|
|
Err error
|
|
|
|
Err error
|
|
|
|
ImageOpt imagetools.Opt
|
|
|
|
ImageOpt imagetools.Opt
|
|
|
|
|
|
|
|
ProxyConfig map[string]string
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
type DockerAPI interface {
|
|
|
|
type DockerAPI interface {
|
|
|
@ -339,7 +340,8 @@ func toRepoOnly(in string) (string, error) {
|
|
|
|
return strings.Join(out, ","), nil
|
|
|
|
return strings.Join(out, ","), nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func toSolveOpt(ctx context.Context, d driver.Driver, multiDriver bool, opt Options, bopts gateway.BuildOpts, configDir string, pw progress.Writer, dl dockerLoadCallback) (solveOpt *client.SolveOpt, release func(), err error) {
|
|
|
|
func toSolveOpt(ctx context.Context, di DriverInfo, multiDriver bool, opt Options, bopts gateway.BuildOpts, configDir string, pw progress.Writer, dl dockerLoadCallback) (solveOpt *client.SolveOpt, release func(), err error) {
|
|
|
|
|
|
|
|
d := di.Driver
|
|
|
|
defers := make([]func(), 0, 2)
|
|
|
|
defers := make([]func(), 0, 2)
|
|
|
|
releaseF := func() {
|
|
|
|
releaseF := func() {
|
|
|
|
for _, f := range defers {
|
|
|
|
for _, f := range defers {
|
|
|
@ -548,6 +550,12 @@ func toSolveOpt(ctx context.Context, d driver.Driver, multiDriver bool, opt Opti
|
|
|
|
so.FrontendAttrs["label:"+k] = v
|
|
|
|
so.FrontendAttrs["label:"+k] = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for k, v := range di.ProxyConfig {
|
|
|
|
|
|
|
|
if _, ok := opt.BuildArgs[k]; !ok {
|
|
|
|
|
|
|
|
so.FrontendAttrs["build-arg:"+k] = v
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// set platforms
|
|
|
|
// set platforms
|
|
|
|
if len(opt.Platforms) != 0 {
|
|
|
|
if len(opt.Platforms) != 0 {
|
|
|
|
pp := make([]string, len(opt.Platforms))
|
|
|
|
pp := make([]string, len(opt.Platforms))
|
|
|
@ -642,12 +650,12 @@ func Build(ctx context.Context, drivers []DriverInfo, opt map[string]Options, do
|
|
|
|
multiDriver := len(m[k]) > 1
|
|
|
|
multiDriver := len(m[k]) > 1
|
|
|
|
hasMobyDriver := false
|
|
|
|
hasMobyDriver := false
|
|
|
|
for i, dp := range m[k] {
|
|
|
|
for i, dp := range m[k] {
|
|
|
|
d := drivers[dp.driverIndex].Driver
|
|
|
|
di := drivers[dp.driverIndex]
|
|
|
|
if d.IsMobyDriver() {
|
|
|
|
if di.Driver.IsMobyDriver() {
|
|
|
|
hasMobyDriver = true
|
|
|
|
hasMobyDriver = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
opt.Platforms = dp.platforms
|
|
|
|
opt.Platforms = dp.platforms
|
|
|
|
so, release, err := toSolveOpt(ctx, d, multiDriver, opt, dp.bopts, configDir, w, func(name string) (io.WriteCloser, func(), error) {
|
|
|
|
so, release, err := toSolveOpt(ctx, di, multiDriver, opt, dp.bopts, configDir, w, func(name string) (io.WriteCloser, func(), error) {
|
|
|
|
return newDockerLoader(ctx, docker, name, w)
|
|
|
|
return newDockerLoader(ctx, docker, name, w)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|