Už som jeden napísalCMD echo je implementované pomocou anonymných pipelineTeraz sa zdá, že kód vtedy bol naozaj slabý, a nahnevane som ho prepísal.
[mw_shl_code=c,true]void ExecuteCommand(WCHAR * pszCommand, WCHAR *pszResult, DWORD dwCount)
{ BOOL bRet = NEPRAVDA; USES_CONVERSION;
WCHAR szCmdPath[MAX_PATH] = {0}; GetSystemDirectory(szCmdPath, sizeof(szCmdPath)); PathAppend(szCmdPath, L"cmd.exe");
SECURITY_ATTRIBUTES SecurityAttributes; SecurityAttributes.nLength = sizeof(SECURITY_ATTRIBUTES); SecurityAttributes.lpSecurityDescrip{filter}tor = NULL; SecurityAttributes.bInheritHandle = PRAVDA;
HANDLE hRead = NULL; HANDLE hWrite = NULL;
if(CreatePipe(&hRead, &hWrite, &SecurityAttributes, 0))
{ STARTUPINFO StartupInfo = {0}; StartupInfo.dwFlags = STARTF_USESTDHANDLES | STARTF_USESHOWWINDOW; StartupInfo.hStdOutput = hWrite; StartupInfo.hStdError = hWrite; StartupInfo.wShowWindow = SW_HIDE;
PROCESS_INFORMATION ProcessInformation = {0};
WCHAR szCurrentPath[MAX_PATH] = {0}; GetCurrentDirectory(sizeof(szCurrentPath), szCurrentPath);
if(CreateProcess(szCmdPath, pszCommand, NULL, NULL, TRUE, 0, NULL, szCurrentPath, &StartupInfo, &ProcessInformation))
{ CloseHandle(hWrite);
char szBuffer[4096] = {0}; DWORD dwRead = 0; if(pszResult)
{ pszResult[0] = 0; zatiaľ čo (PRAVDA)
{ memset(szBuffer, 0, sizeof(szBuffer)); bRet = ReadFile(hRead, szBuffer, sizeof(szBuffer), &dwRead, NULL); if((FALSE == bRet) || (dwRead = 0)) prestávka;
wcscat_s(pszResult, dwCount, A2W(szBuffer));
}
}
}
CloseHandle(hRead);
} }[/mw_shl_code]
|