From f26c8c8b60217dea25f3d53e3d613ad11bb98216 Mon Sep 17 00:00:00 2001 From: Alexander Karatarakis Date: Thu, 22 Sep 2016 01:15:09 -0700 Subject: Place import_command() in a separate cpp file --- toolsrc/src/commands_import.cpp | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 toolsrc/src/commands_import.cpp (limited to 'toolsrc/src/commands_import.cpp') diff --git a/toolsrc/src/commands_import.cpp b/toolsrc/src/commands_import.cpp new file mode 100644 index 000000000..b1eae277c --- /dev/null +++ b/toolsrc/src/commands_import.cpp @@ -0,0 +1,30 @@ +#include "vcpkg_Commands.h" +#include "vcpkg.h" +#include "vcpkg_System.h" + +namespace vcpkg +{ + void import_command(const vcpkg_cmd_arguments& args, const vcpkg_paths& paths) + { + if (args.command_arguments.size() != 3) + { + System::println(System::color::error, "Error: %s requires 3 parameters", args.command); + print_example(Strings::format(R"(%s C:\path\to\CONTROLfile C:\path\to\includedir C:\path\to\projectdir)", args.command).c_str()); + exit(EXIT_FAILURE); + } + + const fs::path control_file_path(args.command_arguments[0]); + const fs::path include_directory(args.command_arguments[1]); + const fs::path project_directory(args.command_arguments[2]); + + auto pghs = get_paragraphs(control_file_path); + Checks::check_throw(pghs.size() == 1, "Invalid control file for package"); + + StatusParagraph spgh; + spgh.package = BinaryParagraph(pghs[0]); + auto& control_file_data = spgh.package; + + vcpkg::binary_import(paths, include_directory, project_directory, control_file_data); + exit(EXIT_SUCCESS); + } +} -- cgit v1.2.3