From 724a69a8d554151f3d1ec4bed03c6c4ab6f11eed Mon Sep 17 00:00:00 2001 From: Colin Fletcher Date: Tue, 27 May 2014 10:21:34 +0100 Subject: [PATCH] Search $PATH for command when creating SystemExec from command line When creating a SystemExec from a command-line, search $PATH for the command to execute, so that post-export hooks don't need to specify a full path. --- libs/pbd/system_exec.cc | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/libs/pbd/system_exec.cc b/libs/pbd/system_exec.cc index 7e94880f85..a5dd20afac 100644 --- a/libs/pbd/system_exec.cc +++ b/libs/pbd/system_exec.cc @@ -43,9 +43,12 @@ #include #endif +#include #define USE_VFORK +#include "pbd/file_utils.h" +#include "pbd/search_path.h" #include "pbd/system_exec.h" using namespace std; @@ -192,8 +195,14 @@ SystemExec::SystemExec (std::string command, const std::map s { init (); make_argp_escaped(command, subs); - cmd = argp[0]; - // cmd = strdup(argp[0]); + if (!find_file_in_search_path (Searchpath (Glib::getenv ("PATH")), argp[0], cmd)) { + // not found in path - use as-is + cmd = argp[0]; + } + + // Glib::find_program_in_path () is only available in Glib >= 2.28 + // cmd = Glib::find_program_in_path (argp[0]); + make_envp(); }