/*========================================================================== * * Copyright (C) 1999 Microsoft Corporation. All Rights Reserved. * * File: dverror.cpp * Content: Error string handling * * History: * Date By Reason * ==== == ====== * 01/21/2000 pnewson Created * 04/19/2000 pnewson Error handling cleanup * ***************************************************************************/ #include "dxvutilspch.h" #undef DPF_SUBCOMP #define DPF_SUBCOMP DN_SUBCOMP_VOICE #define MESSAGE_STRING_MAX_LEN 256 #define MAX_ERROR_CODE_STRING_LEN 8 static const TCHAR* g_tszDefaultMessage = "DirectPlay Voice has encountered an error\r\n(The error code was 0x%x)"; static const TCHAR* g_tszDefaultMessageCaption = "Error"; #undef DPF_MODNAME #define DPF_MODNAME "DV_DisplayDefaultErrorBox" void DV_DisplayDefaultErrorBox(HRESULT hr, HWND hwndParent) { DPFX(DPFPREP, DVF_ERRORLEVEL, "DV_DisplayDefaultErrorBox called"); TCHAR tszMsgFmt[MESSAGE_STRING_MAX_LEN]; if (_tcslen(g_tszDefaultMessage) + MAX_ERROR_CODE_STRING_LEN + 1 < MESSAGE_STRING_MAX_LEN) { _stprintf(tszMsgFmt, g_tszDefaultMessage, hr); } else { // Programmer mess up, DNASSERT if we're in debug, otherwise just // copy what we can of the default message over. DNASSERT(FALSE); _tcsncpy(tszMsgFmt, g_tszDefaultMessage, MESSAGE_STRING_MAX_LEN - 1); } MessageBox(hwndParent, tszMsgFmt, g_tszDefaultMessageCaption, MB_OK|MB_ICONERROR); return; } #undef DPF_MODNAME #define DPF_MODNAME "DV_DisplayErrorBox" void DV_DisplayErrorBox(HRESULT hr, HWND hwndParent, UINT idsErrorMessage) { DPFX(DPFPREP, DVF_ERRORLEVEL, "DV_DisplayErrorBox called"); TCHAR tszMsg[MESSAGE_STRING_MAX_LEN]; TCHAR tszMsgFmt[MESSAGE_STRING_MAX_LEN]; TCHAR tszCaption[MESSAGE_STRING_MAX_LEN]; HINSTANCE hDPVoiceDll = LoadLibrary("dpvoice.dll"); if (hDPVoiceDll == NULL) { // Very weird! go with a default message. DPFX(DPFPREP, DVF_ERRORLEVEL, "LoadLibrary(dpvoice.dll) failed - using default hardcoded message"); DV_DisplayDefaultErrorBox(hr, hwndParent); return; } if (!LoadString(hDPVoiceDll, IDS_ERROR_CAPTION, tszCaption, MESSAGE_STRING_MAX_LEN)) { DPFX(DPFPREP, DVF_ERRORLEVEL, "LoadString failed - using default hardcoded message"); DV_DisplayDefaultErrorBox(hr, hwndParent); return; } if (idsErrorMessage == 0) { if (!LoadString(hDPVoiceDll, IDS_ERROR_MSG, tszMsg, MESSAGE_STRING_MAX_LEN)) { DPFX(DPFPREP, DVF_ERRORLEVEL, "LoadString failed - using default hardcoded message"); DV_DisplayDefaultErrorBox(hr, hwndParent); return; } if (_tcslen(tszMsg) + MAX_ERROR_CODE_STRING_LEN + 1 < MESSAGE_STRING_MAX_LEN) { _stprintf(tszMsgFmt, tszMsg, hr); } else { // Programmer mess up, DNASSERT if we're in debug, otherwise just // copy what we can of the default message over. DNASSERT(FALSE); _tcsncpy(tszMsgFmt, tszMsg, MESSAGE_STRING_MAX_LEN - 1); } } else { // This is the only custom error message that we expect at this time DNASSERT(idsErrorMessage == IDS_ERROR_NODEVICES); if (!LoadString(hDPVoiceDll, IDS_ERROR_NODEVICES, tszMsgFmt, MESSAGE_STRING_MAX_LEN)) { DPFX(DPFPREP, DVF_ERRORLEVEL, "LoadString failed - using default hardcoded message"); DV_DisplayDefaultErrorBox(hr, hwndParent); return; } } if (!IsWindow(hwndParent)) { hwndParent = NULL; } PlaySound( _T("SystemExclamation"), NULL, SND_ASYNC ); MessageBox(hwndParent, tszMsgFmt, tszCaption, MB_OK|MB_ICONERROR); return; }