From 390ff275c538f70d03277932b6b0a83ffedb6d1a Mon Sep 17 00:00:00 2001 From: William Pitcock Date: Wed, 8 Aug 2012 11:15:13 -0500 Subject: [PATCH] pkg: ensure libs.private merging is always after libs --- pkg.c | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/pkg.c b/pkg.c index 543bedb..6d3f270 100644 --- a/pkg.c +++ b/pkg.c @@ -860,15 +860,21 @@ pkg_libs_collect(pkg_t *pkg, void *data, unsigned int flags) { pkg_fragment_t **list = data; pkg_fragment_t *frag; + (void) flags; PKG_FOREACH_LIST_ENTRY(pkg->libs, frag) *list = pkg_fragment_copy(*list, frag); +} - if (flags & PKGF_MERGE_PRIVATE_FRAGMENTS) - { - PKG_FOREACH_LIST_ENTRY(pkg->libs_private, frag) - *list = pkg_fragment_copy(*list, frag); - } +static void +pkg_libs_private_collect(pkg_t *pkg, void *data, unsigned int flags) +{ + pkg_fragment_t **list = data; + pkg_fragment_t *frag; + (void) flags; + + PKG_FOREACH_LIST_ENTRY(pkg->libs_private, frag) + *list = pkg_fragment_copy(*list, frag); } pkg_fragment_t * @@ -876,5 +882,8 @@ pkg_libs(pkg_t *root, pkg_fragment_t **list, int maxdepth, unsigned int flags) { pkg_traverse(root, pkg_libs_collect, list, maxdepth, flags); + if (flags & PKGF_MERGE_PRIVATE_FRAGMENTS) + pkg_traverse(root, pkg_libs_private_collect, list, maxdepth, flags); + return *list; }