Ya he escrito uno antesEl eco CMD se implementa usando pipelines anónimasAhora parece que el código en ese momento era realmente débil, y lo reescribí con enfado.
[mw_shl_code=c,true]void ExecuteCommand(WCHAR * pszCommand, WCHAR *pszResult, DWORD dwCount)
{ BOOL bRet = FALSO; 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 = 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 ProcesInformación = {0};
WCHAR szCurrentPath[MAX_PATH] = {0}; GetCurrentDirectory(sizeof(szCurrentPath), szCurrentPath);
if(CreateProcess(szCmdPath, pszCommand, NULL, NULL, TRUE, 0, NULL, szCurrentPath, & StartupInfo, &ProcesInformation))
{ CerrarHandle(hWrite);
char szBuffer[4096] = {0}; DWORD dwRead = 0; if(pszResult)
{ pszResult[0] = 0; while(VERDADERO)
{ memset(szBuffer, 0, sizeof(szBuffer)); bRet = ReadFile(hRead, szBuffer, sizeof(szBuffer), & dwRead, NULL); if((FALSE == bRet) || (dwRead = 0)) pausa;
wcscat_s(pszResult, dwCount, A2W(szBuffer));
}
}
}
CerrarAsamblar (hRead);
} }[/mw_shl_code]
|