Improved symlink removal

This commit is contained in:
CapCreeperGR 2024-04-27 09:47:48 +03:00
parent 4d7bf7179b
commit 555ea75403
5 changed files with 48 additions and 40 deletions

View File

@ -836,19 +836,17 @@ func InstallPackage(filename, installDir string, force, binaryPkgFromSrc, keepTe
lstat, err := os.Lstat(f) lstat, err := os.Lstat(f)
if os.IsNotExist(err) { if os.IsNotExist(err) {
continue continue
} } else if err != nil {
if err != nil {
return err return err
} }
if lstat.Mode() == os.ModeSymlink { if lstat.Mode()&os.ModeSymlink != 0 {
symlinks = append(symlinks, f) symlinks = append(symlinks, f)
continue continue
} }
stat, err := os.Stat(f) stat, err := os.Stat(f)
if os.IsNotExist(err) { if os.IsNotExist(err) {
continue continue
} } else if err != nil {
if err != nil {
return err return err
} }
if stat.IsDir() { if stat.IsDir() {
@ -871,24 +869,29 @@ func InstallPackage(filename, installDir string, force, binaryPkgFromSrc, keepTe
} }
} }
} }
for _, f := range symlinks { removals := -1
f = path.Join(installDir, f) for len(symlinks) > 0 && removals != 0 {
_, err := os.Lstat(f) removals = 0
if os.IsNotExist(err) { for i := len(symlinks) - 1; i >= 0; i-- {
continue f := symlinks[i]
} f = path.Join(installDir, f)
if err != nil { _, err := os.Lstat(f)
return err if os.IsNotExist(err) {
} continue
_, err = filepath.EvalSymlinks(f) } else if err != nil {
if os.IsNotExist(err) { return err
err := os.Remove(f) }
if err != nil { _, err = filepath.EvalSymlinks(f)
if os.IsNotExist(err) {
err := os.Remove(f)
if err != nil {
return err
}
removals++
fmt.Println("Removing: " + f)
} else if err != nil {
return err return err
} }
}
if err != nil {
return err
} }
} }
} }
@ -1135,7 +1138,7 @@ func RemovePackage(pkg, rootDir string) error {
if err != nil { if err != nil {
return err return err
} }
if lstat.Mode() == os.ModeSymlink { if lstat.Mode()&os.ModeSymlink != 0 {
symlinks = append(symlinks, file) symlinks = append(symlinks, file)
continue continue
} }
@ -1166,24 +1169,29 @@ func RemovePackage(pkg, rootDir string) error {
} }
} }
} }
for _, file := range symlinks { removals := -1
file = path.Join(rootDir, file) for len(symlinks) > 0 && removals != 0 {
_, err := os.Lstat(file) removals = 0
if os.IsNotExist(err) { for i := len(symlinks) - 1; i >= 0; i-- {
continue file := symlinks[i]
} file = path.Join(rootDir, file)
if err != nil { _, err := os.Lstat(file)
return err if os.IsNotExist(err) {
} continue
_, err = filepath.EvalSymlinks(file) } else if err != nil {
if os.IsNotExist(err) { return err
err := os.Remove(file) }
if err != nil { _, err = filepath.EvalSymlinks(file)
if os.IsNotExist(err) {
err := os.Remove(file)
if err != nil {
return err
}
removals++
fmt.Println("Removing: " + file)
} else if err != nil {
return err return err
} }
}
if err != nil {
return err
} }
} }
if _, err := os.Stat(path.Join(pkgDir, "post_remove.sh")); err == nil { if _, err := os.Stat(path.Join(pkgDir, "post_remove.sh")); err == nil {

View File

@ -17,7 +17,7 @@ import (
/* A simple-to-use package manager */ /* A simple-to-use package manager */
/* ---------------------------------- */ /* ---------------------------------- */
var bpmVer = "0.2.0" var bpmVer = "0.2.1"
var subcommand = "help" var subcommand = "help"
var subcommandArgs []string var subcommandArgs []string

Binary file not shown.

View File

@ -1,6 +1,6 @@
name: bpm name: bpm
description: The Bubble Package Manager description: The Bubble Package Manager
version: 0.2.0 version: 0.2.1
url: https://gitlab.com/bubble-package-manager/bpm/ url: https://gitlab.com/bubble-package-manager/bpm/
license: GPL3 license: GPL3
architecture: x86_64 architecture: x86_64