aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src/commands_edit.cpp
diff options
context:
space:
mode:
authorAlexander Karatarakis <alkarata@microsoft.com>2016-09-30 17:36:33 -0700
committerAlexander Karatarakis <alkarata@microsoft.com>2016-09-30 17:36:33 -0700
commit25145714f7e4474c73a230a56910e01960bada6b (patch)
tree8725c5757c2a38f670ec71499d3561672e41f403 /toolsrc/src/commands_edit.cpp
parent188eac680ba930c51943d4af34de58bbd325dcb1 (diff)
downloadvcpkg-25145714f7e4474c73a230a56910e01960bada6b.tar.gz
vcpkg-25145714f7e4474c73a230a56910e01960bada6b.zip
[vcpkg edit] Now throws an error if it cannot launch an editor
Diffstat (limited to 'toolsrc/src/commands_edit.cpp')
-rw-r--r--toolsrc/src/commands_edit.cpp15
1 files changed, 13 insertions, 2 deletions
diff --git a/toolsrc/src/commands_edit.cpp b/toolsrc/src/commands_edit.cpp
index a3e2f402d..2007eac10 100644
--- a/toolsrc/src/commands_edit.cpp
+++ b/toolsrc/src/commands_edit.cpp
@@ -11,12 +11,23 @@ namespace vcpkg
const package_spec spec = Input::check_and_get_package_spec(args.command_arguments.at(0), default_target_triplet, example.c_str());
Input::check_triplet(spec.target_triplet, paths);
+ const fs::path portpath = paths.ports / spec.name;
+
// Find editor
std::wstring env_EDITOR = System::wdupenv_str(L"EDITOR");
if (env_EDITOR.empty())
- env_EDITOR = LR"(C:\Program Files (x86)\Microsoft VS Code\Code.exe)";
+ {
+ static const std::wstring CODE_EXE_PATH = LR"(C:\Program Files (x86)\Microsoft VS Code\Code.exe)";
+ if (fs::exists(CODE_EXE_PATH))
+ {
+ env_EDITOR = CODE_EXE_PATH;
+ }
+ else
+ {
+ Checks::exit_with_message("Visual Studio Code was not found and the environmental variable EDITOR is not set");
+ }
+ }
- const fs::path portpath = paths.ports / spec.name;
std::wstring cmdLine = Strings::wformat(LR"("%s" "%s" "%s")", env_EDITOR, portpath.native(), (portpath / "portfile.cmake").native());
exit(System::cmd_execute(cmdLine));
}