summaryrefslogtreecommitdiff
path: root/src/database.c
diff options
context:
space:
mode:
authorTimo Teras <timo.teras@iki.fi>2009-01-13 15:22:14 +0200
committerTimo Teras <timo.teras@iki.fi>2009-01-13 15:22:14 +0200
commitb7f9f9bdb21ffeb50f5814fdcce2f315215fdb1e (patch)
treea77d7e52c7d61b6601ea6f0021bd529da3e85dbe /src/database.c
parentc831ead63c5fdb4d1e75c264084576cfefe581e6 (diff)
downloadapk-tools-b7f9f9bdb21ffeb50f5814fdcce2f315215fdb1e.tar.gz
apk-tools-b7f9f9bdb21ffeb50f5814fdcce2f315215fdb1e.tar.bz2
apk-tools-b7f9f9bdb21ffeb50f5814fdcce2f315215fdb1e.tar.xz
apk-tools-b7f9f9bdb21ffeb50f5814fdcce2f315215fdb1e.zip
info: implement who owns packages query (apk_info -W)
In quiet mode e.g. "apk info -q -W <file list>" a list of dependencies suitable for .PKGINFO is output in one line.
Diffstat (limited to 'src/database.c')
-rw-r--r--src/database.c40
1 files changed, 37 insertions, 3 deletions
diff --git a/src/database.c b/src/database.c
index 373acb6..3f67d4e 100644
--- a/src/database.c
+++ b/src/database.c
@@ -135,6 +135,12 @@ static struct apk_db_dir *apk_db_dir_get(struct apk_db_dir *dir)
return dir;
}
+static struct apk_db_dir *apk_db_dir_query(struct apk_database *db,
+ apk_blob_t name)
+{
+ return (struct apk_db_dir *) apk_hash_get(&db->installed.dirs, name);
+}
+
static struct apk_db_dir *apk_db_dir_get_db(struct apk_database *db,
apk_blob_t name)
{
@@ -145,7 +151,7 @@ static struct apk_db_dir *apk_db_dir_get_db(struct apk_database *db,
if (name.len && name.ptr[name.len-1] == '/')
name.len--;
- dir = (struct apk_db_dir *) apk_hash_get(&db->installed.dirs, name);
+ dir = apk_db_dir_query(db, name);
if (dir != NULL)
return apk_db_dir_get(dir);
@@ -643,6 +649,8 @@ static int apk_db_write_config(struct apk_database *db)
if (os == NULL)
return -1;
n = apk_deps_format(buf, sizeof(buf), db->world);
+ if (n < sizeof(buf))
+ buf[n++] = '\n';
os->write(os, buf, n);
os->close(os);
@@ -677,7 +685,6 @@ void apk_db_close(struct apk_database *db)
}
}
-
for (i = 0; i < db->num_repos; i++)
free(db->repos[i].url);
for (i = 0; i < db->protected_paths->num; i++)
@@ -700,6 +707,33 @@ struct apk_package *apk_db_get_pkg(struct apk_database *db, csum_t sum)
APK_BLOB_PTR_LEN((void*) sum, sizeof(csum_t)));
}
+struct apk_package *apk_db_get_file_owner(struct apk_database *db,
+ apk_blob_t filename)
+{
+ apk_blob_t dir, file;
+ struct apk_db_dir *ddir;
+ struct apk_db_file *dfile;
+ struct hlist_node *cur;
+
+ if (!apk_blob_rsplit(filename, '/', &dir, &file))
+ return NULL;
+
+ if (dir.ptr[0] == '/')
+ dir.ptr++, dir.len--;
+
+ ddir = apk_db_dir_query(db, dir);
+ if (ddir == NULL)
+ return NULL;
+
+ hlist_for_each_entry(dfile, cur, &ddir->files, dir_files_list) {
+ if (strncmp(dfile->filename, file.ptr, file.len) == 0 &&
+ dfile->filename[file.len] == 0)
+ return dfile->diri->pkg;
+ }
+
+ return NULL;
+}
+
struct apk_package *apk_db_pkg_add_file(struct apk_database *db, const char *file)
{
struct apk_package *info;
@@ -901,7 +935,7 @@ static int apk_db_install_archive_entry(void *_ctx,
ctx->diri = diri;
}
- file = apk_db_file_get(db, name, ctx);
+ file = apk_db_file_get(db, bfile, ctx);
if (file == NULL) {
apk_error("%s: Failed to create fdb entry for '%*s'\n",
pkg->name->name, name.len, name.ptr);