Code Cleanup
- Removed unused util.cpp ::execute variant.
This commit is contained in:
56
src/util.cpp
56
src/util.cpp
@@ -393,62 +393,6 @@ void combine (std::vector <int>& dest, const std::vector <int>& source)
|
|||||||
std::sort (dest.begin (), dest.end ());
|
std::sort (dest.begin (), dest.end ());
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Run an external executable with execvp. This means stdio goes to
|
|
||||||
// the child process, so that it can receive user input (e.g. passwords).
|
|
||||||
//
|
|
||||||
int execute (const std::string& executable, const std::vector<std::string>& arguments)
|
|
||||||
{
|
|
||||||
if (executable == "")
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
// create command line before forking because the parent process also needs this for
|
|
||||||
// calling context.debug ()
|
|
||||||
char shell [] = "sh";
|
|
||||||
char opt [] = "-c";
|
|
||||||
|
|
||||||
std::string cmdline = executable;
|
|
||||||
|
|
||||||
std::vector <std::string>::const_iterator it;
|
|
||||||
for (it = arguments.begin (); it != arguments.end (); ++it)
|
|
||||||
cmdline += " " + (std::string) *it;
|
|
||||||
|
|
||||||
context.debug ("Executing: " + std::string (shell) + " " + std::string (opt) + " " + cmdline);
|
|
||||||
|
|
||||||
pid_t child_pid = fork ();
|
|
||||||
|
|
||||||
if (child_pid == 0)
|
|
||||||
{
|
|
||||||
// this is done by the child process
|
|
||||||
char** argv = new char*[4];
|
|
||||||
argv[0] = shell; // sh
|
|
||||||
argv[1] = opt; // -c
|
|
||||||
argv[2] = (char*) cmdline.c_str (); // e.g. scp undo.data user@host:.task/
|
|
||||||
argv[3] = NULL; // required by execv
|
|
||||||
|
|
||||||
int ret = execvp (shell, argv);
|
|
||||||
delete[] argv;
|
|
||||||
|
|
||||||
exit (ret);
|
|
||||||
}
|
|
||||||
else if (child_pid == -1)
|
|
||||||
{
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// this is done by the parent process
|
|
||||||
int child_status;
|
|
||||||
|
|
||||||
pid_t pid = waitpid (child_pid, &child_status, 0);
|
|
||||||
|
|
||||||
if (pid == -1)
|
|
||||||
return -1;
|
|
||||||
else
|
|
||||||
return WEXITSTATUS (child_status);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// Run a binary with args, capturing output.
|
// Run a binary with args, capturing output.
|
||||||
int execute (
|
int execute (
|
||||||
|
|||||||
@@ -52,7 +52,6 @@ void uuid_unparse_lower (uuid_t uu, char *out);
|
|||||||
#endif
|
#endif
|
||||||
const std::string uuid ();
|
const std::string uuid ();
|
||||||
|
|
||||||
int execute (const std::string&, const std::vector <std::string>&);
|
|
||||||
int execute (const std::string&, const std::vector <std::string>&, const std::string&, std::string&);
|
int execute (const std::string&, const std::vector <std::string>&, const std::string&, std::string&);
|
||||||
|
|
||||||
#ifdef SOLARIS
|
#ifdef SOLARIS
|
||||||
|
|||||||
Reference in New Issue
Block a user