diff options
| author | Jeff Carr <[email protected]> | 2024-10-27 07:20:47 -0500 |
|---|---|---|
| committer | Jeff Carr <[email protected]> | 2024-10-27 07:20:47 -0500 |
| commit | eba6f5c1883014558baffbe97be9e24ee9453c44 (patch) | |
| tree | 73ae333742812da0ef10df360890f008029449b9 | |
| parent | 6b5323da11c5c47162d13784f170f37c2f6f74f1 (diff) | |
filepath.Walk is overkill here
Signed-off-by: Jeff Carr <[email protected]>
| -rw-r--r-- | backup.go | 39 | ||||
| -rw-r--r-- | backupDir.go | 47 |
2 files changed, 64 insertions, 22 deletions
@@ -4,8 +4,9 @@ package virtbuf // kick this out in 30 seconds import ( + "errors" + "fmt" "io" - "log" "os" "path/filepath" ) @@ -14,35 +15,29 @@ func backupFiles(srcDir string, destDir string) error { // Create the destination directory err := os.MkdirAll(destDir, os.ModePerm) if err != nil { - log.Println("Failed to create directory: %v", err) - return err + return errors.New(fmt.Sprintf("Failed to create directory: %v", err)) } - // Walk through the source directory - err = filepath.Walk(srcDir, func(path string, info os.FileInfo, err error) error { - if err != nil { - return err - } + // Read the contents of the source directory + entries, err := os.ReadDir(srcDir) + if err != nil { + return errors.New(fmt.Sprintf("Failed to read directory: %v", err)) + } - // Skip if it's not a .test file or if it's a directory - // if filepath.Ext(path) != ".json" || info.IsDir() { - if info.IsDir() { - return nil + // Iterate over the entries in the source directory + for _, entry := range entries { + // Skip directories and files that do not have the .test extension + if entry.IsDir() || filepath.Ext(entry.Name()) != ".test" { + continue } - // Destination file path - destPath := filepath.Join(destDir, info.Name()) + srcPath := filepath.Join(srcDir, entry.Name()) + destPath := filepath.Join(destDir, entry.Name()) // Copy the file - if err := copyFile(path, destPath); err != nil { - return err + if err := copyFile(srcPath, destPath); err != nil { + return errors.New(fmt.Sprintf("Failed to copy file %s: %v", entry.Name(), err)) } - return nil - }) - - if err != nil { - log.Println("Failed to copy files: %v", err) - return err } return nil } diff --git a/backupDir.go b/backupDir.go new file mode 100644 index 0000000..1c633af --- /dev/null +++ b/backupDir.go @@ -0,0 +1,47 @@ +package virtbuf + +// thank chatgpt for this because why. why write this if you can have it +// kick this out in 30 seconds + +import ( + "log" + "os" + "path/filepath" +) + +func backupDir(srcDir string, destDir string) error { + // Create the destination directory + err := os.MkdirAll(destDir, os.ModePerm) + if err != nil { + log.Println("Failed to create directory: %v", err) + return err + } + + // Walk through the source directory + err = filepath.Walk(srcDir, func(path string, info os.FileInfo, err error) error { + if err != nil { + return err + } + + // Skip if it's not a .test file or if it's a directory + // if filepath.Ext(path) != ".json" || info.IsDir() { + if info.IsDir() { + return nil + } + + // Destination file path + destPath := filepath.Join(destDir, info.Name()) + + // Copy the file + if err := copyFile(path, destPath); err != nil { + return err + } + return nil + }) + + if err != nil { + log.Println("Failed to copy files: %v", err) + return err + } + return nil +} |
