From 45fc07260c8a9f1fb0d88669a508d5cd8825e256 Mon Sep 17 00:00:00 2001 From: Duncaen Date: Fri, 14 Jun 2019 23:19:59 +0200 Subject: [PATCH] xbps_binpkg_exists: fix access() on remote packages and avoid malloc --- lib/util.c | 26 ++++++++++++++++++-------- 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/lib/util.c b/lib/util.c index b1d754ee..4777f8e2 100644 --- a/lib/util.c +++ b/lib/util.c @@ -328,17 +328,27 @@ xbps_repository_pkg_path(struct xbps_handle *xhp, xbps_dictionary_t pkg_repod) bool xbps_binpkg_exists(struct xbps_handle *xhp, xbps_dictionary_t pkgd) { - char *binpkg; - bool exists = true; + char path[PATH_MAX]; + const char *pkgver, *arch, *repoloc; - if ((binpkg = xbps_repository_pkg_path(xhp, pkgd)) == NULL) - return false; + assert(xhp); + assert(xbps_object_type(pkgd) == XBPS_TYPE_DICTIONARY); - if (access(binpkg, R_OK) == -1) - exists = false; + if (!xbps_dictionary_get_cstring_nocopy(pkgd, + "pkgver", &pkgver)) + return NULL; + if (!xbps_dictionary_get_cstring_nocopy(pkgd, + "architecture", &arch)) + return NULL; + if (!xbps_dictionary_get_cstring_nocopy(pkgd, + "repository", &repoloc)) + return NULL; - free(binpkg); - return exists; + snprintf(path, sizeof(path), "%s/%s.%s.xbps", + xbps_repository_is_remote(repoloc) ? xhp->cachedir : repoloc, + pkgver, arch); + + return access(path, R_OK) == 0; } bool