diff options
author | Timo Teräs <timo.teras@iki.fi> | 2015-11-09 10:03:31 +0200 |
---|---|---|
committer | Timo Teräs <timo.teras@iki.fi> | 2015-11-09 10:06:57 +0200 |
commit | 7501f6012fc06ebfa8c6d8f928f38318267abe72 (patch) | |
tree | 8bbf351ff170230fbdcc0ed16088b2b0b2c7aa6e /src | |
parent | 707b51e0c615c0cb488468e4461c778c4d113e5e (diff) | |
download | apk-tools-7501f6012fc06ebfa8c6d8f928f38318267abe72.tar.gz apk-tools-7501f6012fc06ebfa8c6d8f928f38318267abe72.tar.bz2 apk-tools-7501f6012fc06ebfa8c6d8f928f38318267abe72.tar.xz apk-tools-7501f6012fc06ebfa8c6d8f928f38318267abe72.zip |
search: match packages only once
fixes #4770
apk_name_foreach_matching() can matches each package via it's
main name and all it's provides. Print matched packages only once.
Diffstat (limited to 'src')
-rw-r--r-- | src/search.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/search.c b/src/search.c index 2e47070..62ca816 100644 --- a/src/search.c +++ b/src/search.c @@ -29,8 +29,16 @@ struct search_ctx { struct apk_string_array *filter; }; +static int unique_match(struct apk_package *pkg) +{ + if (pkg->state_int) return 0; + pkg->state_int = 1; + return 1; +} + static void print_package_name(struct search_ctx *ctx, struct apk_package *pkg) { + if (!unique_match(pkg)) return; printf("%s", pkg->name->name); if (apk_verbosity > 0) printf("-" BLOB_FMT, BLOB_PRINTF(*pkg->version)); @@ -41,6 +49,7 @@ static void print_package_name(struct search_ctx *ctx, struct apk_package *pkg) static void print_origin_name(struct search_ctx *ctx, struct apk_package *pkg) { + if (!unique_match(pkg)) return; if (pkg->origin != NULL) printf(BLOB_FMT, BLOB_PRINTF(*pkg->origin)); else |