Send patches - preferably formatted by git format-patch - to patches at archlinux32 dot org.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAurelien Foret <aurelien@archlinux.org>2005-03-29 22:19:11 +0000
committerAurelien Foret <aurelien@archlinux.org>2005-03-29 22:19:11 +0000
commitb009c5bafa63581a0c590a8c1a1d8dafd5e7654a (patch)
treecb143e0ebc9b75a2b6bcf399c299bdb307f78d42
parent73c6779067548fdbecd1627669c3cd93cc10d995 (diff)
checked for db_update() archive existence
-rw-r--r--lib/libalpm/alpm.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/libalpm/alpm.c b/lib/libalpm/alpm.c
index 9789f467..c8c8f3e1 100644
--- a/lib/libalpm/alpm.c
+++ b/lib/libalpm/alpm.c
@@ -222,6 +222,8 @@ int alpm_db_getlastupdate(PM_DB *db, char *ts)
int alpm_db_update(PM_DB *db, char *archive, char *ts)
{
+ struct stat buf;
+
/* Sanity checks */
ASSERT(handle != NULL, RET_ERR(PM_ERR_HANDLE_NULL, -1));
ASSERT(db != NULL && db != handle->db_local, RET_ERR(PM_ERR_WRONG_ARGS, -1));
@@ -239,8 +241,10 @@ int alpm_db_update(PM_DB *db, char *archive, char *ts)
}
}
- /* ORE
- stat() the archive to check it exists */
+ if(stat(archive, &buf)) {
+ /* not found */
+ RET_ERR(PM_ERR_NOT_A_FILE, -1);
+ }
/* Cache needs to be rebuild */
db_free_pkgcache(db);