build: handle lowercase Dockerfile name as a fallback

This was supported by the legacy builder: moby#10858

Signed-off-by: Tonis Tiigi <tonistiigi@gmail.com>
pull/444/head
Tonis Tiigi 4 years ago
parent 1ccf0bd7d8
commit f057195a4f

@ -796,12 +796,14 @@ func LoadInputs(inp Inputs, target *client.SolveOpt) (func(), error) {
if dockerfileName == "" { if dockerfileName == "" {
dockerfileName = "Dockerfile" dockerfileName = "Dockerfile"
} }
target.FrontendAttrs["filename"] = dockerfileName
if dockerfileDir != "" { if dockerfileDir != "" {
target.LocalDirs["dockerfile"] = dockerfileDir target.LocalDirs["dockerfile"] = dockerfileDir
dockerfileName = handleLowercaseDockerfile(dockerfileDir, dockerfileName)
} }
target.FrontendAttrs["filename"] = dockerfileName
release := func() { release := func() {
for _, dir := range toRemove { for _, dir := range toRemove {
os.RemoveAll(dir) os.RemoveAll(dir)
@ -889,3 +891,34 @@ func (w *waitingWriter) Close() error {
} }
return err return err
} }
// handle https://github.com/moby/moby/pull/10858
func handleLowercaseDockerfile(dir, p string) string {
if filepath.Base(p) != "Dockerfile" {
return p
}
f, err := os.Open(filepath.Dir(filepath.Join(dir, p)))
if err != nil {
return p
}
names, err := f.Readdirnames(-1)
if err != nil {
return p
}
foundLowerCase := false
for _, n := range names {
if n == "Dockerfile" {
return p
}
if n == "dockerfile" {
foundLowerCase = true
}
}
if foundLowerCase {
return filepath.Join(filepath.Dir(p), "dockerfile")
}
return p
}

Loading…
Cancel
Save