data:image/s3,"s3://crabby-images/788b2/788b2ecd5080c141098efb6d63735ee92ee39302" alt="" |
Dealing With HRESULTS
Submitted by |
data:image/s3,"s3://crabby-images/9cb2a/9cb2a1de1588cd30ad52466911d1d92dcb58c44d" alt=""
Here's a little macro and function combo you might find useful when dealing
with HRESULTS:
#define Report(function) _Report(__FILE__, __LINE__, #function, function)
HRESULT _Report(const char* szFileName, int nLine, const char* szFunction, HRESULT hResult)
{
if (FAILED(hResult))
cerr << szFileName << " [" << nLine << "] - FAILED. Result: " << hResult << endl;
return hResult;
} |
This makes some pretty easy to understand code, for example:
if (Report(pDDS->Flip(NULL, DDFLIP_DONOTWAIT )) == DDERR_WASSTILLDRAWING)
{
// Do some AI...
} |
I think this provides a simple, yet effective way of logging errors that may
occur. If you want something more versatile, you could try transforming the
_Report function to a singleton class, complete with file logging.
Anyways, enjoy!
|
The zip file viewer built into the Developer Toolbox made use
of the zlib library, as well as the zlibdll source additions.
|