|
|
|
|
@ -13,12 +13,12 @@ BOOL terminating;
|
|
|
|
|
int cleanup_thread_id; |
|
|
|
|
|
|
|
|
|
// delete overloads the delete operator.
|
|
|
|
|
//void operator delete(void *ptr)
|
|
|
|
|
//{
|
|
|
|
|
// if (ptr != NULL) {
|
|
|
|
|
// SMemFree(ptr, "delete", -1, 0);
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
void __cdecl operator delete(void *ptr) |
|
|
|
|
{ |
|
|
|
|
if (ptr != NULL) { |
|
|
|
|
SMemFree(ptr, "delete", -1, 0); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void TriggerBreak() |
|
|
|
|
{ |
|
|
|
|
@ -55,6 +55,9 @@ LONG __stdcall BreakFilter(PEXCEPTION_POINTERS pExc)
|
|
|
|
|
} |
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Returns a formatted error message based on the given error code. |
|
|
|
|
*/ |
|
|
|
|
char *GetErrorStr(DWORD error_code) |
|
|
|
|
{ |
|
|
|
|
int size; |
|
|
|
|
@ -96,188 +99,161 @@ void TraceErrorDD(HRESULT hError, char *pszBuffer, DWORD dwMaxChars)
|
|
|
|
|
const char *szError; |
|
|
|
|
|
|
|
|
|
switch (hError) { |
|
|
|
|
case DDERR_CANTPAGEUNLOCK: |
|
|
|
|
szError = "DDERR_CANTPAGEUNLOCK"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOTPAGELOCKED: |
|
|
|
|
szError = "DDERR_NOTPAGELOCKED"; |
|
|
|
|
break; |
|
|
|
|
case DD_OK: |
|
|
|
|
szError = "DD_OK"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANTPAGELOCK: |
|
|
|
|
szError = "DDERR_CANTPAGELOCK"; |
|
|
|
|
case DDERR_ALREADYINITIALIZED: |
|
|
|
|
szError = "DDERR_ALREADYINITIALIZED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_BLTFASTCANTCLIP: |
|
|
|
|
szError = "DDERR_BLTFASTCANTCLIP"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOBLTHW: |
|
|
|
|
szError = "DDERR_NOBLTHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NODDROPSHW: |
|
|
|
|
szError = "DDERR_NODDROPSHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_OVERLAYNOTVISIBLE: |
|
|
|
|
szError = "DDERR_OVERLAYNOTVISIBLE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOOVERLAYDEST: |
|
|
|
|
szError = "DDERR_NOOVERLAYDEST"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDPOSITION: |
|
|
|
|
szError = "DDERR_INVALIDPOSITION"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOTAOVERLAYSURFACE: |
|
|
|
|
szError = "DDERR_NOTAOVERLAYSURFACE"; |
|
|
|
|
case DDERR_CANNOTATTACHSURFACE: |
|
|
|
|
szError = "DDERR_CANNOTATTACHSURFACE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_EXCLUSIVEMODEALREADYSET: |
|
|
|
|
szError = "DDERR_EXCLUSIVEMODEALREADYSET"; |
|
|
|
|
case DDERR_CANNOTDETACHSURFACE: |
|
|
|
|
szError = "DDERR_CANNOTDETACHSURFACE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOTFLIPPABLE: |
|
|
|
|
szError = "DDERR_NOTFLIPPABLE"; |
|
|
|
|
case DDERR_CANTCREATEDC: |
|
|
|
|
szError = "DDERR_CANTCREATEDC"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANTDUPLICATE: |
|
|
|
|
szError = "DDERR_CANTDUPLICATE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOTLOCKED: |
|
|
|
|
szError = "DDERR_NOTLOCKED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANTCREATEDC: |
|
|
|
|
szError = "DDERR_CANTCREATEDC"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NODC: |
|
|
|
|
szError = "DDERR_NODC"; |
|
|
|
|
case DDERR_CLIPPERISUSINGHWND: |
|
|
|
|
szError = "DDERR_CLIPPERISUSINGHWND"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_WRONGMODE: |
|
|
|
|
szError = "DDERR_WRONGMODE"; |
|
|
|
|
case DDERR_COLORKEYNOTSET: |
|
|
|
|
szError = "DDERR_COLORKEYNOTSET"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_IMPLICITLYCREATED: |
|
|
|
|
szError = "DDERR_IMPLICITLYCREATED"; |
|
|
|
|
case DDERR_CURRENTLYNOTAVAIL: |
|
|
|
|
szError = "DDERR_CURRENTLYNOTAVAIL"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOTPALETTIZED: |
|
|
|
|
szError = "DDERR_NOTPALETTIZED"; |
|
|
|
|
case DDERR_DIRECTDRAWALREADYCREATED: |
|
|
|
|
szError = "DDERR_DIRECTDRAWALREADYCREATED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOMIPMAPHW: |
|
|
|
|
szError = "DDERR_NOMIPMAPHW"; |
|
|
|
|
case DDERR_EXCEPTION: |
|
|
|
|
szError = "DDERR_EXCEPTION"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDSURFACETYPE: |
|
|
|
|
szError = "DDERR_INVALIDSURFACETYPE"; |
|
|
|
|
case DDERR_EXCLUSIVEMODEALREADYSET: |
|
|
|
|
szError = "DDERR_EXCLUSIVEMODEALREADYSET"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_DCALREADYCREATED: |
|
|
|
|
szError = "DDERR_DCALREADYCREATED"; |
|
|
|
|
case DDERR_GENERIC: |
|
|
|
|
szError = "DDERR_GENERIC"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOPALETTEHW: |
|
|
|
|
szError = "DDERR_NOPALETTEHW"; |
|
|
|
|
case DDERR_HEIGHTALIGN: |
|
|
|
|
szError = "DDERR_HEIGHTALIGN"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_DIRECTDRAWALREADYCREATED: |
|
|
|
|
szError = "DDERR_DIRECTDRAWALREADYCREATED"; |
|
|
|
|
case DDERR_HWNDALREADYSET: |
|
|
|
|
szError = "DDERR_HWNDALREADYSET"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NODIRECTDRAWHW: |
|
|
|
|
szError = "DDERR_NODIRECTDRAWHW"; |
|
|
|
|
case DDERR_HWNDSUBCLASSED: |
|
|
|
|
szError = "DDERR_HWNDSUBCLASSED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_PRIMARYSURFACEALREADYEXISTS: |
|
|
|
|
szError = "DDERR_PRIMARYSURFACEALREADYEXISTS"; |
|
|
|
|
case DDERR_IMPLICITLYCREATED: |
|
|
|
|
szError = "DDERR_IMPLICITLYCREATED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOEMULATION: |
|
|
|
|
szError = "DDERR_NOEMULATION"; |
|
|
|
|
case DDERR_INCOMPATIBLEPRIMARY: |
|
|
|
|
szError = "DDERR_INCOMPATIBLEPRIMARY"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_REGIONTOOSMALL: |
|
|
|
|
szError = "DDERR_REGIONTOOSMALL"; |
|
|
|
|
case DDERR_INVALIDCAPS: |
|
|
|
|
szError = "DDERR_INVALIDCAPS"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CLIPPERISUSINGHWND: |
|
|
|
|
szError = "DDERR_CLIPPERISUSINGHWND"; |
|
|
|
|
case DDERR_INVALIDCLIPLIST: |
|
|
|
|
szError = "DDERR_INVALIDCLIPLIST"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOCLIPPERATTACHED: |
|
|
|
|
szError = "DDERR_NOCLIPPERATTACHED"; |
|
|
|
|
case DDERR_INVALIDDIRECTDRAWGUID: |
|
|
|
|
szError = "DDERR_INVALIDDIRECTDRAWGUID"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOHWND: |
|
|
|
|
szError = "DDERR_NOHWND"; |
|
|
|
|
case DDERR_INVALIDMODE: |
|
|
|
|
szError = "DDERR_INVALIDMODE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_HWNDSUBCLASSED: |
|
|
|
|
szError = "DDERR_HWNDSUBCLASSED"; |
|
|
|
|
case DDERR_INVALIDOBJECT: |
|
|
|
|
szError = "DDERR_INVALIDOBJECT"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_HWNDALREADYSET: |
|
|
|
|
szError = "DDERR_HWNDALREADYSET"; |
|
|
|
|
case DDERR_INVALIDPARAMS: |
|
|
|
|
szError = "DDERR_INVALIDPARAMS"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOPALETTEATTACHED: |
|
|
|
|
szError = "DDERR_NOPALETTEATTACHED"; |
|
|
|
|
case DDERR_INVALIDPIXELFORMAT: |
|
|
|
|
szError = "DDERR_INVALIDPIXELFORMAT"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDDIRECTDRAWGUID: |
|
|
|
|
szError = "DDERR_INVALIDDIRECTDRAWGUID"; |
|
|
|
|
case DDERR_INVALIDPOSITION: |
|
|
|
|
szError = "DDERR_INVALIDPOSITION"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_UNSUPPORTEDFORMAT: |
|
|
|
|
szError = "DDERR_UNSUPPORTEDFORMAT"; |
|
|
|
|
case DDERR_INVALIDRECT: |
|
|
|
|
szError = "DDERR_INVALIDRECT"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_UNSUPPORTEDMASK: |
|
|
|
|
szError = "DDERR_UNSUPPORTEDMASK"; |
|
|
|
|
case DDERR_LOCKEDSURFACES: |
|
|
|
|
szError = "DDERR_LOCKEDSURFACES"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_VERTICALBLANKINPROGRESS: |
|
|
|
|
szError = "DDERR_VERTICALBLANKINPROGRESS"; |
|
|
|
|
case DDERR_NO3D: |
|
|
|
|
szError = "DDERR_NO3D"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_WASSTILLDRAWING: |
|
|
|
|
szError = "DDERR_WASSTILLDRAWING"; |
|
|
|
|
case DDERR_NOALPHAHW: |
|
|
|
|
szError = "DDERR_NOALPHAHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_XALIGN: |
|
|
|
|
szError = "DDERR_XALIGN"; |
|
|
|
|
case DDERR_NOBLTHW: |
|
|
|
|
szError = "DDERR_NOBLTHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_TOOBIGWIDTH: |
|
|
|
|
szError = "DDERR_TOOBIGWIDTH"; |
|
|
|
|
case DDERR_NOCLIPLIST: |
|
|
|
|
szError = "DDERR_NOCLIPLIST"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANTLOCKSURFACE: |
|
|
|
|
szError = "DDERR_CANTLOCKSURFACE"; |
|
|
|
|
case DDERR_NOCLIPPERATTACHED: |
|
|
|
|
szError = "DDERR_NOCLIPPERATTACHED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_SURFACEISOBSCURED: |
|
|
|
|
szError = "DDERR_SURFACEISOBSCURED"; |
|
|
|
|
case DDERR_NOCOLORCONVHW: |
|
|
|
|
szError = "DDERR_NOCOLORCONVHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_SURFACELOST: |
|
|
|
|
szError = "DDERR_SURFACELOST"; |
|
|
|
|
case DDERR_NOCOLORKEY: |
|
|
|
|
szError = "DDERR_NOCOLORKEY"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_SURFACENOTATTACHED: |
|
|
|
|
szError = "DDERR_SURFACENOTATTACHED"; |
|
|
|
|
case DDERR_NOCOLORKEYHW: |
|
|
|
|
szError = "DDERR_NOCOLORKEYHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_TOOBIGHEIGHT: |
|
|
|
|
szError = "DDERR_TOOBIGHEIGHT"; |
|
|
|
|
case DDERR_NOCOOPERATIVELEVELSET: |
|
|
|
|
szError = "DDERR_NOCOOPERATIVELEVELSET"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_TOOBIGSIZE: |
|
|
|
|
szError = "DDERR_TOOBIGSIZE"; |
|
|
|
|
case DDERR_NODC: |
|
|
|
|
szError = "DDERR_NODC"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_SURFACEBUSY: |
|
|
|
|
szError = "DDERR_SURFACEBUSY"; |
|
|
|
|
case DDERR_NODDROPSHW: |
|
|
|
|
szError = "DDERR_NODDROPSHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_OVERLAYCOLORKEYONLYONEACTIVE: |
|
|
|
|
szError = "DDERR_OVERLAYCOLORKEYONLYONEACTIVE"; |
|
|
|
|
case DDERR_NODIRECTDRAWHW: |
|
|
|
|
szError = "DDERR_NODIRECTDRAWHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_PALETTEBUSY: |
|
|
|
|
szError = "DDERR_PALETTEBUSY"; |
|
|
|
|
case DDERR_NOEMULATION: |
|
|
|
|
szError = "DDERR_NOEMULATION"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_COLORKEYNOTSET: |
|
|
|
|
szError = "DDERR_COLORKEYNOTSET"; |
|
|
|
|
case DDERR_NOEXCLUSIVEMODE: |
|
|
|
|
szError = "DDERR_NOEXCLUSIVEMODE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_SURFACEALREADYATTACHED: |
|
|
|
|
szError = "DDERR_SURFACEALREADYATTACHED"; |
|
|
|
|
case DDERR_NOFLIPHW: |
|
|
|
|
szError = "DDERR_NOFLIPHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_SURFACEALREADYDEPENDENT: |
|
|
|
|
szError = "DDERR_SURFACEALREADYDEPENDENT"; |
|
|
|
|
case DDERR_NOGDI: |
|
|
|
|
szError = "DDERR_NOGDI"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_OVERLAYCANTCLIP: |
|
|
|
|
szError = "DDERR_OVERLAYCANTCLIP"; |
|
|
|
|
case DDERR_NOHWND: |
|
|
|
|
szError = "DDERR_NOHWND"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOVSYNCHW: |
|
|
|
|
szError = "DDERR_NOVSYNCHW"; |
|
|
|
|
case DDERR_NOMIRRORHW: |
|
|
|
|
szError = "DDERR_NOMIRRORHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOZBUFFERHW: |
|
|
|
|
szError = "DDERR_NOZBUFFERHW"; |
|
|
|
|
case DDERR_NOOVERLAYDEST: |
|
|
|
|
szError = "DDERR_NOOVERLAYDEST"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOZOVERLAYHW: |
|
|
|
|
szError = "DDERR_NOZOVERLAYHW"; |
|
|
|
|
case DDERR_NOOVERLAYHW: |
|
|
|
|
szError = "DDERR_NOOVERLAYHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_OUTOFCAPS: |
|
|
|
|
szError = "DDERR_OUTOFCAPS"; |
|
|
|
|
case DDERR_NOPALETTEATTACHED: |
|
|
|
|
szError = "DDERR_NOPALETTEATTACHED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_OUTOFVIDEOMEMORY: |
|
|
|
|
szError = "DDERR_OUTOFVIDEOMEMORY"; |
|
|
|
|
case DDERR_NOPALETTEHW: |
|
|
|
|
szError = "DDERR_NOPALETTEHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOTEXTUREHW: |
|
|
|
|
szError = "DDERR_NOTEXTUREHW"; |
|
|
|
|
case DDERR_NORASTEROPHW: |
|
|
|
|
szError = "DDERR_NORASTEROPHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOROTATIONHW: |
|
|
|
|
szError = "DDERR_NOROTATIONHW"; |
|
|
|
|
@ -294,101 +270,128 @@ void TraceErrorDD(HRESULT hError, char *pszBuffer, DWORD dwMaxChars)
|
|
|
|
|
case DDERR_NOT8BITCOLOR: |
|
|
|
|
szError = "DDERR_NOT8BITCOLOR"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NORASTEROPHW: |
|
|
|
|
szError = "DDERR_NORASTEROPHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOEXCLUSIVEMODE: |
|
|
|
|
szError = "DDERR_NOEXCLUSIVEMODE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOFLIPHW: |
|
|
|
|
szError = "DDERR_NOFLIPHW"; |
|
|
|
|
case DDERR_NOTAOVERLAYSURFACE: |
|
|
|
|
szError = "DDERR_NOTAOVERLAYSURFACE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOGDI: |
|
|
|
|
szError = "DDERR_NOGDI"; |
|
|
|
|
case DDERR_NOTEXTUREHW: |
|
|
|
|
szError = "DDERR_NOTEXTUREHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOMIRRORHW: |
|
|
|
|
szError = "DDERR_NOMIRRORHW"; |
|
|
|
|
case DDERR_NOTFLIPPABLE: |
|
|
|
|
szError = "DDERR_NOTFLIPPABLE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOTFOUND: |
|
|
|
|
szError = "DDERR_NOTFOUND"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOOVERLAYHW: |
|
|
|
|
szError = "DDERR_NOOVERLAYHW"; |
|
|
|
|
case DDERR_NOTLOCKED: |
|
|
|
|
szError = "DDERR_NOTLOCKED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOCOLORKEYHW: |
|
|
|
|
szError = "DDERR_NOCOLORKEYHW"; |
|
|
|
|
case DDERR_NOTPALETTIZED: |
|
|
|
|
szError = "DDERR_NOTPALETTIZED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOALPHAHW: |
|
|
|
|
szError = "DDERR_NOALPHAHW"; |
|
|
|
|
case DDERR_NOVSYNCHW: |
|
|
|
|
szError = "DDERR_NOVSYNCHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOCLIPLIST: |
|
|
|
|
szError = "DDERR_NOCLIPLIST"; |
|
|
|
|
case DDERR_NOZBUFFERHW: |
|
|
|
|
szError = "DDERR_NOZBUFFERHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOCOLORCONVHW: |
|
|
|
|
szError = "DDERR_NOCOLORCONVHW"; |
|
|
|
|
case DDERR_NOZOVERLAYHW: |
|
|
|
|
szError = "DDERR_NOZOVERLAYHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOCOOPERATIVELEVELSET: |
|
|
|
|
szError = "DDERR_NOCOOPERATIVELEVELSET"; |
|
|
|
|
case DDERR_OUTOFCAPS: |
|
|
|
|
szError = "DDERR_OUTOFCAPS"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOCOLORKEY: |
|
|
|
|
szError = "DDERR_NOCOLORKEY"; |
|
|
|
|
case DDERR_OUTOFMEMORY: |
|
|
|
|
szError = "DDERR_OUTOFMEMORY"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NO3D: |
|
|
|
|
szError = "DDERR_NO3D"; |
|
|
|
|
case DDERR_OUTOFVIDEOMEMORY: |
|
|
|
|
szError = "DDERR_OUTOFVIDEOMEMORY"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDMODE: |
|
|
|
|
szError = "DDERR_INVALIDMODE"; |
|
|
|
|
case DDERR_OVERLAYCANTCLIP: |
|
|
|
|
szError = "DDERR_OVERLAYCANTCLIP"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDOBJECT: |
|
|
|
|
szError = "DDERR_INVALIDOBJECT"; |
|
|
|
|
case DDERR_OVERLAYCOLORKEYONLYONEACTIVE: |
|
|
|
|
szError = "DDERR_OVERLAYCOLORKEYONLYONEACTIVE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDPIXELFORMAT: |
|
|
|
|
szError = "DDERR_INVALIDPIXELFORMAT"; |
|
|
|
|
case DDERR_OVERLAYNOTVISIBLE: |
|
|
|
|
szError = "DDERR_OVERLAYNOTVISIBLE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDRECT: |
|
|
|
|
szError = "DDERR_INVALIDRECT"; |
|
|
|
|
case DDERR_PALETTEBUSY: |
|
|
|
|
szError = "DDERR_PALETTEBUSY"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_LOCKEDSURFACES: |
|
|
|
|
szError = "DDERR_LOCKEDSURFACES"; |
|
|
|
|
case DDERR_PRIMARYSURFACEALREADYEXISTS: |
|
|
|
|
szError = "DDERR_PRIMARYSURFACEALREADYEXISTS"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDCLIPLIST: |
|
|
|
|
szError = "DDERR_INVALIDCLIPLIST"; |
|
|
|
|
case DDERR_REGIONTOOSMALL: |
|
|
|
|
szError = "DDERR_REGIONTOOSMALL"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CURRENTLYNOTAVAIL: |
|
|
|
|
szError = "DDERR_CURRENTLYNOTAVAIL"; |
|
|
|
|
case DDERR_SURFACEALREADYATTACHED: |
|
|
|
|
szError = "DDERR_SURFACEALREADYATTACHED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_EXCEPTION: |
|
|
|
|
szError = "DDERR_EXCEPTION"; |
|
|
|
|
case DDERR_SURFACEALREADYDEPENDENT: |
|
|
|
|
szError = "DDERR_SURFACEALREADYDEPENDENT"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_HEIGHTALIGN: |
|
|
|
|
szError = "DDERR_HEIGHTALIGN"; |
|
|
|
|
case DDERR_SURFACEBUSY: |
|
|
|
|
szError = "DDERR_SURFACEBUSY"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INCOMPATIBLEPRIMARY: |
|
|
|
|
szError = "DDERR_INCOMPATIBLEPRIMARY"; |
|
|
|
|
case DDERR_SURFACEISOBSCURED: |
|
|
|
|
szError = "DDERR_SURFACEISOBSCURED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDCAPS: |
|
|
|
|
szError = "DDERR_INVALIDCAPS"; |
|
|
|
|
case DDERR_SURFACELOST: |
|
|
|
|
szError = "DDERR_SURFACELOST"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANNOTDETACHSURFACE: |
|
|
|
|
szError = "DDERR_CANNOTDETACHSURFACE"; |
|
|
|
|
case DDERR_SURFACENOTATTACHED: |
|
|
|
|
szError = "DDERR_SURFACENOTATTACHED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_TOOBIGHEIGHT: |
|
|
|
|
szError = "DDERR_TOOBIGHEIGHT"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_TOOBIGSIZE: |
|
|
|
|
szError = "DDERR_TOOBIGSIZE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_TOOBIGWIDTH: |
|
|
|
|
szError = "DDERR_TOOBIGWIDTH"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_UNSUPPORTED: |
|
|
|
|
szError = "DDERR_UNSUPPORTED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_GENERIC: |
|
|
|
|
szError = "DDERR_GENERIC"; |
|
|
|
|
case DDERR_UNSUPPORTEDFORMAT: |
|
|
|
|
szError = "DDERR_UNSUPPORTEDFORMAT"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_OUTOFMEMORY: |
|
|
|
|
szError = "DDERR_OUTOFMEMORY"; |
|
|
|
|
case DDERR_UNSUPPORTEDMASK: |
|
|
|
|
szError = "DDERR_UNSUPPORTEDMASK"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDPARAMS: |
|
|
|
|
szError = "DDERR_INVALIDPARAMS"; |
|
|
|
|
case DDERR_VERTICALBLANKINPROGRESS: |
|
|
|
|
szError = "DDERR_VERTICALBLANKINPROGRESS"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_ALREADYINITIALIZED: |
|
|
|
|
szError = "DDERR_ALREADYINITIALIZED"; |
|
|
|
|
case DDERR_WASSTILLDRAWING: |
|
|
|
|
szError = "DDERR_WASSTILLDRAWING"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANNOTATTACHSURFACE: |
|
|
|
|
szError = "DDERR_CANNOTATTACHSURFACE"; |
|
|
|
|
case DDERR_WRONGMODE: |
|
|
|
|
szError = "DDERR_WRONGMODE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_XALIGN: |
|
|
|
|
szError = "DDERR_XALIGN"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANTLOCKSURFACE: |
|
|
|
|
szError = "DDERR_CANTLOCKSURFACE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANTPAGELOCK: |
|
|
|
|
szError = "DDERR_CANTPAGELOCK"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_CANTPAGEUNLOCK: |
|
|
|
|
szError = "DDERR_CANTPAGEUNLOCK"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_DCALREADYCREATED: |
|
|
|
|
szError = "DDERR_DCALREADYCREATED"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_INVALIDSURFACETYPE: |
|
|
|
|
szError = "DDERR_INVALIDSURFACETYPE"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOMIPMAPHW: |
|
|
|
|
szError = "DDERR_NOMIPMAPHW"; |
|
|
|
|
break; |
|
|
|
|
case DDERR_NOTPAGELOCKED: |
|
|
|
|
szError = "DDERR_NOTPAGELOCKED"; |
|
|
|
|
break; |
|
|
|
|
default: { |
|
|
|
|
const char szUnknown[] = "DDERR unknown 0x%x"; |
|
|
|
|
@ -462,11 +465,17 @@ void TraceErrorDS(HRESULT hError, char *pszBuffer, DWORD dwMaxChars)
|
|
|
|
|
strncpy(pszBuffer, szError, dwMaxChars); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Returns a formatted error message of the last error. |
|
|
|
|
*/ |
|
|
|
|
char *TraceLastError() |
|
|
|
|
{ |
|
|
|
|
return GetErrorStr(GetLastError()); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Terminates the game and displays an error message box. |
|
|
|
|
*/ |
|
|
|
|
void __cdecl app_fatal(const char *pszFmt, ...) |
|
|
|
|
{ |
|
|
|
|
va_list va; |
|
|
|
|
@ -484,8 +493,12 @@ void __cdecl app_fatal(const char *pszFmt, ...)
|
|
|
|
|
|
|
|
|
|
init_cleanup(FALSE); |
|
|
|
|
exit(1); |
|
|
|
|
ExitProcess(1); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Displays an error message box based on the given format string and variable argument list. |
|
|
|
|
*/ |
|
|
|
|
void MsgBox(const char *pszFmt, va_list va) |
|
|
|
|
{ |
|
|
|
|
char Text[256]; |
|
|
|
|
@ -496,6 +509,9 @@ void MsgBox(const char *pszFmt, va_list va)
|
|
|
|
|
MessageBox(ghMainWnd, Text, "ERROR", MB_TASKMODAL | MB_ICONHAND); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Cleans up after a fatal application error. |
|
|
|
|
*/ |
|
|
|
|
void FreeDlg() |
|
|
|
|
{ |
|
|
|
|
if (terminating && cleanup_thread_id != GetCurrentThreadId()) |
|
|
|
|
@ -515,6 +531,9 @@ void FreeDlg()
|
|
|
|
|
ShowCursor(TRUE); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Displays a warning message box based on the given formatted error message. |
|
|
|
|
*/ |
|
|
|
|
void __cdecl DrawDlg(char *pszFmt, ...) |
|
|
|
|
{ |
|
|
|
|
char text[256]; |
|
|
|
|
@ -533,6 +552,9 @@ void assert_fail(int nLineNo, const char *pszFile, const char *pszFail)
|
|
|
|
|
} |
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Terminates the game with a DirectDraw assertion message box. |
|
|
|
|
*/ |
|
|
|
|
void DDErrMsg(DWORD error_code, int log_line_nr, char *log_file_path) |
|
|
|
|
{ |
|
|
|
|
char *msg; |
|
|
|
|
@ -543,6 +565,9 @@ void DDErrMsg(DWORD error_code, int log_line_nr, char *log_file_path)
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Terminates the game with a DirectSound assertion message box. |
|
|
|
|
*/ |
|
|
|
|
void DSErrMsg(DWORD error_code, int log_line_nr, char *log_file_path) |
|
|
|
|
{ |
|
|
|
|
char *msg; |
|
|
|
|
@ -553,6 +578,9 @@ void DSErrMsg(DWORD error_code, int log_line_nr, char *log_file_path)
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Centres the given dialog box. |
|
|
|
|
*/ |
|
|
|
|
void center_window(HWND hDlg) |
|
|
|
|
{ |
|
|
|
|
LONG w, h; |
|
|
|
|
@ -573,6 +601,9 @@ void center_window(HWND hDlg)
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Callback function which processes messages sent to the given dialog box. |
|
|
|
|
*/ |
|
|
|
|
static BOOL CALLBACK FuncDlg(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) |
|
|
|
|
{ |
|
|
|
|
switch (uMsg) { |
|
|
|
|
@ -593,7 +624,10 @@ static BOOL CALLBACK FuncDlg(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
|
|
|
|
return TRUE; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void ErrDlg(int template_id, DWORD error_code, char *log_file_path, int log_line_nr) |
|
|
|
|
/**
|
|
|
|
|
* @brief Terminates the game and displays an error dialog box based on the given dialog_id. |
|
|
|
|
*/ |
|
|
|
|
void ErrDlg(int dialog_id, DWORD error_code, char *log_file_path, int log_line_nr) |
|
|
|
|
{ |
|
|
|
|
char *size; |
|
|
|
|
LPARAM dwInitParam[128]; |
|
|
|
|
@ -605,12 +639,15 @@ void ErrDlg(int template_id, DWORD error_code, char *log_file_path, int log_line
|
|
|
|
|
log_file_path = size + 1; |
|
|
|
|
|
|
|
|
|
wsprintf((LPSTR)dwInitParam, "%s\nat: %s line %d", GetErrorStr(error_code), log_file_path, log_line_nr); |
|
|
|
|
if (DialogBoxParam(ghInst, MAKEINTRESOURCE(template_id), ghMainWnd, (DLGPROC)FuncDlg, (LPARAM)dwInitParam) == -1) |
|
|
|
|
app_fatal("ErrDlg: %d", template_id); |
|
|
|
|
if (DialogBoxParam(ghInst, MAKEINTRESOURCE(dialog_id), ghMainWnd, (DLGPROC)FuncDlg, (LPARAM)dwInitParam) == -1) |
|
|
|
|
app_fatal("ErrDlg: %d", dialog_id); |
|
|
|
|
|
|
|
|
|
app_fatal(NULL); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Sets the text of the given dialog. |
|
|
|
|
*/ |
|
|
|
|
static void TextDlg(HWND hDlg, char *text) |
|
|
|
|
{ |
|
|
|
|
center_window(hDlg); |
|
|
|
|
@ -619,7 +656,10 @@ static void TextDlg(HWND hDlg, char *text)
|
|
|
|
|
SetDlgItemText(hDlg, 1000, text); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void ErrOkDlg(int template_id, DWORD error_code, char *log_file_path, int log_line_nr) |
|
|
|
|
/**
|
|
|
|
|
* @brief Displays a warning dialog box based on the given dialog_id and error code. |
|
|
|
|
*/ |
|
|
|
|
void ErrOkDlg(int dialog_id, DWORD error_code, char *log_file_path, int log_line_nr) |
|
|
|
|
{ |
|
|
|
|
char *size; |
|
|
|
|
LPARAM dwInitParam[128]; |
|
|
|
|
@ -629,9 +669,12 @@ void ErrOkDlg(int template_id, DWORD error_code, char *log_file_path, int log_li
|
|
|
|
|
log_file_path = size + 1; |
|
|
|
|
|
|
|
|
|
wsprintf((LPSTR)dwInitParam, "%s\nat: %s line %d", GetErrorStr(error_code), log_file_path, log_line_nr); |
|
|
|
|
DialogBoxParam(ghInst, MAKEINTRESOURCE(template_id), ghMainWnd, (DLGPROC)FuncDlg, (LPARAM)dwInitParam); |
|
|
|
|
DialogBoxParam(ghInst, MAKEINTRESOURCE(dialog_id), ghMainWnd, (DLGPROC)FuncDlg, (LPARAM)dwInitParam); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Terminates the game with a file not found error dialog. |
|
|
|
|
*/ |
|
|
|
|
void FileErrDlg(const char *error) |
|
|
|
|
{ |
|
|
|
|
FreeDlg(); |
|
|
|
|
@ -645,6 +688,9 @@ void FileErrDlg(const char *error)
|
|
|
|
|
app_fatal(NULL); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Terminates the game with an out of disk space error dialog. |
|
|
|
|
*/ |
|
|
|
|
void DiskFreeDlg(char *error) |
|
|
|
|
{ |
|
|
|
|
FreeDlg(); |
|
|
|
|
@ -655,6 +701,9 @@ void DiskFreeDlg(char *error)
|
|
|
|
|
app_fatal(NULL); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Terminates the game with an insert CD error dialog. |
|
|
|
|
*/ |
|
|
|
|
BOOL InsertCDDlg() |
|
|
|
|
{ |
|
|
|
|
int nResult; |
|
|
|
|
@ -670,6 +719,9 @@ BOOL InsertCDDlg()
|
|
|
|
|
return nResult == IDOK; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Terminates the game with a read-only directory error dialog. |
|
|
|
|
*/ |
|
|
|
|
void DirErrorDlg(char *error) |
|
|
|
|
{ |
|
|
|
|
FreeDlg(); |
|
|
|
|
|