@@ -5,7 +5,7 @@ ARG XX_VERSION=1.1.2
55ARG OSXCROSS_VERSION=11.3-r7-alpine
66ARG GOLANGCI_LINT_VERSION=v1.47.3
77
8- ARG PKG =github.com/docker/docker-credential-helpers
8+ ARG PACKAGE =github.com/docker/docker-credential-helpers
99
1010# xx is a helper for cross-compilation
1111FROM --platform=$BUILDPLATFORM tonistiigi/xx:${XX_VERSION} AS xx
@@ -15,7 +15,7 @@ FROM crazymax/osxcross:${OSXCROSS_VERSION} AS osxcross
1515
1616FROM --platform=$BUILDPLATFORM golang:${GO_VERSION}-alpine AS gobase
1717COPY --from=xx / /
18- RUN apk add --no-cache clang file git lld llvm pkgconf rsync
18+ RUN apk add --no-cache clang file git lld llvm make pkgconf rsync
1919ENV GOFLAGS="-mod=vendor"
2020ENV CGO_ENABLED="1"
2121WORKDIR /src
@@ -57,13 +57,6 @@ RUN --mount=type=bind,target=. \
5757 --mount=from=golangci-lint,source=/usr/bin/golangci-lint,target=/usr/bin/golangci-lint \
5858 golangci-lint run ./...
5959
60- FROM gobase AS version
61- ARG PKG
62- RUN --mount=target=. \
63- VERSION=$(git describe --match 'v[0-9]*' --dirty='.m' --always --tags); \
64- echo "-s -w -X ${PKG}/credentials.Version=${VERSION}" | tee /tmp/.ldflags; \
65- echo -n "${VERSION}" | tee /tmp/.version;
66-
6760FROM gobase AS base
6861ARG TARGETPLATFORM
6962RUN xx-apk add musl-dev gcc libsecret-dev pass
@@ -93,50 +86,49 @@ FROM scratch AS test-coverage
9386COPY --from=test /out /
9487
9588FROM base AS build-linux
89+ ARG PACKAGE
9690ARG TARGETOS
9791ARG TARGETARCH
9892ARG TARGETVARIANT
9993RUN --mount=type=bind,target=. \
10094 --mount=type=cache,target=/root/.cache \
101- --mount=type=cache,target=/go/pkg/mod \
102- --mount=type=bind,from=version,source=/tmp/.ldflags,target=/tmp/.ldflags <<EOT
95+ --mount=type=cache,target=/go/pkg/mod <<EOT
10396 set -ex
104- mkdir /out
105- xx-go build -ldflags "$(cat /tmp/.ldflags)" -o / out/ docker-credential-pass-${TARGETOS}-${TARGETARCH}${TARGETVARIANT} ./pass/cmd/
97+ xx-go --wrap
98+ make build-pass PACKAGE=$PACKAGE DESTDIR=/ out BINNAME= docker-credential-pass-${TARGETOS}-${TARGETARCH}${TARGETVARIANT}
10699 xx-verify /out/docker-credential-pass-${TARGETOS}-${TARGETARCH}${TARGETVARIANT}
107- xx-go build -ldflags "$(cat /tmp/.ldflags)" -o / out/ docker-credential-secretservice-${TARGETOS}-${TARGETARCH}${TARGETVARIANT} ./secretservice/cmd/
100+ make build-secretservice PACKAGE=$PACKAGE DESTDIR=/ out BINNAME= docker-credential-secretservice-${TARGETOS}-${TARGETARCH}${TARGETVARIANT}
108101 xx-verify /out/docker-credential-secretservice-${TARGETOS}-${TARGETARCH}${TARGETVARIANT}
109102EOT
110103
111104FROM base AS build-darwin
105+ ARG PACKAGE
112106ARG TARGETOS
113107ARG TARGETARCH
114108ARG TARGETVARIANT
115109RUN --mount=type=bind,target=. \
116110 --mount=type=cache,target=/root/.cache \
117111 --mount=type=cache,target=/go/pkg/mod \
118- --mount=type=bind,from=osxcross,src=/osxsdk,target=/xx-sdk \
119- --mount=type=bind,from=version,source=/tmp/.ldflags,target=/tmp/.ldflags <<EOT
112+ --mount=type=bind,from=osxcross,src=/osxsdk,target=/xx-sdk <<EOT
120113 set -ex
121- mkdir /out
122- xx- go install std
123- xx-go build -ldflags "$(cat /tmp/.ldflags)" -o / out/ docker-credential-osxkeychain-${TARGETARCH}${TARGETVARIANT} ./osxkeychain/cmd/
114+ xx-go --wrap
115+ go install std
116+ make build-osxkeychain PACKAGE=$PACKAGE DESTDIR=/ out BINNAME= docker-credential-osxkeychain-${TARGETARCH}${TARGETVARIANT}
124117 xx-verify /out/docker-credential-osxkeychain-${TARGETARCH}${TARGETVARIANT}
125-
126- xx-go build -ldflags "$(cat /tmp/.ldflags)" -o /out/docker-credential-pass-${TARGETOS}-${TARGETARCH}${TARGETVARIANT} ./pass/cmd/
118+ make build-pass PACKAGE=$PACKAGE DESTDIR=/out BINNAME=docker-credential-pass-${TARGETOS}-${TARGETARCH}${TARGETVARIANT}
127119 xx-verify /out/docker-credential-pass-${TARGETOS}-${TARGETARCH}${TARGETVARIANT}
128120EOT
129121
130122FROM base AS build-windows
123+ ARG PACKAGE
131124ARG TARGETARCH
132125ARG TARGETVARIANT
133126RUN --mount=type=bind,target=. \
134127 --mount=type=cache,target=/root/.cache \
135- --mount=type=cache,target=/go/pkg/mod \
136- --mount=type=bind,from=version,source=/tmp/.ldflags,target=/tmp/.ldflags <<EOT
128+ --mount=type=cache,target=/go/pkg/mod <<EOT
137129 set -ex
138- mkdir /out
139- xx-go build -ldflags "$(cat /tmp/.ldflags)" -o / out/ docker-credential-wincred-${TARGETARCH}${TARGETVARIANT}.exe ./wincred/cmd/
130+ xx-go --wrap
131+ make build-wincred PACKAGE=$PACKAGE DESTDIR=/ out BINNAME= docker-credential-wincred-${TARGETARCH}${TARGETVARIANT}.exe
140132 xx-verify /out/docker-credential-wincred-${TARGETARCH}${TARGETVARIANT}.exe
141133EOT
142134
0 commit comments