MFC のCStringを使用してデバッグ情報をログに投稿する必要がありますが、最後の WinAPI によって設定されたエラー コードが保持されているかどうか (およびGetLastErrorで取得可能かどうか)を確認できないようです。
編集:これは、既存のプロジェクトで現在行っていることの簡略化されたバージョンのコード例です。
HANDLE hFile = CreateFile(strFilePath, ...);
if(hFile == INVALID_HANDLE_VALUE)
{
logError(collectDebuggerInfo(strFilePath));
}
void logError(LPCTSTR pStrDesc)
{
int nLastError = ::GetLastError();
CString str;
str.Format(L"LastError=%d, Description: %s", nLastError, pStrDesc);
//Add 'str' to the logging file...
}
CString collectDebuggerInfo(LPCTSTR pFilePath)
{
int nLastError = ::GetLastError();
CString str;
str.Format(L"Debugging info for file: \"%s\"", pFilePath);
::SetLastError(nLastError);
return str; //RETURNING CString -- will it overwrite the last error?
}