diff options
| author | Robert Schumacher <roschuma@microsoft.com> | 2016-09-30 17:09:23 -0700 |
|---|---|---|
| committer | Robert Schumacher <roschuma@microsoft.com> | 2016-09-30 17:09:23 -0700 |
| commit | 98b4a67fe1af6974f146b518c0f1644de290d8da (patch) | |
| tree | 015bea935501b3ae80c635b06da83e9591d9166c /toolsrc/src/vcpkg_Input.cpp | |
| parent | 241ca8cd17929d53a5c10c4f366f6972d865ba4f (diff) | |
| parent | 188eac680ba930c51943d4af34de58bbd325dcb1 (diff) | |
| download | vcpkg-98b4a67fe1af6974f146b518c0f1644de290d8da.tar.gz vcpkg-98b4a67fe1af6974f146b518c0f1644de290d8da.zip | |
Merge branch 'master' of https://github.com/microsoft/vcpkg
Diffstat (limited to 'toolsrc/src/vcpkg_Input.cpp')
| -rw-r--r-- | toolsrc/src/vcpkg_Input.cpp | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/toolsrc/src/vcpkg_Input.cpp b/toolsrc/src/vcpkg_Input.cpp new file mode 100644 index 000000000..269de13b3 --- /dev/null +++ b/toolsrc/src/vcpkg_Input.cpp @@ -0,0 +1,50 @@ +#include "vcpkg_Input.h" +#include "vcpkg_System.h" +#include "metrics.h" +#include "vcpkg_Commands.h" + +namespace vcpkg {namespace Input +{ + package_spec check_and_get_package_spec(const std::string& package_spec_as_string, const triplet& default_target_triplet, const char* example_text) + { + expected<package_spec> expected_spec = package_spec::from_string(package_spec_as_string, default_target_triplet); + if (auto spec = expected_spec.get()) + { + return *spec; + } + + System::println(System::color::error, "Error: %s: %s", expected_spec.error_code().message(), package_spec_as_string); + System::print(example_text); + exit(EXIT_FAILURE); + } + + std::vector<package_spec> check_and_get_package_specs(const std::vector<std::string>& package_specs_as_strings, const triplet& default_target_triplet, const char* example_text) + { + std::vector<package_spec> specs; + for (const std::string& spec : package_specs_as_strings) + { + specs.push_back(check_and_get_package_spec(spec, default_target_triplet, example_text)); + } + + return specs; + } + + void check_triplet(const triplet& t, const vcpkg_paths& paths) + { + if (!paths.is_valid_triplet(t)) + { + System::println(System::color::error, "Error: invalid triplet: %s", t.value); + TrackProperty("error", "invalid triplet: " + t.value); + help_topic_valid_triplet(paths); + exit(EXIT_FAILURE); + } + } + + void check_triplets(std::vector<package_spec> triplets, const vcpkg_paths& paths) + { + for (const package_spec& spec : triplets) + { + check_triplet(spec.target_triplet, paths); + } + } +}} |
