summaryrefslogtreecommitdiff
path: root/src/apk_adb.c
diff options
context:
space:
mode:
authorTimo Teräs <timo.teras@iki.fi>2022-03-21 12:48:16 +0200
committerTimo Teräs <timo.teras@iki.fi>2022-03-21 14:09:06 +0200
commitc6b9297bcb1c9d5ff11fceb0a453ec4daa1ee6dd (patch)
treeb9fd2078b4eccc384f2fe06e5fab9f0e35be5e5e /src/apk_adb.c
parent950972a56b6c9ba6e33b33e60cab076f5a18daec (diff)
downloadapk-tools-c6b9297bcb1c9d5ff11fceb0a453ec4daa1ee6dd.tar.gz
apk-tools-c6b9297bcb1c9d5ff11fceb0a453ec4daa1ee6dd.tar.bz2
apk-tools-c6b9297bcb1c9d5ff11fceb0a453ec4daa1ee6dd.tar.xz
apk-tools-c6b9297bcb1c9d5ff11fceb0a453ec4daa1ee6dd.zip
mkndx, adb: fix index searching
Additioal logic is needed to search objects on array: the object comparer needs separate modes to match index, template or exact object template. This should fix mkndx to be able to use old index. fixes #10828
Diffstat (limited to 'src/apk_adb.c')
-rw-r--r--src/apk_adb.c35
1 files changed, 5 insertions, 30 deletions
diff --git a/src/apk_adb.c b/src/apk_adb.c
index 25508c1..febe359 100644
--- a/src/apk_adb.c
+++ b/src/apk_adb.c
@@ -341,17 +341,12 @@ fail:
return -APKE_DEPENDENCY_FORMAT;
}
-static int dependency_cmp(const struct adb_obj *o1, const struct adb_obj *o2)
-{
- return adb_ro_cmp(o1, o2, ADBI_DEP_NAME);
-}
-
const struct adb_object_schema schema_dependency = {
.kind = ADB_KIND_OBJECT,
.num_fields = ADBI_DEP_MAX,
+ .num_compare = ADBI_DEP_NAME,
.tostring = dependency_tostring,
.fromstring = dependency_fromstring,
- .compare = dependency_cmp,
.fields = {
ADB_FIELD(ADBI_DEP_NAME, "name", scalar_string),
ADB_FIELD(ADBI_DEP_VERSION, "version", scalar_version),
@@ -383,20 +378,10 @@ const struct adb_object_schema schema_dependency_array = {
.fields = ADB_ARRAY_ITEM(schema_dependency),
};
-static int pkginfo_cmp(const struct adb_obj *o1, const struct adb_obj *o2)
-{
- int r;
- r = adb_ro_cmp(o1, o2, ADBI_PI_NAME);
- if (r) return r;
- r = adb_ro_cmp(o1, o2, ADBI_PI_VERSION);
- if (r) return r;
- return adb_ro_cmp(o1, o2, ADBI_PI_UNIQUE_ID);
-}
-
const struct adb_object_schema schema_pkginfo = {
.kind = ADB_KIND_OBJECT,
.num_fields = ADBI_PI_MAX,
- .compare = pkginfo_cmp,
+ .num_compare = ADBI_PI_UNIQUE_ID,
.fields = {
ADB_FIELD(ADBI_PI_NAME, "name", scalar_string),
ADB_FIELD(ADBI_PI_VERSION, "version", scalar_version),
@@ -448,15 +433,10 @@ const struct adb_object_schema schema_acl = {
},
};
-static int file_cmp(const struct adb_obj *o1, const struct adb_obj *o2)
-{
- return adb_ro_cmp(o1, o2, ADBI_FI_NAME);
-}
-
const struct adb_object_schema schema_file = {
.kind = ADB_KIND_OBJECT,
.num_fields = ADBI_FI_MAX,
- .compare = file_cmp,
+ .num_compare = ADBI_FI_NAME,
.fields = {
ADB_FIELD(ADBI_FI_NAME, "name", scalar_string),
ADB_FIELD(ADBI_FI_ACL, "acl", schema_acl),
@@ -477,7 +457,7 @@ const struct adb_object_schema schema_file_array = {
const struct adb_object_schema schema_dir = {
.kind = ADB_KIND_OBJECT,
.num_fields = ADBI_DI_MAX,
- .compare = file_cmp,
+ .num_compare = ADBI_DI_NAME,
.fields = {
ADB_FIELD(ADBI_DI_NAME, "name", scalar_string),
ADB_FIELD(ADBI_DI_ACL, "acl", schema_acl),
@@ -506,15 +486,10 @@ const struct adb_object_schema schema_scripts = {
},
};
-static int package_cmp(const struct adb_obj *o1, const struct adb_obj *o2)
-{
- return adb_ro_cmp(o1, o2, ADBI_PKG_PKGINFO);
-}
-
const struct adb_object_schema schema_package = {
.kind = ADB_KIND_OBJECT,
.num_fields = ADBI_PKG_MAX,
- .compare = package_cmp,
+ .num_compare = ADBI_PKG_PKGINFO,
.fields = {
ADB_FIELD(ADBI_PKG_PKGINFO, "info", schema_pkginfo),
ADB_FIELD(ADBI_PKG_PATHS, "paths", schema_dir_array),