aboutsummaryrefslogtreecommitdiff
path: root/lib/purge.c
diff options
context:
space:
mode:
authorJoseph Hunkeler <jhunkeler@users.noreply.github.com>2020-04-19 00:35:25 -0400
committerGitHub <noreply@github.com>2020-04-19 00:35:25 -0400
commit57c9489b28a481abc078ad3a2dd197079f9c414b (patch)
tree12cc1ea0186b242a82d87bc2f62142e5decefedb /lib/purge.c
parent59f7d29e2d707373ba1153337dca3279a2e3acc5 (diff)
parent8cdddbb0f1a8c6eb023cbe732e5701240a54ff3c (diff)
downloadspmc-57c9489b28a481abc078ad3a2dd197079f9c414b.tar.gz
Merge pull request #25 from jhunkeler/error-handler-etc
Error handler etc
Diffstat (limited to 'lib/purge.c')
-rw-r--r--lib/purge.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/lib/purge.c b/lib/purge.c
index 997df51..da3e5e6 100644
--- a/lib/purge.c
+++ b/lib/purge.c
@@ -14,6 +14,7 @@ int spm_purge(SPM_Hierarchy *fs, const char *_package_name) {
char *package_topdir = join((char *[]) {fs->dbrecdir, package_name, NULL}, DIRSEPS);
char *descriptor = join((char *[]) {package_topdir, SPM_META_DESCRIPTOR, NULL}, DIRSEPS);
char *filelist = join((char *[]) {package_topdir, SPM_META_FILELIST, NULL}, DIRSEPS);
+ char *rootrec = join((char *[]){path, "var", ".spm_root"}, DIRSEPS);
if (spm_check_installed(fs, package_name) == 0) {
// package is not installed in this root
@@ -67,6 +68,11 @@ int spm_purge(SPM_Hierarchy *fs, const char *_package_name) {
int spm_do_purge(SPM_Hierarchy *fs, StrList *packages) {
int status_remove = 0;
+ if (spm_hierarchy_is_root(fs) < 0) {
+ spmerrno = SPM_ERR_ROOT_NO_RECORD;
+ return -1;
+ }
+
printf("Removing package(s):\n");
for (size_t i = 0; i < strlist_count(packages); i++) {
char *package = strlist_item(packages, i);