diff options
author | Timo Teras <timo.teras@iki.fi> | 2009-01-13 15:22:14 +0200 |
---|---|---|
committer | Timo Teras <timo.teras@iki.fi> | 2009-01-13 15:22:14 +0200 |
commit | b7f9f9bdb21ffeb50f5814fdcce2f315215fdb1e (patch) | |
tree | a77d7e52c7d61b6601ea6f0021bd529da3e85dbe /src/database.c | |
parent | c831ead63c5fdb4d1e75c264084576cfefe581e6 (diff) | |
download | apk-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.c | 40 |
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); |