Actually fixed the bug that could brick your system
This commit is contained in:
parent
c8fc1b902c
commit
3e8b247e83
@ -590,9 +590,21 @@ func InstallPackage(filename, installDir string, force, binaryPkgFromSrc, keepTe
|
||||
}
|
||||
if len(filesDiff) != 0 {
|
||||
fmt.Println("Removing obsolete files")
|
||||
var symlinks []string
|
||||
for _, f := range filesDiff {
|
||||
f = path.Join(installDir, f)
|
||||
stat, err := os.Lstat(f)
|
||||
lstat, err := os.Lstat(f)
|
||||
if os.IsNotExist(err) {
|
||||
continue
|
||||
}
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if lstat.Mode() == os.ModeSymlink {
|
||||
symlinks = append(symlinks, f)
|
||||
continue
|
||||
}
|
||||
stat, err := os.Stat(f)
|
||||
if os.IsNotExist(err) {
|
||||
continue
|
||||
}
|
||||
@ -619,6 +631,26 @@ func InstallPackage(filename, installDir string, force, binaryPkgFromSrc, keepTe
|
||||
}
|
||||
}
|
||||
}
|
||||
for _, f := range symlinks {
|
||||
f = path.Join(installDir, f)
|
||||
_, err := os.Lstat(f)
|
||||
if os.IsNotExist(err) {
|
||||
continue
|
||||
}
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
_, err = filepath.EvalSymlinks(f)
|
||||
if os.IsNotExist(err) {
|
||||
err := os.Remove(f)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
}
|
||||
return nil
|
||||
}
|
||||
@ -838,9 +870,21 @@ func RemovePackage(pkg, rootDir string) error {
|
||||
installedDir := path.Join(rootDir, "var/lib/bpm/installed/")
|
||||
pkgDir := path.Join(installedDir, pkg)
|
||||
files := GetPackageFiles(pkg, rootDir)
|
||||
var symlinks []string
|
||||
for _, file := range files {
|
||||
file = path.Join(rootDir, file)
|
||||
stat, err := os.Lstat(file)
|
||||
lstat, err := os.Lstat(file)
|
||||
if os.IsNotExist(err) {
|
||||
continue
|
||||
}
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if lstat.Mode() == os.ModeSymlink {
|
||||
symlinks = append(symlinks, file)
|
||||
continue
|
||||
}
|
||||
stat, err := os.Stat(file)
|
||||
if os.IsNotExist(err) {
|
||||
continue
|
||||
}
|
||||
@ -867,6 +911,26 @@ func RemovePackage(pkg, rootDir string) error {
|
||||
}
|
||||
}
|
||||
}
|
||||
for _, file := range symlinks {
|
||||
file = path.Join(rootDir, file)
|
||||
_, err := os.Lstat(file)
|
||||
if os.IsNotExist(err) {
|
||||
continue
|
||||
}
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
_, err = filepath.EvalSymlinks(file)
|
||||
if os.IsNotExist(err) {
|
||||
err := os.Remove(file)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
err := os.RemoveAll(pkgDir)
|
||||
if err != nil {
|
||||
return err
|
||||
|
2
main.go
2
main.go
@ -17,7 +17,7 @@ import (
|
||||
/* A simple-to-use package manager */
|
||||
/* ---------------------------------- */
|
||||
|
||||
var bpmVer = "0.1.5"
|
||||
var bpmVer = "0.1.6"
|
||||
|
||||
var subcommand = "help"
|
||||
var subcommandArgs []string
|
||||
|
Binary file not shown.
Binary file not shown.
@ -1,6 +1,6 @@
|
||||
name: bpm
|
||||
description: The Bubble Package Manager
|
||||
version: 0.1.5
|
||||
version: 0.1.6
|
||||
url: https://gitlab.com/bubble-package-manager/bpm/
|
||||
license: GPL3
|
||||
architecture: x86_64
|
||||
|
Loading…
x
Reference in New Issue
Block a user