Już wcześniej pisałem takiEcho CMD jest implementowane za pomocą anonimowych potokówTeraz wydaje się, że kod z tamtego czasu był naprawdę słaby i ze złością go przepisałem.
[mw_shl_code=c,true]void WykonajCommand(WCHAR * pszCommand, WCHAR *pszResult, DWORD dwCount)
{ BOOL bRet = FAŁSZYWE; USES_CONVERSION;
WCHAR szCmdPath[MAX_PATH] = {0}; GetSystemDirectory(szCmdPath, sizeof(szCmdPath)); PathAppend(szCmdPath, L"cmd.exe");
SECURITY_ATTRIBUTES SafetyAttributes; SecurityAttributes.nLength = sizeof(SECURITY_ATTRIBUTES); SecurityAttributes.lpSecurityDescrip{filter}tor = NULL; SecurityAttributes.bInheritHandle = TRUE;
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))
{ ZamknijUchwyt(hWrite);
char szBuffer[4096] = {0}; DWORD dwRead = 0; if(pszResult)
{ pszResult[0] = 0; while(TRUE)
{ memset(szBuffer, 0, sizeof(szBuffer)); bRet = ReadFile(hRead, szBuffer, sizeof(szBuffer), &dwRead, NULL); if((FALSE == bRet) || (dwRead = 0)) przerwę;
wcscat_s(pszResult, dwCount, A2W(szBuffer));
}
}
}
ZamknijUchwyt(hRead);
} }[/mw_shl_code]
|