Commit 2a5a79d3 authored by Cristian Maglie's avatar Cristian Maglie

go-paths-helper API change

parent 65154185
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
[[projects]] [[projects]]
branch = "cli-inception" branch = "cli-inception"
digest = "1:6eba8131d991db4e2af3227360fd74387f558ff7f6087dc4370074e63ade1a71" digest = "1:3238cb26ae6f3f359a578afdf2c830d8110bea3a1fc10e620724db99e672d174"
name = "github.com/arduino/arduino-builder" name = "github.com/arduino/arduino-builder"
packages = [ packages = [
".", ".",
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
"utils", "utils",
] ]
pruneopts = "UT" pruneopts = "UT"
revision = "f99ab5a8093d682b710b9eebf67304aa829f5b15" revision = "f9276b5710cc5f2300d5e0bb352ed0771864b876"
source = "github.com/arduino/arduino-builder" source = "github.com/arduino/arduino-builder"
[[projects]] [[projects]]
...@@ -30,11 +30,11 @@ ...@@ -30,11 +30,11 @@
[[projects]] [[projects]]
branch = "master" branch = "master"
digest = "1:6e187ec48f872c78e3546a99d39d0a770771dc34c27b78a15f08fbf7175b39f5" digest = "1:5c252a193aaa1c0306a7465d11022653dab30d36c3ab5e1e47bd3d608659f061"
name = "github.com/arduino/go-paths-helper" name = "github.com/arduino/go-paths-helper"
packages = ["."] packages = ["."]
pruneopts = "UT" pruneopts = "UT"
revision = "571aca5072f595c081b5ecfb96a465b714533ae5" revision = "44d19052dd968f9ee7c3cc26043b81752794a6dd"
[[projects]] [[projects]]
branch = "master" branch = "master"
......
...@@ -209,7 +209,7 @@ func (release *PlatformRelease) RuntimeProperties() properties.Map { ...@@ -209,7 +209,7 @@ func (release *PlatformRelease) RuntimeProperties() properties.Map {
// present // present
func (release *PlatformRelease) GetLibrariesDir() *paths.Path { func (release *PlatformRelease) GetLibrariesDir() *paths.Path {
libDir := release.InstallDir.Join("libraries") libDir := release.InstallDir.Join("libraries")
if isDir, _ := libDir.IsDir(); isDir { if libDir.IsDir() {
return libDir return libDir
} }
return nil return nil
......
...@@ -64,9 +64,7 @@ func (pm *PackageManager) LoadHardwareFromDirectory(path *paths.Path) error { ...@@ -64,9 +64,7 @@ func (pm *PackageManager) LoadHardwareFromDirectory(path *paths.Path) error {
} }
// TODO: IS THIS CHECK NEEDED? can we ignore and let it fail at next ReadDir? // TODO: IS THIS CHECK NEEDED? can we ignore and let it fail at next ReadDir?
if isDir, err := path.IsDir(); err != nil { if !path.IsDir() {
return fmt.Errorf("reading %s stat info: %s", path, err)
} else if !isDir {
return fmt.Errorf("%s is not a directory", path) return fmt.Errorf("%s is not a directory", path)
} }
...@@ -103,10 +101,10 @@ func (pm *PackageManager) LoadHardwareFromDirectory(path *paths.Path) error { ...@@ -103,10 +101,10 @@ func (pm *PackageManager) LoadHardwareFromDirectory(path *paths.Path) error {
// in the latter case we just move into "hardware" directory and continue // in the latter case we just move into "hardware" directory and continue
var architectureParentPath *paths.Path var architectureParentPath *paths.Path
hardwareSubdirPath := packagerPath.Join("hardware") // ex: .arduino15/packages/arduino/hardware hardwareSubdirPath := packagerPath.Join("hardware") // ex: .arduino15/packages/arduino/hardware
if isDir, _ := hardwareSubdirPath.IsDir(); isDir { if hardwareSubdirPath.IsDir() {
// we found the "hardware" directory move down into that // we found the "hardware" directory move down into that
architectureParentPath = hardwareSubdirPath // ex: .arduino15/packages/arduino/ architectureParentPath = hardwareSubdirPath // ex: .arduino15/packages/arduino/
} else if isDir, _ := packagerPath.IsDir(); isDir { } else if packagerPath.IsDir() {
// we are already at the correct level // we are already at the correct level
architectureParentPath = packagerPath architectureParentPath = packagerPath
} else { } else {
...@@ -122,7 +120,7 @@ func (pm *PackageManager) LoadHardwareFromDirectory(path *paths.Path) error { ...@@ -122,7 +120,7 @@ func (pm *PackageManager) LoadHardwareFromDirectory(path *paths.Path) error {
// Check if we have tools to load, the directory structure is as follows: // Check if we have tools to load, the directory structure is as follows:
// - PACKAGER/tools/TOOL-NAME/TOOL-VERSION/... (ex: arduino/tools/bossac/1.7.0/...) // - PACKAGER/tools/TOOL-NAME/TOOL-VERSION/... (ex: arduino/tools/bossac/1.7.0/...)
toolsSubdirPath := packagerPath.Join("tools") toolsSubdirPath := packagerPath.Join("tools")
if isDir, _ := toolsSubdirPath.IsDir(); isDir { if toolsSubdirPath.IsDir() {
pm.Log.Infof("Checking existence of 'tools' path: %s", toolsSubdirPath) pm.Log.Infof("Checking existence of 'tools' path: %s", toolsSubdirPath)
if err := pm.loadToolsFromPackage(targetPackage, toolsSubdirPath); err != nil { if err := pm.loadToolsFromPackage(targetPackage, toolsSubdirPath); err != nil {
return fmt.Errorf("loading tools from %s: %s", toolsSubdirPath, err) return fmt.Errorf("loading tools from %s: %s", toolsSubdirPath, err)
...@@ -150,7 +148,7 @@ func (pm *PackageManager) loadPlatforms(targetPackage *cores.Package, packageDir ...@@ -150,7 +148,7 @@ func (pm *PackageManager) loadPlatforms(targetPackage *cores.Package, packageDir
continue continue
} }
platformPath := packageDir.Join(architecure) platformPath := packageDir.Join(architecure)
if isDir, _ := platformPath.IsDir(); !isDir { if !platformPath.IsDir() {
continue continue
} }
...@@ -159,7 +157,7 @@ func (pm *PackageManager) loadPlatforms(targetPackage *cores.Package, packageDir ...@@ -159,7 +157,7 @@ func (pm *PackageManager) loadPlatforms(targetPackage *cores.Package, packageDir
// - ARCHITECTURE/VERSION/boards.txt // - ARCHITECTURE/VERSION/boards.txt
// We identify them by checking where is the bords.txt file // We identify them by checking where is the bords.txt file
possibleBoardTxtPath := platformPath.Join("boards.txt") possibleBoardTxtPath := platformPath.Join("boards.txt")
if exist, err := possibleBoardTxtPath.Exist(); err != nil { if exist, err := possibleBoardTxtPath.ExistCheck(); err != nil {
return fmt.Errorf("looking for boards.txt in %s: %s", possibleBoardTxtPath, err) return fmt.Errorf("looking for boards.txt in %s: %s", possibleBoardTxtPath, err)
...@@ -169,7 +167,7 @@ func (pm *PackageManager) loadPlatforms(targetPackage *cores.Package, packageDir ...@@ -169,7 +167,7 @@ func (pm *PackageManager) loadPlatforms(targetPackage *cores.Package, packageDir
// this is an unversioned Platform // this is an unversioned Platform
// FIXME: this check is duplicated, find a better way to handle this // FIXME: this check is duplicated, find a better way to handle this
if exist, err := platformPath.Join("boards.txt").Exist(); err != nil { if exist, err := platformPath.Join("boards.txt").ExistCheck(); err != nil {
return fmt.Errorf("opening boards.txt: %s", err) return fmt.Errorf("opening boards.txt: %s", err)
} else if !exist { } else if !exist {
continue continue
...@@ -198,7 +196,7 @@ func (pm *PackageManager) loadPlatforms(targetPackage *cores.Package, packageDir ...@@ -198,7 +196,7 @@ func (pm *PackageManager) loadPlatforms(targetPackage *cores.Package, packageDir
versionDirs.FilterDirs() versionDirs.FilterDirs()
versionDirs.FilterOutHiddenFiles() versionDirs.FilterOutHiddenFiles()
for _, versionDir := range versionDirs { for _, versionDir := range versionDirs {
if exist, err := versionDir.Join("boards.txt").Exist(); err != nil { if exist, err := versionDir.Join("boards.txt").ExistCheck(); err != nil {
return fmt.Errorf("opening boards.txt: %s", err) return fmt.Errorf("opening boards.txt: %s", err)
} else if !exist { } else if !exist {
continue continue
......
...@@ -50,7 +50,7 @@ func (lm *LibrariesManager) Install(indexLibrary *librariesindex.Release) (*path ...@@ -50,7 +50,7 @@ func (lm *LibrariesManager) Install(indexLibrary *librariesindex.Release) (*path
libPath := libsDir.Join(utils.SanitizeName(indexLibrary.Library.Name)) libPath := libsDir.Join(utils.SanitizeName(indexLibrary.Library.Name))
if replaced != nil && replaced.InstallDir.EquivalentTo(libPath) { if replaced != nil && replaced.InstallDir.EquivalentTo(libPath) {
formatter.Print(fmt.Sprintf("Replacing %s with %s", replaced, indexLibrary)) formatter.Print(fmt.Sprintf("Replacing %s with %s", replaced, indexLibrary))
} else if isdir, _ := libPath.IsDir(); isdir { } else if libPath.IsDir() {
return nil, fmt.Errorf("destination dir %s already exists, cannot install", libPath) return nil, fmt.Errorf("destination dir %s already exists, cannot install", libPath)
} }
return libPath, indexLibrary.Resource.Install(lm.DownloadsDir, libsDir, libPath) return libPath, indexLibrary.Resource.Install(lm.DownloadsDir, libsDir, libPath)
......
...@@ -28,7 +28,7 @@ import ( ...@@ -28,7 +28,7 @@ import (
// Load loads a library from the given LibraryLocation // Load loads a library from the given LibraryLocation
func Load(libDir *paths.Path, location LibraryLocation) (*Library, error) { func Load(libDir *paths.Path, location LibraryLocation) (*Library, error) {
if exist, _ := libDir.Join("library.properties").Exist(); exist { if libDir.Join("library.properties").Exist() {
return makeNewLibrary(libDir, location) return makeNewLibrary(libDir, location)
} }
return makeLegacyLibrary(libDir, location) return makeLegacyLibrary(libDir, location)
...@@ -36,7 +36,7 @@ func Load(libDir *paths.Path, location LibraryLocation) (*Library, error) { ...@@ -36,7 +36,7 @@ func Load(libDir *paths.Path, location LibraryLocation) (*Library, error) {
func addUtilityDirectory(library *Library) { func addUtilityDirectory(library *Library) {
utilitySourcePath := library.InstallDir.Join("utility") utilitySourcePath := library.InstallDir.Join("utility")
if isDir, _ := utilitySourcePath.IsDir(); isDir { if utilitySourcePath.IsDir() {
library.UtilityDir = utilitySourcePath library.UtilityDir = utilitySourcePath
} }
} }
...@@ -60,7 +60,7 @@ func makeNewLibrary(libraryDir *paths.Path, location LibraryLocation) (*Library, ...@@ -60,7 +60,7 @@ func makeNewLibrary(libraryDir *paths.Path, location LibraryLocation) (*Library,
library := &Library{} library := &Library{}
library.Location = location library.Location = location
library.InstallDir = libraryDir library.InstallDir = libraryDir
if exist, _ := libraryDir.Join("src").Exist(); exist { if libraryDir.Join("src").Exist() {
library.Layout = RecursiveLayout library.Layout = RecursiveLayout
library.SourceDir = libraryDir.Join("src") library.SourceDir = libraryDir.Join("src")
} else { } else {
......
...@@ -41,12 +41,7 @@ func (r *DownloadResource) IsCached(downloadDir *paths.Path) (bool, error) { ...@@ -41,12 +41,7 @@ func (r *DownloadResource) IsCached(downloadDir *paths.Path) (bool, error) {
if err != nil { if err != nil {
return false, fmt.Errorf("getting archive path: %s", err) return false, fmt.Errorf("getting archive path: %s", err)
} }
exist, err := archivePath.Exist() return archivePath.Exist(), nil
if err != nil {
return false, fmt.Errorf("checking archive existence: %s", err)
}
return exist, nil
} }
// Download a DownloadResource. // Download a DownloadResource.
......
...@@ -76,7 +76,7 @@ func (release *DownloadResource) Install(downloadDir, tempPath, destDir *paths.P ...@@ -76,7 +76,7 @@ func (release *DownloadResource) Install(downloadDir, tempPath, destDir *paths.P
}() }()
// If the destination dir already exists remove it // If the destination dir already exists remove it
if isdir, _ := destDir.IsDir(); isdir { if destDir.IsDir() {
destDir.RemoveAll() destDir.RemoveAll()
} }
...@@ -110,7 +110,7 @@ func findPackageRoot(parent *paths.Path) (*paths.Path, error) { ...@@ -110,7 +110,7 @@ func findPackageRoot(parent *paths.Path) (*paths.Path, error) {
} }
var root *paths.Path var root *paths.Path
for _, file := range files { for _, file := range files {
if isdir, _ := file.IsDir(); !isdir { if !file.IsDir() {
continue continue
} }
if root == nil { if root == nil {
......
...@@ -35,13 +35,11 @@ func (config *Configuration) HardwareDirectories() (paths.PathList, error) { ...@@ -35,13 +35,11 @@ func (config *Configuration) HardwareDirectories() (paths.PathList, error) {
} }
} }
dir := config.PackagesDir() if dir := config.PackagesDir(); dir.IsDir() {
if isdir, _ := dir.IsDir(); isdir {
res.Add(dir) res.Add(dir)
} }
dir = config.SketchbookDir.Join("hardware") if dir := config.SketchbookDir.Join("hardware"); dir.IsDir() {
if isdir, _ := dir.IsDir(); isdir {
res.Add(dir) res.Add(dir)
} }
......
...@@ -130,7 +130,7 @@ func proxyConfigsFromIDEPrefs(props properties.Map) error { ...@@ -130,7 +130,7 @@ func proxyConfigsFromIDEPrefs(props properties.Map) error {
func IDEBundledLibrariesDir() *paths.Path { func IDEBundledLibrariesDir() *paths.Path {
if IsBundledInDesktopIDE() { if IsBundledInDesktopIDE() {
libDir := paths.New(*arduinoIDEDirectory, "libraries") libDir := paths.New(*arduinoIDEDirectory, "libraries")
if isDir, _ := libDir.IsDir(); isDir { if libDir.IsDir() {
return libDir return libDir
} }
} }
......
...@@ -144,7 +144,7 @@ func (s *ContainerFindIncludes) Run(ctx *types.Context) error { ...@@ -144,7 +144,7 @@ func (s *ContainerFindIncludes) Run(ctx *types.Context) error {
sourceFilePaths := ctx.CollectedSourceFiles sourceFilePaths := ctx.CollectedSourceFiles
queueSourceFilesFromFolder(ctx, sourceFilePaths, sketch, ctx.SketchBuildPath, false /* recurse */) queueSourceFilesFromFolder(ctx, sourceFilePaths, sketch, ctx.SketchBuildPath, false /* recurse */)
srcSubfolderPath := ctx.SketchBuildPath.Join(constants.SKETCH_FOLDER_SRC) srcSubfolderPath := ctx.SketchBuildPath.Join(constants.SKETCH_FOLDER_SRC)
if isDir, _ := srcSubfolderPath.IsDir(); isDir { if srcSubfolderPath.IsDir() {
queueSourceFilesFromFolder(ctx, sourceFilePaths, sketch, srcSubfolderPath, true /* recurse */) queueSourceFilesFromFolder(ctx, sourceFilePaths, sketch, srcSubfolderPath, true /* recurse */)
} }
......
...@@ -47,7 +47,7 @@ func (s *FailIfImportedLibraryIsWrong) Run(ctx *types.Context) error { ...@@ -47,7 +47,7 @@ func (s *FailIfImportedLibraryIsWrong) Run(ctx *types.Context) error {
for _, library := range ctx.ImportedLibraries { for _, library := range ctx.ImportedLibraries {
if !library.IsLegacy { if !library.IsLegacy {
if isDir, _ := library.InstallDir.Join(constants.LIBRARY_FOLDER_ARCH).IsDir(); isDir { if library.InstallDir.Join(constants.LIBRARY_FOLDER_ARCH).IsDir() {
return i18n.ErrorfWithLogger(logger, constants.MSG_ARCH_FOLDER_NOT_SUPPORTED) return i18n.ErrorfWithLogger(logger, constants.MSG_ARCH_FOLDER_NOT_SUPPORTED)
} }
for _, propName := range libraries.MandatoryProperties { for _, propName := range libraries.MandatoryProperties {
......
...@@ -40,13 +40,9 @@ type LoadPreviousBuildOptionsMap struct{} ...@@ -40,13 +40,9 @@ type LoadPreviousBuildOptionsMap struct{}
func (s *LoadPreviousBuildOptionsMap) Run(ctx *types.Context) error { func (s *LoadPreviousBuildOptionsMap) Run(ctx *types.Context) error {
buildOptionsFile := ctx.BuildPath.Join(constants.BUILD_OPTIONS_FILE) buildOptionsFile := ctx.BuildPath.Join(constants.BUILD_OPTIONS_FILE)
if exist, err := buildOptionsFile.Exist(); err == nil { if buildOptionsFile.NotExist() {
if !exist {
return nil return nil
} }
} else {
return i18n.WrapError(err)
}
bytes, err := buildOptionsFile.ReadFile() bytes, err := buildOptionsFile.ReadFile()
if err != nil { if err != nil {
...@@ -54,6 +50,5 @@ func (s *LoadPreviousBuildOptionsMap) Run(ctx *types.Context) error { ...@@ -54,6 +50,5 @@ func (s *LoadPreviousBuildOptionsMap) Run(ctx *types.Context) error {
} }
ctx.BuildOptionsJsonPrevious = string(bytes) ctx.BuildOptionsJsonPrevious = string(bytes)
return nil return nil
} }
...@@ -58,9 +58,9 @@ func (s *MergeSketchWithBootloader) Run(ctx *types.Context) error { ...@@ -58,9 +58,9 @@ func (s *MergeSketchWithBootloader) Run(ctx *types.Context) error {
sketchInSubfolder := buildPath.Join(constants.FOLDER_SKETCH, sketchFileName+".hex") sketchInSubfolder := buildPath.Join(constants.FOLDER_SKETCH, sketchFileName+".hex")
var builtSketchPath *paths.Path var builtSketchPath *paths.Path
if exist, _ := sketchInBuildPath.Exist(); exist { if sketchInBuildPath.Exist() {
builtSketchPath = sketchInBuildPath builtSketchPath = sketchInBuildPath
} else if exist, _ := sketchInSubfolder.Exist(); exist { } else if sketchInSubfolder.Exist() {
builtSketchPath = sketchInSubfolder builtSketchPath = sketchInSubfolder
} else { } else {
return nil return nil
...@@ -75,7 +75,7 @@ func (s *MergeSketchWithBootloader) Run(ctx *types.Context) error { ...@@ -75,7 +75,7 @@ func (s *MergeSketchWithBootloader) Run(ctx *types.Context) error {
bootloader = buildProperties.ExpandPropsInString(bootloader) bootloader = buildProperties.ExpandPropsInString(bootloader)
bootloaderPath := buildProperties.GetPath(constants.BUILD_PROPERTIES_RUNTIME_PLATFORM_PATH).Join(constants.FOLDER_BOOTLOADERS, bootloader) bootloaderPath := buildProperties.GetPath(constants.BUILD_PROPERTIES_RUNTIME_PLATFORM_PATH).Join(constants.FOLDER_BOOTLOADERS, bootloader)
if exist, _ := bootloaderPath.Exist(); !exist { if bootloaderPath.NotExist() {
logger.Fprintln(os.Stdout, constants.LOG_LEVEL_WARN, constants.MSG_BOOTLOADER_FILE_MISSING, bootloaderPath) logger.Fprintln(os.Stdout, constants.LOG_LEVEL_WARN, constants.MSG_BOOTLOADER_FILE_MISSING, bootloaderPath)
return nil return nil
} }
......
...@@ -55,7 +55,7 @@ func (s *SketchBuilder) Run(ctx *types.Context) error { ...@@ -55,7 +55,7 @@ func (s *SketchBuilder) Run(ctx *types.Context) error {
// The "src/" subdirectory of a sketch is compiled recursively // The "src/" subdirectory of a sketch is compiled recursively
sketchSrcPath := sketchBuildPath.Join(constants.SKETCH_FOLDER_SRC) sketchSrcPath := sketchBuildPath.Join(constants.SKETCH_FOLDER_SRC)
if isDir, _ := sketchSrcPath.IsDir(); isDir { if sketchSrcPath.IsDir() {
srcObjectFiles, err := builder_utils.CompileFiles(ctx, sketchSrcPath, true, sketchSrcPath, buildProperties, includes) srcObjectFiles, err := builder_utils.CompileFiles(ctx, sketchSrcPath, true, sketchSrcPath, buildProperties, includes)
if err != nil { if err != nil {
return i18n.WrapError(err) return i18n.WrapError(err)
......
...@@ -89,7 +89,7 @@ func (s *PlatformKeysRewriteLoader) Run(ctx *types.Context) error { ...@@ -89,7 +89,7 @@ func (s *PlatformKeysRewriteLoader) Run(ctx *types.Context) error {
func findPlatformKeysRewriteTxt(folders paths.PathList) (*paths.Path, error) { func findPlatformKeysRewriteTxt(folders paths.PathList) (*paths.Path, error) {
for _, folder := range folders { for _, folder := range folders {
txtPath := folder.Join(constants.FILE_PLATFORM_KEYS_REWRITE_TXT) txtPath := folder.Join(constants.FILE_PLATFORM_KEYS_REWRITE_TXT)
if exist, err := txtPath.Exist(); exist { if exist, err := txtPath.ExistCheck(); exist {
return txtPath, nil return txtPath, nil
} else if err != nil { } else if err != nil {
return nil, i18n.WrapError(err) return nil, i18n.WrapError(err)
......
...@@ -41,7 +41,7 @@ type UnusedCompiledLibrariesRemover struct{} ...@@ -41,7 +41,7 @@ type UnusedCompiledLibrariesRemover struct{}
func (s *UnusedCompiledLibrariesRemover) Run(ctx *types.Context) error { func (s *UnusedCompiledLibrariesRemover) Run(ctx *types.Context) error {
librariesBuildPath := ctx.LibrariesBuildPath librariesBuildPath := ctx.LibrariesBuildPath
if exist, _ := librariesBuildPath.Exist(); !exist { if librariesBuildPath.NotExist() {
return nil return nil
} }
...@@ -52,7 +52,7 @@ func (s *UnusedCompiledLibrariesRemover) Run(ctx *types.Context) error { ...@@ -52,7 +52,7 @@ func (s *UnusedCompiledLibrariesRemover) Run(ctx *types.Context) error {
return i18n.WrapError(err) return i18n.WrapError(err)
} }
for _, file := range files { for _, file := range files {
if isDir, _ := file.IsDir(); isDir { if file.IsDir() {
if !utils.SliceContains(libraryNames, file.Base()) { if !utils.SliceContains(libraryNames, file.Base()) {
if err := file.RemoveAll(); err != nil { if err := file.RemoveAll(); err != nil {
return i18n.WrapError(err) return i18n.WrapError(err)
......
...@@ -37,7 +37,7 @@ using this library can be done this way: ...@@ -37,7 +37,7 @@ using this library can be done this way:
```go ```go
buildPath := paths.New("/path/to/somewhere") buildPath := paths.New("/path/to/somewhere")
srcPath := buildPath.Join("src") srcPath := buildPath.Join("src")
if isDir, _ := srcPath.IsDir(); !isDir { if !srcPath.IsDir() {
scrPath.MkdirAll() scrPath.MkdirAll()
} }
``` ```
......
...@@ -67,7 +67,7 @@ func (p *PathList) AsStrings() []string { ...@@ -67,7 +67,7 @@ func (p *PathList) AsStrings() []string {
func (p *PathList) FilterDirs() { func (p *PathList) FilterDirs() {
res := (*p)[:0] res := (*p)[:0]
for _, path := range *p { for _, path := range *p {
if isDir, _ := path.IsDir(); isDir { if path.IsDir() {
res = append(res, path) res = append(res, path)
} }
} }
...@@ -78,7 +78,7 @@ func (p *PathList) FilterDirs() { ...@@ -78,7 +78,7 @@ func (p *PathList) FilterDirs() {
func (p *PathList) FilterOutDirs() { func (p *PathList) FilterOutDirs() {
res := (*p)[:0] res := (*p)[:0]
for _, path := range *p { for _, path := range *p {
if isDir, _ := path.IsDir(); isDir { if path.IsDir() {
res = append(res, path) res = append(res, path)
} }
} }
......
...@@ -229,8 +229,23 @@ func (p *Path) FollowSymLink() error { ...@@ -229,8 +229,23 @@ func (p *Path) FollowSymLink() error {
return nil return nil
} }
// Exist return true if the path exists // Exist return true if the file denoted by this path exists, false
func (p *Path) Exist() (bool, error) { // in any other case (also in case of error).
func (p *Path) Exist() bool {
exist, err := p.ExistCheck()
return exist && err == nil
}
// NotExist return true if the file denoted by this path DO NOT exists, false
// in any other case (also in case of error).
func (p *Path) NotExist() bool {
exist, err := p.ExistCheck()
return !exist && err == nil
}
// ExistCheck return true if the path exists or false if the path doesn't exists.
// In case the check fails false is returned together with the corresponding error.
func (p *Path) ExistCheck() (bool, error) {
_, err := p.Stat() _, err := p.Stat()
if err == nil { if err == nil {
return true, nil return true, nil
...@@ -241,8 +256,24 @@ func (p *Path) Exist() (bool, error) { ...@@ -241,8 +256,24 @@ func (p *Path) Exist() (bool, error) {
return false, err return false, err
} }
// IsDir return true if the path exists and is a directory // IsDir returns true if the path exists and is a directory. In all the other
func (p *Path) IsDir() (bool, error) { // cases (and also in case of any error) false is returned.
func (p *Path) IsDir() bool {
isdir, err := p.IsDirCheck()
return isdir && err == nil
}
// IsNotDir returns true if the path exists and is NOT a directory. In all the other
// cases (and also in case of any error) false is returned.
func (p *Path) IsNotDir() bool {
isdir, err := p.IsDirCheck()
return !isdir && err == nil
}
// IsDirCheck return true if the path exists and is a directory or false
// if the path exists and is not a directory. In all the other case false and
// the corresponding error is returned.
func (p *Path) IsDirCheck() (bool, error) {
info, err := p.Stat() info, err := p.Stat()
if err == nil { if err == nil {
return info.IsDir(), nil return info.IsDir(), nil
...@@ -315,15 +346,12 @@ func (p *Path) CopyDirTo(dst *Path) error { ...@@ -315,15 +346,12 @@ func (p *Path) CopyDirTo(dst *Path) error {
src := p.Clean() src := p.Clean()
dst = dst.Clean() dst = dst.Clean()
srcInfo, err := src.Stat() srcFiles, err := src.ReadDir()
if err != nil { if err != nil {
return fmt.Errorf("getting stat infor for %s: %s", src, err) return fmt.Errorf("error reading source dir %s: %s", src, err)
}
if !srcInfo.IsDir() {
return fmt.Errorf("%s is not a directory", src)
} }
if exist, err := dst.Exist(); exist { if exist, err := dst.ExistCheck(); exist {
return fmt.Errorf("destination %s already exists", dst) return fmt.Errorf("destination %s already exists", dst)
} else if err != nil { } else if err != nil {
return fmt.Errorf("checking if %s exists: %s", dst, err) return fmt.Errorf("checking if %s exists: %s", dst, err)
...@@ -332,13 +360,13 @@ func (p *Path) CopyDirTo(dst *Path) error { ...@@ -332,13 +360,13 @@ func (p *Path) CopyDirTo(dst *Path) error {
if err := dst.MkdirAll(); err != nil { if err := dst.MkdirAll(); err != nil {
return fmt.Errorf("creating destination dir %s: %s", dst, err) return fmt.Errorf("creating destination dir %s: %s", dst, err)
} }
if err := os.Chmod(dst.path, srcInfo.Mode()); err != nil {
return fmt.Errorf("setting permission for dir %s: %s", dst, err)
}
srcFiles, err := src.ReadDir() srcInfo, err := src.Stat()
if err != nil { if err != nil {
return fmt.Errorf("error reading source dir %s: %s", src, err) return fmt.Errorf("getting stat info for %s: %s", src, err)
}
if err := os.Chmod(dst.path, srcInfo.Mode()); err != nil {
return fmt.Errorf("setting permission for dir %s: %s", dst, err)
} }
for _, srcPath := range srcFiles { for _, srcPath := range srcFiles {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment