本文整理汇总了C++中CPalThread::SetLastError方法的典型用法代码示例。如果您正苦于以下问题:C++ CPalThread::SetLastError方法的具体用法?C++ CPalThread::SetLastError怎么用?C++ CPalThread::SetLastError使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CPalThread
的用法示例。
在下文中一共展示了CPalThread::SetLastError方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: ENTRY
/*++
Function:
GetThreadContext
See MSDN doc.
--*/
BOOL
PALAPI
GetThreadContext(
IN HANDLE hThread,
IN OUT LPCONTEXT lpContext)
{
PAL_ERROR palError;
CPalThread *pThread;
CPalThread *pTargetThread;
IPalObject *pobjThread = NULL;
BOOL ret = FALSE;
PERF_ENTRY(GetThreadContext);
ENTRY("GetThreadContext (hThread=%p, lpContext=%p)\n",hThread,lpContext);
pThread = InternalGetCurrentThread();
palError = InternalGetThreadDataFromHandle(
pThread,
hThread,
0, // THREAD_GET_CONTEXT
&pTargetThread,
&pobjThread
);
if (NO_ERROR == palError)
{
if (!pTargetThread->IsDummy())
{
ret = CONTEXT_GetThreadContext(
GetCurrentProcessId(),
pTargetThread->GetPThreadSelf(),
lpContext
);
}
else
{
ASSERT("Dummy thread handle passed to GetThreadContext\n");
pThread->SetLastError(ERROR_INVALID_HANDLE);
}
}
else
{
pThread->SetLastError(palError);
}
if (NULL != pobjThread)
{
pobjThread->ReleaseReference(pThread);
}
LOGEXIT("GetThreadContext returns ret:%d\n", ret);
PERF_EXIT(GetThreadContext);
return ret;
}
示例2: futimes
/*++
Function:
SetFileTime
Notes: This function will drop one digit (radix 10) of precision from
the supplied times, since Unix can set to the microsecond (at most, i.e.
if the futimes() function is available).
As noted in the file header, there is no analog to "creation time" on Unix
systems, so the lpCreationTime argument to this function will always be
ignored, and the inode change time will be set to the current time.
--*/
BOOL
PALAPI
SetFileTime(
IN HANDLE hFile,
IN CONST FILETIME *lpCreationTime,
IN CONST FILETIME *lpLastAccessTime,
IN CONST FILETIME *lpLastWriteTime)
{
CPalThread *pThread;
PAL_ERROR palError = NO_ERROR;
const UINT64 MAX_FILETIMEVALUE = 0x8000000000000000LL;
PERF_ENTRY(SetFileTime);
ENTRY("SetFileTime(hFile=%p, lpCreationTime=%p, lpLastAccessTime=%p, "
"lpLastWriteTime=%p)\n", hFile, lpCreationTime, lpLastAccessTime,
lpLastWriteTime);
pThread = InternalGetCurrentThread();
/* validate filetime values */
if ( (lpCreationTime && (((UINT64)lpCreationTime->dwHighDateTime << 32) +
lpCreationTime->dwLowDateTime >= MAX_FILETIMEVALUE)) ||
(lpLastAccessTime && (((UINT64)lpLastAccessTime->dwHighDateTime << 32) +
lpLastAccessTime->dwLowDateTime >= MAX_FILETIMEVALUE)) ||
(lpLastWriteTime && (((UINT64)lpLastWriteTime->dwHighDateTime << 32) +
lpLastWriteTime->dwLowDateTime >= MAX_FILETIMEVALUE)))
{
pThread->SetLastError(ERROR_INVALID_HANDLE);
return FALSE;
}
palError = InternalSetFileTime(
pThread,
hFile,
lpCreationTime,
lpLastAccessTime,
lpLastWriteTime
);
if (NO_ERROR != palError)
{
pThread->SetLastError(palError);
}
LOGEXIT("SetFileTime returns BOOL %s\n", NO_ERROR == palError ? "TRUE":"FALSE");
PERF_EXIT(SetFileTime);
return NO_ERROR == palError;
}
示例3: ENTRY
/*++
Function:
TlsGetValue
See MSDN doc.
--*/
LPVOID
PALAPI
TlsGetValue(
IN DWORD dwTlsIndex)
{
CPalThread *pThread;
PERF_ENTRY(TlsGetValue);
ENTRY("TlsGetValue()\n");
if (dwTlsIndex == (DWORD) -1 || dwTlsIndex >= TLS_SLOT_SIZE)
{
SetLastError(ERROR_INVALID_PARAMETER);
return 0;
}
pThread = InternalGetCurrentThread();
/* From MSDN : "The TlsGetValue function calls SetLastError to clear a
thread's last error when it succeeds." */
pThread->SetLastError(NO_ERROR);
LOGEXIT("TlsGetValue \n" );
PERF_EXIT(TlsGetValue);
return pThread->tlsInfo.tlsSlots[dwTlsIndex];
}
示例4: ENTRY
/*++
Function:
GetFileTime
Notes: As noted at the top of this file, there is no analog to "creation
time" on Unix systems, so the inode change time is used instead. Also, Win32
LastAccessTime is updated after a write operation, but it is not on Unix.
To be consistent with Win32, this function returns the greater of mtime and
atime for LastAccessTime.
--*/
BOOL
PALAPI
GetFileTime(
IN HANDLE hFile,
OUT LPFILETIME lpCreationTime,
OUT LPFILETIME lpLastAccessTime,
OUT LPFILETIME lpLastWriteTime)
{
CPalThread *pThread;
PAL_ERROR palError = NO_ERROR;
PERF_ENTRY(GetFileTime);
ENTRY("GetFileTime(hFile=%p, lpCreationTime=%p, lpLastAccessTime=%p, "
"lpLastWriteTime=%p)\n",
hFile, lpCreationTime, lpLastAccessTime, lpLastWriteTime);
pThread = InternalGetCurrentThread();
palError = InternalGetFileTime(
pThread,
hFile,
lpCreationTime,
lpLastAccessTime,
lpLastWriteTime
);
if (NO_ERROR != palError)
{
pThread->SetLastError(palError);
}
LOGEXIT("GetFileTime returns BOOL %s\n", NO_ERROR == palError ? "TRUE":"FALSE");
PERF_EXIT(GetFileTime);
return NO_ERROR == palError;
}
示例5: ENTRY
/*++
Function:
ResumeThread
See MSDN doc.
--*/
DWORD
PALAPI
ResumeThread(
IN HANDLE hThread
)
{
PAL_ERROR palError;
CPalThread *pthrResumer;
DWORD dwSuspendCount = (DWORD)-1;
PERF_ENTRY(ResumeThread);
ENTRY("ResumeThread(hThread=%p)\n", hThread);
pthrResumer = InternalGetCurrentThread();
palError = InternalResumeThread(
pthrResumer,
hThread,
&dwSuspendCount
);
if (NO_ERROR != palError)
{
pthrResumer->SetLastError(palError);
dwSuspendCount = (DWORD) -1;
}
else
{
_ASSERT_MSG(dwSuspendCount != static_cast<DWORD>(-1), "InternalResumeThread returned success but dwSuspendCount did not change.\n");
}
LOGEXIT("ResumeThread returns DWORD %u\n", dwSuspendCount);
PERF_EXIT(ResumeThread);
return dwSuspendCount;
}
示例6: ENTRY
BOOL
PALAPI
ReleaseSemaphore(
IN HANDLE hSemaphore,
IN LONG lReleaseCount,
OUT LPLONG lpPreviousCount)
{
PAL_ERROR palError = NO_ERROR;
CPalThread *pthr = NULL;
PERF_ENTRY(ReleaseSemaphore);
ENTRY("ReleaseSemaphore(hSemaphore=%p, lReleaseCount=%d, "
"lpPreviousCount=%p)\n",
hSemaphore, lReleaseCount, lpPreviousCount);
pthr = InternalGetCurrentThread();
palError = InternalReleaseSemaphore(
pthr,
hSemaphore,
lReleaseCount,
lpPreviousCount
);
if (NO_ERROR != palError)
{
pthr->SetLastError(palError);
}
LOGEXIT ("ReleaseSemaphore returns BOOL %d\n", (NO_ERROR == palError));
PERF_EXIT(ReleaseSemaphore);
return (NO_ERROR == palError);
}
示例7: ENTRY
HANDLE
PALAPI
CreateMutexW(
IN LPSECURITY_ATTRIBUTES lpMutexAttributes,
IN BOOL bInitialOwner,
IN LPCWSTR lpName)
{
HANDLE hMutex = NULL;
PAL_ERROR palError;
CPalThread *pthr = NULL;
char utf8Name[SHARED_MEMORY_MAX_NAME_CHAR_COUNT + 1];
PERF_ENTRY(CreateMutexW);
ENTRY("CreateMutexW(lpMutexAttr=%p, bInitialOwner=%d, lpName=%p (%S)\n",
lpMutexAttributes, bInitialOwner, lpName, lpName?lpName:W16_NULLSTRING);
pthr = InternalGetCurrentThread();
if (lpName != nullptr)
{
int bytesWritten = WideCharToMultiByte(CP_ACP, 0, lpName, -1, utf8Name, _countof(utf8Name), nullptr, nullptr);
if (bytesWritten == 0)
{
DWORD errorCode = GetLastError();
if (errorCode == ERROR_INSUFFICIENT_BUFFER)
{
palError = static_cast<DWORD>(SharedMemoryError::NameTooLong);
}
else
{
ASSERT("WideCharToMultiByte failed (%u)\n", errorCode);
palError = errorCode;
}
goto CreateMutexWExit;
}
}
palError = InternalCreateMutex(
pthr,
lpMutexAttributes,
bInitialOwner,
lpName == nullptr ? nullptr : utf8Name,
&hMutex
);
CreateMutexWExit:
//
// We always need to set last error, even on success:
// we need to protect ourselves from the situation
// where last error is set to ERROR_ALREADY_EXISTS on
// entry to the function
//
pthr->SetLastError(palError);
LOGEXIT("CreateMutexW returns HANDLE %p\n", hMutex);
PERF_EXIT(CreateMutexW);
return hMutex;
}
示例8: ENTRY
HANDLE
PALAPI
OpenMutexA (
IN DWORD dwDesiredAccess,
IN BOOL bInheritHandle,
IN LPCSTR lpName)
{
HANDLE hMutex = NULL;
WCHAR pwName[c_cchMaxMutex];
CPalThread *pthr = NULL;
PAL_ERROR palError;
PERF_ENTRY(OpenMutexA);
ENTRY("OpenMutexA(dwDesiredAccess=%#x, bInheritHandle=%d, lpName=%p (%s))\n",
dwDesiredAccess, bInheritHandle, lpName, lpName?lpName:"NULL");
pthr = InternalGetCurrentThread();
/* validate parameters */
if (lpName == NULL)
{
ERROR("name is NULL\n");
palError = ERROR_INVALID_PARAMETER;
goto OpenMutexAExit;
}
palError = InternalWszNameFromSzName(
pthr,
lpName,
pwName,
sizeof(pwName) / sizeof(pwName[0])
);
if (NO_ERROR != palError)
{
goto OpenMutexAExit;
}
palError = InternalOpenMutex(
pthr,
dwDesiredAccess,
bInheritHandle,
pwName,
&hMutex
);
OpenMutexAExit:
if (NO_ERROR != palError)
{
pthr->SetLastError(palError);
}
LOGEXIT("OpenMutexA returns HANDLE %p\n", hMutex);
PERF_EXIT(OpenMutexA);
return hMutex;
}
示例9: ENTRY
HANDLE
PALAPI
OpenSemaphoreW(
IN DWORD dwDesiredAccess,
IN BOOL bInheritHandle,
IN LPCWSTR lpName)
{
HANDLE hSemaphore = NULL;
PAL_ERROR palError = NO_ERROR;
CPalThread *pthr = NULL;
PERF_ENTRY(OpenSemaphoreW);
ENTRY("OpenSemaphoreW(dwDesiredAccess=%#x, bInheritHandle=%d, lpName=%p (%S))\n",
dwDesiredAccess, bInheritHandle, lpName, lpName?lpName:W16_NULLSTRING);
pthr = InternalGetCurrentThread();
/* validate parameters */
if (lpName == NULL)
{
ERROR("lpName is NULL\n");
palError = ERROR_INVALID_PARAMETER;
goto OpenSemaphoreWExit;
}
palError = InternalOpenSemaphore(
pthr,
dwDesiredAccess,
bInheritHandle,
lpName,
&hSemaphore
);
OpenSemaphoreWExit:
if (NO_ERROR != palError)
{
pthr->SetLastError(palError);
}
LOGEXIT("OpenSemaphoreW returns HANDLE %p\n", hSemaphore);
PERF_EXIT(OpenSemaphoreW);
return hSemaphore;
}
示例10: ENTRY
/*++
Function:
Sleep
See MSDN doc.
--*/
VOID
PALAPI
Sleep(IN DWORD dwMilliseconds)
{
PERF_ENTRY(Sleep);
ENTRY("Sleep(dwMilliseconds=%u)\n", dwMilliseconds);
CPalThread * pThread = InternalGetCurrentThread();
DWORD internalSleepRet = InternalSleepEx(pThread, dwMilliseconds, FALSE);
if (internalSleepRet != 0)
{
ERROR("Sleep(dwMilliseconds=%u) failed [error=%u]\n", dwMilliseconds, internalSleepRet);
pThread->SetLastError(internalSleepRet);
}
LOGEXIT("Sleep returns VOID\n");
PERF_EXIT(Sleep);
}
示例11: InternalGetCurrentThread
/*++
Function:
GetComputerNameW
Uses gethostname to get the computer name. See MSDN for functional spec.
--*/
PALIMPORT
BOOL
PALAPI
GetComputerNameW(
OUT LPWSTR lpBuffer, // address of name buffer
IN OUT LPDWORD nSize) // address of size of name buffer
{
BOOL fRet = FALSE;
char szHostName[MAXHOSTNAMELEN+1];
char *pchDot = NULL;
DWORD cwchLen = 0;
CPalThread *pPalThread = InternalGetCurrentThread();
PERF_ENTRY(GetComputerNameW);
ENTRY("GetComputerNameW(lpBuffer = %p, nSize = %p (%d)\n",
lpBuffer, nSize, nSize?*nSize:0);
if (NULL == lpBuffer || NULL == nSize)
{
ERROR("lpBuffer == NULL or nSize == NULL");
pPalThread->SetLastError(ERROR_INVALID_PARAMETER);
goto done;
}
if (0 != gethostname(szHostName, sizeof(szHostName)/sizeof(szHostName[0])))
{
ERROR("gethostname failed with error (%d) %s\n", errno, strerror(errno));
pPalThread->SetLastError(ERROR_INTERNAL_ERROR);
goto done;
}
// Null terminate the string
szHostName[sizeof(szHostName)/sizeof(szHostName[0])-1] = '\0';
// some OSes return the hostname with the domain name included.
// We want to return only the host part of the name (see the spec for
// more details
pchDot = strchr(szHostName, '.');
if (NULL != pchDot)
{
*pchDot = '\0'; // remove the domain name info
}
// clip the hostname to MAX_COMPUTERNAME_LENGTH
if (sizeof(szHostName) > MAX_COMPUTERNAME_LENGTH)
{
szHostName[MAX_COMPUTERNAME_LENGTH] = '\0';
}
// copy the hostname (including NULL character)
cwchLen = MultiByteToWideChar(CP_ACP, 0, szHostName, -1, lpBuffer, *nSize);
if (0 == cwchLen)
{
ERROR ("MultiByteToWideChar failed with error %d when trying to convert the hostname "
"%s to wide char\n", pPalThread->GetLastError(), szHostName);
if (ERROR_INSUFFICIENT_BUFFER == pPalThread->GetLastError())
{
// Find the required size (including NULL)
cwchLen = MultiByteToWideChar(CP_ACP, 0, szHostName, -1, NULL, 0);
if (0 == cwchLen)
{
ERROR ("MultiByteToWideChar failed with error %d when trying to find the size of "
"%s in wide chars\n", pPalThread->GetLastError(), szHostName);
pPalThread->SetLastError(ERROR_INTERNAL_ERROR);
}
else
{
// Update the required size
*nSize = cwchLen - 1; // don't include the NULL
pPalThread->SetLastError(ERROR_BUFFER_OVERFLOW);
}
}
goto done;
}
*nSize = cwchLen - 1; // don't include the NULL
fRet = TRUE;
done:
LOGEXIT("GetComputerNameW returning BOOL %d\n", fRet);
PERF_EXIT(GetComputerNameW);
return fRet;
}