summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Macek <david.macek.0@gmail.com>2015-11-29 14:55:15 +0100
committerAllan McRae <allan@archlinux.org>2015-12-06 00:22:40 +1000
commit71f9de64c6eaf11e22551de56d4e9233dddfe238 (patch)
tree8d0080328b097f2dfd244c5f9d0cde2b2e03c6c1
parent8ee084dbb33a9a9fee77376f5fac07f331a24ef8 (diff)
downloadpacman-71f9de64c6eaf11e22551de56d4e9233dddfe238.tar.xz
alpm_initialize: Fix double slash in sys hook dir path
The path of the default system hook directory was created by concatenating `myhandle->root` (usually "/"), and SYSHOOKDIR (usually "/usr/share/libalpm/hooks/"), resulting in "//usr/share/libalpm/hooks/". Fix this by skipping the initial slash from SYSHOOKDIR. Signed-off-by: Allan McRae <allan@archlinux.org>
-rw-r--r--lib/libalpm/alpm.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/lib/libalpm/alpm.c b/lib/libalpm/alpm.c
index 0798c0bc..54dfade2 100644
--- a/lib/libalpm/alpm.c
+++ b/lib/libalpm/alpm.c
@@ -65,8 +65,11 @@ alpm_handle_t SYMEXPORT *alpm_initialize(const char *root, const char *dbpath,
goto cleanup;
}
- MALLOC(hookdir, strlen(myhandle->root) + strlen(SYSHOOKDIR) + 1, goto cleanup);
- sprintf(hookdir, "%s%s", myhandle->root, SYSHOOKDIR);
+ /* to contatenate myhandle->root (ends with a slash) with SYSHOOKDIR (starts
+ * with a slash) correctly, we skip SYSHOOKDIR[0]; the regular +1 therefore
+ * disappears from the allocation */
+ MALLOC(hookdir, strlen(myhandle->root) + strlen(SYSHOOKDIR), goto cleanup);
+ sprintf(hookdir, "%s%s", myhandle->root, SYSHOOKDIR + 1);
myhandle->hookdirs = alpm_list_add(NULL, hookdir);
/* set default database extension */