aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src/commands_list.cpp
diff options
context:
space:
mode:
authorAlexander Karatarakis <alkarata@microsoft.com>2017-03-29 16:00:41 -0700
committerAlexander Karatarakis <alkarata@microsoft.com>2017-03-31 16:15:05 -0700
commitf1d4a4457ece7067bff16479b6e86d06770d3095 (patch)
treee8d10403053b5aed8a34d80867c37d06207a4a44 /toolsrc/src/commands_list.cpp
parentb3773070fee854ad7a9ea93b8f65b09239947f36 (diff)
downloadvcpkg-f1d4a4457ece7067bff16479b6e86d06770d3095.tar.gz
vcpkg-f1d4a4457ece7067bff16479b6e86d06770d3095.zip
Introduce get_installed_ports()
Diffstat (limited to 'toolsrc/src/commands_list.cpp')
-rw-r--r--toolsrc/src/commands_list.cpp22
1 files changed, 8 insertions, 14 deletions
diff --git a/toolsrc/src/commands_list.cpp b/toolsrc/src/commands_list.cpp
index cee95767b..f7b6bd778 100644
--- a/toolsrc/src/commands_list.cpp
+++ b/toolsrc/src/commands_list.cpp
@@ -22,13 +22,7 @@ namespace vcpkg::Commands::List
args.check_and_get_optional_command_arguments({});
const StatusParagraphs status_paragraphs = database_load_check(paths);
- std::vector<StatusParagraph> installed_packages;
- for (auto&& pgh : status_paragraphs)
- {
- if (pgh->state == install_state_t::not_installed && pgh->want == want_t::purge)
- continue;
- installed_packages.push_back(*pgh);
- }
+ std::vector<StatusParagraph*> installed_packages = get_installed_ports(status_paragraphs);
if (installed_packages.empty())
{
@@ -37,30 +31,30 @@ namespace vcpkg::Commands::List
}
std::sort(installed_packages.begin(), installed_packages.end(),
- [ ]( const StatusParagraph& lhs, const StatusParagraph& rhs ) -> bool
+ [ ]( const StatusParagraph* lhs, const StatusParagraph* rhs ) -> bool
{
- return lhs.package.displayname() < rhs.package.displayname();
+ return lhs->package.displayname() < rhs->package.displayname();
});
if (args.command_arguments.size() == 0)
{
- for (const StatusParagraph& status_paragraph : installed_packages)
+ for (const StatusParagraph* status_paragraph : installed_packages)
{
- do_print(status_paragraph);
+ do_print(*status_paragraph);
}
}
else
{
// At this point there is 1 argument
- for (const StatusParagraph& status_paragraph : installed_packages)
+ for (const StatusParagraph* status_paragraph : installed_packages)
{
- const std::string displayname = status_paragraph.package.displayname();
+ const std::string displayname = status_paragraph->package.displayname();
if (Strings::case_insensitive_ascii_find(displayname, args.command_arguments[0]) == displayname.end())
{
continue;
}
- do_print(status_paragraph);
+ do_print(*status_paragraph);
}
}