107 lines
2.6 KiB
C++
107 lines
2.6 KiB
C++
// Copyright (c) 1997-1999 Microsoft Corporation
|
|
//
|
|
// core utility functions
|
|
//
|
|
// 30 Nov 1999 sburns
|
|
|
|
|
|
|
|
#ifndef COREUTIL_HPP_INCLUDED
|
|
#define COREUTIL_HPP_INCLUDED
|
|
|
|
|
|
|
|
#define BREAK_ON_FAILED_HRESULT(hr) \
|
|
if (FAILED(hr)) \
|
|
{ \
|
|
LOG_HRESULT(hr); \
|
|
break; \
|
|
}
|
|
|
|
|
|
|
|
#define BREAK_ON_FAILED_HRESULT2(hr,msg) \
|
|
if (FAILED(hr)) \
|
|
{ \
|
|
LOG(msg) \
|
|
LOG_HRESULT(hr); \
|
|
break; \
|
|
}
|
|
|
|
|
|
|
|
namespace Burnslib
|
|
{
|
|
|
|
|
|
|
|
// Loads various message dlls in an an attempt to resolve the HRESULT into
|
|
// an error message. Returns a "unknown error" string on failure.
|
|
|
|
String
|
|
GetErrorMessage(HRESULT hr);
|
|
|
|
|
|
|
|
// Returns the HINSTANCE of the DLL designated to contain all resources.
|
|
//
|
|
// This function requires that the first module loaded (whether it be a DLL or
|
|
// EXE) set the global variable hResourceModuleHandle to the HINSTANCE of the
|
|
// module (DLL or EXE) that contains all of the program's binary resources.
|
|
// This should be done as early as possible in the module's startup code.
|
|
|
|
HINSTANCE
|
|
GetResourceModuleHandle();
|
|
|
|
|
|
|
|
// a safe version of HRESULT_FROM_WIN32 that doesn't repeatedly evaluate
|
|
// it's arguement. The problem with using the macro directly is that the
|
|
// argument -- the win32 error to convert -- will be evaluated more than
|
|
// once. So, if you use an expression as the argument, at best you get
|
|
// an inefficiency, at worst you get unexpected side effects.
|
|
|
|
inline
|
|
HRESULT
|
|
Win32ToHresult(DWORD win32Error)
|
|
{
|
|
ASSERT(win32Error < 0xFFFF);
|
|
|
|
// If win32Error is really an HRESULT, then this will preserve that
|
|
// HRESULT, rather than whack off the error code part and change the
|
|
// facility code. See winerror.h
|
|
|
|
return HRESULT_FROM_WIN32(win32Error);
|
|
}
|
|
|
|
|
|
|
|
// unsigned version
|
|
|
|
inline
|
|
HRESULT
|
|
Win32ToHresult(LONG win32Error)
|
|
{
|
|
ASSERT(win32Error < 0xFFFF);
|
|
|
|
return HRESULT_FROM_WIN32(win32Error);
|
|
}
|
|
|
|
|
|
|
|
inline
|
|
HRESULT
|
|
NtStatusToHRESULT(NTSTATUS status)
|
|
{
|
|
return Win32ToHresult(::RtlNtStatusToDosError(status));
|
|
}
|
|
|
|
|
|
|
|
} // namespace Burnslib
|
|
|
|
|
|
|
|
#endif // COREUTIL_HPP_INCLUDED
|
|
|