C++/CLI Code Snippet - Execute Shell Commands from .Net
C++/CLI code snippet creates a command process and then invokes the command that we want to execute. The result of the command and any errors occurred during execution is stored in a string variables. This is a great method to execute your DOS commands from .Net.
Bookmark:
C++/CLI Code Snippet - Execute Shell Commands from .Net
This .Net C++/CLI code snippet executes a shell command. To use this function simply provide the file/command to execute, command line parameters (optional), string variable to store output and string variable to store errors occurred during execution.
The code creates a command process and then invokes the command that we want to execute. The result of the command and any errors occurred during execution is stored in a string variables, which can then be used for further reference. This is a great method to execute your DOS commands from .Net.
/// <summary>
/// Execute a shell command
/// </summary>
/// <param name="_FileToExecute">File/Command to execute</param>
/// <param name="_CommandLine">Command line parameters to pass</param>
/// <param name="_outputMessage">returned string value after executing shell command</param>
/// <param name="_errorMessage">Error messages generated during shell execution</param>
void ExecuteShellCommand(System::String ^_FileToExecute, System::String ^_CommandLine, System::String ^%_outputMessage, System::String ^%_errorMessage)
{
// Set process variable
// Provides access to local and remote processes and enables you to start and stop local system processes.
System::Diagnostics::Process ^_Process = nullptr;
try
{
_Process = gcnew System::Diagnostics::Process();
// invokes the cmd process specifying the command to be executed.
System::String ^_CMDProcess = System::String::Format(System::Globalization::CultureInfo::InvariantCulture, "{0}\\cmd.exe", gcnew array<System::Object^> { Environment::SystemDirectory });
// pass executing file to cmd (Windows command interpreter) as a arguments
// /C tells cmd that we want it to execute the command that follows, and then exit.
System::String ^_Arguments = System::String::Format(System::Globalization::CultureInfo::InvariantCulture, "/C {0}", gcnew array<System::Object^> { _FileToExecute });
// pass any command line parameters for execution
if (_CommandLine != nullptr && _CommandLine->Length > 0)
{
_Arguments += System::String::Format(System::Globalization::CultureInfo::InvariantCulture, " {0}", gcnew array<System::Object^> { _CommandLine, System::Globalization::CultureInfo::InvariantCulture });
}
// Specifies a set of values used when starting a process.
System::Diagnostics::ProcessStartInfo ^_ProcessStartInfo = gcnew System::Diagnostics::ProcessStartInfo(_CMDProcess, _Arguments);
// sets a value indicating not to start the process in a new window.
_ProcessStartInfo->CreateNoWindow = true;
// sets a value indicating not to use the operating system shell to start the process.
_ProcessStartInfo->UseShellExecute = false;
// sets a value that indicates the output/input/error of an application is written to the Process.
_ProcessStartInfo->RedirectStandardOutput = true;
_ProcessStartInfo->RedirectStandardInput = true;
_ProcessStartInfo->RedirectStandardError = true;
_Process->StartInfo = _ProcessStartInfo;
// Starts a process resource and associates it with a Process component.
_Process->Start();
// Instructs the Process component to wait indefinitely for the associated process to exit.
_errorMessage = _Process->StandardError->ReadToEnd();
_Process->WaitForExit();
// Instructs the Process component to wait indefinitely for the associated process to exit.
_outputMessage = _Process->StandardOutput->ReadToEnd();
_Process->WaitForExit();
}
catch (Win32Exception ^_Win32Exception)
{
// Error
Console::WriteLine("Win32 Exception caught in process: {0}", _Win32Exception->ToString());
}
catch (Exception ^_Exception)
{
// Error
Console::WriteLine("Exception caught in process: {0}", _Exception->ToString());
}
finally
{
// close process and do cleanup
_Process->Close();
delete _Process;
_Process = nullptr;
}
}
Here is a simple example showing how to use above function (ExecuteShellCommand) to execute a simple DOS dir command and show output result in a richtextbox.
System::String ^_Output = nullptr;
System::String ^_Error = nullptr;
ExecuteShellCommand("dir", "c:\\", _Output, _Error);
richTextBox1->Text = _Output;
This example shows how to use above method to execute DOS del command to delete all the ZIP files in c:\temp folder using .Net.
/F - Force deleting of read-only files.
/Q - Quiet mode, do not ask if ok to delete on global wildcard.
System::String ^_Output = nullptr;
System::String ^_Error = nullptr;
ExecuteShellCommand("del", "/F /Q c:\\temp\\*.zip", _Output, _Error);
C++/CLI Keywords Used:
- Process
- Format
- ProcessStartInfo
- Environment
- SystemDirectory
- InvariantCulture
- Win32Exception
- Exception
Code Snippet Information:
- Applies To: .Net, C++, CLI, Shell Execute from .Net, DOS, System Processes, Execute DOS Commands from .Net, Redirect Standard Output, Windows command interpreter
- Programming Language : C++/CLI
External Resources: