Improved symlink removal
This commit is contained in:
parent
4d7bf7179b
commit
555ea75403
@ -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 {
|
||||||
|
2
main.go
2
main.go
@ -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.
Binary file not shown.
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user