aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src/commands_search.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'toolsrc/src/commands_search.cpp')
-rw-r--r--toolsrc/src/commands_search.cpp62
1 files changed, 41 insertions, 21 deletions
diff --git a/toolsrc/src/commands_search.cpp b/toolsrc/src/commands_search.cpp
index a4714477e..8bac858f1 100644
--- a/toolsrc/src/commands_search.cpp
+++ b/toolsrc/src/commands_search.cpp
@@ -1,35 +1,47 @@
+#include "pch.h"
#include "vcpkg_Commands.h"
#include "vcpkg_System.h"
#include "Paragraphs.h"
#include "vcpkglib_helpers.h"
#include "SourceParagraph.h"
-namespace vcpkg
+namespace vcpkg::Commands::Search
{
- static std::vector<SourceParagraph> read_all_source_paragraphs(const vcpkg_paths& paths)
+ static const std::string OPTION_GRAPH = "--graph"; //TODO: This should find a better home, eventually
+
+ static std::string replace_dashes_with_underscore(const std::string& input)
{
- std::vector<SourceParagraph> output;
- for (auto it = fs::directory_iterator(paths.ports); it != fs::directory_iterator(); ++it)
- {
- const fs::path& path = it->path();
+ std::string output = input;
+ std::replace(output.begin(), output.end(), '-', '_');
+ return output;
+ }
- try
- {
- auto pghs = Paragraphs::get_paragraphs(path / "CONTROL");
- if (pghs.empty())
- {
- continue;
- }
+ static std::string create_graph_as_string(const std::vector<SourceParagraph>& source_paragraphs)
+ {
+ int empty_node_count = 0;
+
+ std::string s;
+ s.append("digraph G{ rankdir=LR; edge [minlen=3]; overlap=false;");
- auto srcpgh = SourceParagraph(pghs[0]);
- output.push_back(srcpgh);
+ for (const SourceParagraph& source_paragraph : source_paragraphs)
+ {
+ if (source_paragraph.depends.empty())
+ {
+ empty_node_count++;
+ continue;
}
- catch (std::runtime_error const&)
+
+ const std::string name = replace_dashes_with_underscore(source_paragraph.name);
+ s.append(Strings::format("%s;", name));
+ for (const dependency& d : source_paragraph.depends)
{
+ const std::string dependency_name = replace_dashes_with_underscore(d.name);
+ s.append(Strings::format("%s -> %s;", name, dependency_name));
}
}
- return output;
+ s.append(Strings::format("empty [label=\"%d singletons...\"]; }", empty_node_count));
+ return s;
}
static void do_print(const SourceParagraph& source_paragraph)
@@ -40,14 +52,22 @@ namespace vcpkg
details::shorten_description(source_paragraph.description));
}
- void search_command(const vcpkg_cmd_arguments& args, const vcpkg_paths& paths)
+ void perform_and_exit(const vcpkg_cmd_arguments& args, const vcpkg_paths& paths)
{
- static const std::string example = Strings::format("The argument should be a substring to search for, or no argument to display all libraries.\n%s", create_example_string("search png"));
+ static const std::string example = Strings::format("The argument should be a substring to search for, or no argument to display all libraries.\n%s",
+ Commands::Help::create_example_string("search png"));
args.check_max_arg_count(1, example);
+ const std::unordered_set<std::string> options = args.check_and_get_optional_command_arguments({ OPTION_GRAPH });
- const std::vector<SourceParagraph> source_paragraphs = read_all_source_paragraphs(paths);
+ const std::vector<SourceParagraph> source_paragraphs = Paragraphs::load_all_ports(paths.ports);
+ if (options.find(OPTION_GRAPH) != options.cend())
+ {
+ const std::string graph_as_string = create_graph_as_string(source_paragraphs);
+ System::println(graph_as_string);
+ exit(EXIT_SUCCESS);
+ }
- if (args.command_arguments.size() == 0)
+ if (args.command_arguments.empty())
{
for (const SourceParagraph& source_paragraph : source_paragraphs)
{