diff --git a/local/compose/build.go b/local/compose/build.go index 5a6f1f9f8..a2cae6565 100644 --- a/local/compose/build.go +++ b/local/compose/build.go @@ -26,12 +26,14 @@ import ( "github.com/docker/compose-cli/api/compose" "github.com/compose-spec/compose-go/types" + "github.com/containerd/containerd/platforms" "github.com/docker/buildx/build" "github.com/docker/buildx/driver" _ "github.com/docker/buildx/driver/docker" // required to get default driver registered "github.com/docker/buildx/util/progress" "github.com/docker/docker/errdefs" bclient "github.com/moby/buildkit/client" + specs "github.com/opencontainers/image-spec/specs-go/v1" ) func (s *composeService) Build(ctx context.Context, project *types.Project, options compose.BuildOptions) error { @@ -41,7 +43,10 @@ func (s *composeService) Build(ctx context.Context, project *types.Project, opti if service.Build != nil { imageName := getImageName(service, project.Name) imagesToBuild = append(imagesToBuild, imageName) - buildOptions := s.toBuildOptions(service, project.WorkingDir, imageName) + buildOptions, err := s.toBuildOptions(service, project.WorkingDir, imageName) + if err != nil { + return err + } buildOptions.Pull = options.Pull buildOptions.BuildArgs = options.Args opts[imageName] = buildOptions @@ -75,7 +80,10 @@ func (s *composeService) ensureImagesExists(ctx context.Context, project *types. continue } imagesToBuild = append(imagesToBuild, imageName) - opts[imageName] = s.toBuildOptions(service, project.WorkingDir, imageName) + opts[imageName], err = s.toBuildOptions(service, project.WorkingDir, imageName) + if err != nil { + return err + } continue } if service.Image != "" { @@ -148,7 +156,7 @@ func (s *composeService) build(ctx context.Context, project *types.Project, opts return err } -func (s *composeService) toBuildOptions(service types.ServiceConfig, contextPath string, imageTag string) build.Options { +func (s *composeService) toBuildOptions(service types.ServiceConfig, contextPath string, imageTag string) (build.Options, error) { var tags []string tags = append(tags, imageTag) @@ -157,6 +165,15 @@ func (s *composeService) toBuildOptions(service types.ServiceConfig, contextPath } var buildArgs map[string]string + var plats []specs.Platform + if service.Platform != "" { + p, err := platforms.Parse(service.Platform) + if err != nil { + return build.Options{}, err + } + plats = append(plats, p) + } + return build.Options{ Inputs: build.Inputs{ ContextPath: path.Join(contextPath, service.Build.Context), @@ -166,7 +183,8 @@ func (s *composeService) toBuildOptions(service types.ServiceConfig, contextPath Tags: tags, Target: service.Build.Target, Exports: []bclient.ExportEntry{{Type: "image", Attrs: map[string]string{}}}, - } + Platforms: plats, + }, nil } func flatten(in types.MappingWithEquals) map[string]string {