diff --git a/src/arduino.cc/builder/sketch_loader.go b/src/arduino.cc/builder/sketch_loader.go index 48625543..ca5eb0e3 100644 --- a/src/arduino.cc/builder/sketch_loader.go +++ b/src/arduino.cc/builder/sketch_loader.go @@ -85,7 +85,7 @@ func (s *SketchLoader) Run(ctx *types.Context) error { logger := ctx.GetLogger() - if !utils.SliceContains(allSketchFilePaths, sketchLocation) { + if !utils.SliceContains(allSketchFilePaths, sketchLocation) && !ctx.SketchZipped { return i18n.ErrorfWithLogger(logger, constants.MSG_CANT_FIND_SKETCH_IN_PATH, sketchLocation, filepath.Dir(sketchLocation)) } diff --git a/src/arduino.cc/builder/utils/utils.go b/src/arduino.cc/builder/utils/utils.go index c96b75f3..698beb8e 100644 --- a/src/arduino.cc/builder/utils/utils.go +++ b/src/arduino.cc/builder/utils/utils.go @@ -477,19 +477,15 @@ func ExtractZip(filePath string, location string) (string, error) { var dirList []string - for _, f := range r.File { - dirList = append(dirList, f.Name) - } - - basedir := findBaseDir(dirList) - for _, f := range r.File { fullname := filepath.Join(location, strings.Replace(f.Name, "", "", -1)) if f.FileInfo().IsDir() { + dirList = append(dirList, fullname) os.MkdirAll(fullname, 0755) } else { _, err := os.Stat(filepath.Dir(fullname)) if err != nil { + dirList = append(dirList, filepath.Dir(fullname)) os.MkdirAll(filepath.Dir(fullname), 0755) } perms := f.FileInfo().Mode().Perm() @@ -515,26 +511,23 @@ func ExtractZip(filePath string, location string) (string, error) { } } } + basedir := filepath.Base(findBaseDir(dirList)) return filepath.Join(location, basedir), nil } func findBaseDir(dirList []string) string { baseDir := "" + minLen := 256 // https://github.com/backdrop-ops/contrib/issues/55#issuecomment-73814500 dontdiff := []string{"pax_global_header"} - for index := range dirList { - if SliceContains(dontdiff, dirList[index]) { + for _, dir := range dirList { + if SliceContains(dontdiff, dir) { continue } - candidateBaseDir := dirList[index] - for i := index; i < len(dirList); i++ { - if !strings.Contains(dirList[i], candidateBaseDir) { - return baseDir - } - } - // avoid setting the candidate if it is the last file - if dirList[len(dirList)-1] != candidateBaseDir { - baseDir = candidateBaseDir + //get the shortest string + if len(dir) < minLen { + baseDir = dir + minLen = len(dir) } } return baseDir