-/*
-goredo -- djb's redo implementation on pure Go
-Copyright (C) 2020-2023 Sergey Matveev <stargrave@stargrave.org>
-
-This program is free software: you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation, version 3 of the License.
-
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with this program. If not, see <http://www.gnu.org/licenses/>.
-*/
+// goredo -- djb's redo implementation on pure Go
+// Copyright (C) 2020-2024 Sergey Matveev <stargrave@stargrave.org>
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation, version 3 of the License.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program. If not, see <http://www.gnu.org/licenses/>.
package main
"log"
"os"
"path"
- "path/filepath"
"strings"
)
}
func redoDirClean(root, what string) error {
- root, err := filepath.Abs(root)
- if err != nil {
- panic(err)
- }
+ root = mustAbs(root)
dir, err := os.Open(root)
if err != nil {
- return err
+ return ErrLine(err)
}
defer dir.Close()
for {
if err == io.EOF {
break
}
- return err
+ return ErrLine(err)
}
var pth string
for _, entry := range entries {
fmt.Println(pth)
if !*DryRun {
if err = os.Remove(pth); err != nil {
- return err
+ return ErrLine(err)
}
}
}
fmt.Println(pth)
if !*DryRun {
if err = os.Remove(pth); err != nil {
- return err
+ return ErrLine(err)
}
}
}
fmt.Println(pth)
if !*DryRun {
if err = os.Remove(pth); err != nil {
- return err
+ return ErrLine(err)
}
}
}
default:
- log.Fatalln("unknown cleanup target")
+ log.Fatal("unknown cleanup target")
}
}
}
}
func cleanupWalker(root, what string) error {
- root, err := filepath.Abs(root)
- if err != nil {
- panic(err)
- }
+ root = mustAbs(root)
dir, err := os.Open(root)
if err != nil {
- return err
+ return ErrLine(err)
}
defer dir.Close()
for {
if err == io.EOF {
break
}
- return err
+ return ErrLine(err)
}
for _, entry := range entries {
pth := path.Join(root, entry.Name())
if what == CleanupFull {
fmt.Println(pthRel)
if !*DryRun {
- err = os.RemoveAll(pth)
+ err = ErrLine(os.RemoveAll(pth))
}
} else {
err = redoDirClean(pth, what)
strings.HasPrefix(entry.Name(), TmpPrefix) {
fmt.Println(pthRel)
if !*DryRun {
- err = os.RemoveAll(pth)
+ err = ErrLine(os.RemoveAll(pth))
}
} else {
err = cleanupWalker(pth, what)
fmt.Println(pthRel)
if !*DryRun {
if err = os.Remove(pth); err != nil {
- return err
+ return ErrLine(err)
}
}
}