2004-03-10 00:25:57 +01:00
|
|
|
/*
|
|
|
|
* DirectX 9 error routines
|
|
|
|
*
|
|
|
|
* Copyright 2004 Robert Reif
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
2006-05-18 14:49:52 +02:00
|
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
2004-03-10 00:25:57 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "windef.h"
|
|
|
|
#include "winbase.h"
|
|
|
|
#include "wingdi.h"
|
|
|
|
#include "winuser.h"
|
|
|
|
|
|
|
|
#include "mmsystem.h"
|
2005-10-27 13:20:15 +02:00
|
|
|
#include "dmerror.h"
|
|
|
|
#include "ddraw.h"
|
|
|
|
#include "dinput.h"
|
|
|
|
#include "vfwmsgs.h"
|
|
|
|
#include "mmstream.h"
|
|
|
|
#include "dplay8.h"
|
|
|
|
#include "dxfile.h"
|
|
|
|
#include "d3d9.h"
|
2004-03-10 00:25:57 +01:00
|
|
|
#include "dsound.h"
|
|
|
|
|
|
|
|
#include "dxerr9.h"
|
|
|
|
|
|
|
|
#include "wine/debug.h"
|
|
|
|
|
|
|
|
WINE_DEFAULT_DEBUG_CHANNEL(dxerr);
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
HRESULT hr;
|
|
|
|
const CHAR* resultA;
|
|
|
|
const WCHAR* resultW;
|
|
|
|
const CHAR* descriptionA;
|
|
|
|
const WCHAR* descriptionW;
|
|
|
|
} error_info;
|
|
|
|
|
|
|
|
#include "errors.h"
|
|
|
|
|
|
|
|
const char * WINAPI DXGetErrorString9A(HRESULT hr)
|
|
|
|
{
|
2005-10-27 13:20:15 +02:00
|
|
|
unsigned int i, j, k = 0;
|
2006-10-08 00:50:14 +02:00
|
|
|
TRACE("(0x%08x)\n", hr);
|
2004-03-10 00:25:57 +01:00
|
|
|
|
2005-10-27 13:20:15 +02:00
|
|
|
for (i = sizeof(info)/sizeof(info[0]); i != 0; i /= 2) {
|
|
|
|
j = k + (i / 2);
|
|
|
|
if (hr == info[j].hr)
|
|
|
|
return info[j].resultA;
|
|
|
|
if ((unsigned int)hr > (unsigned int)info[j].hr) {
|
|
|
|
k = j + 1;
|
|
|
|
i--;
|
|
|
|
}
|
2004-03-10 00:25:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return "Unknown";
|
|
|
|
}
|
|
|
|
|
|
|
|
const WCHAR * WINAPI DXGetErrorString9W(HRESULT hr)
|
|
|
|
{
|
|
|
|
static const WCHAR unknown[] = { 'U', 'n', 'k', 'n', 'o', 'w', 'n', 0 };
|
2005-10-27 13:20:15 +02:00
|
|
|
unsigned int i, j, k = 0;
|
2006-10-08 00:50:14 +02:00
|
|
|
TRACE("(0x%08x)\n", hr);
|
2004-03-10 00:25:57 +01:00
|
|
|
|
2005-10-27 13:20:15 +02:00
|
|
|
for (i = sizeof(info)/sizeof(info[0]); i != 0; i /= 2) {
|
|
|
|
j = k + (i / 2);
|
|
|
|
if (hr == info[j].hr)
|
|
|
|
return info[j].resultW;
|
|
|
|
if ((unsigned int)hr > (unsigned int)info[j].hr) {
|
|
|
|
k = j + 1;
|
|
|
|
i--;
|
2004-03-10 00:25:57 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return unknown;
|
|
|
|
}
|
|
|
|
|
|
|
|
const char * WINAPI DXGetErrorDescription9A(HRESULT hr)
|
|
|
|
{
|
2005-10-27 13:20:15 +02:00
|
|
|
unsigned int i, j, k = 0;
|
2006-10-08 00:50:14 +02:00
|
|
|
TRACE("(0x%08x)\n", hr);
|
2004-03-10 00:25:57 +01:00
|
|
|
|
2005-10-27 13:20:15 +02:00
|
|
|
for (i = sizeof(info)/sizeof(info[0]); i != 0; i /= 2) {
|
|
|
|
j = k + (i / 2);
|
|
|
|
if (hr == info[j].hr)
|
|
|
|
return info[j].descriptionA;
|
|
|
|
if ((unsigned int)hr > (unsigned int)info[j].hr) {
|
|
|
|
k = j + 1;
|
|
|
|
i--;
|
|
|
|
}
|
2004-03-10 00:25:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return "n/a";
|
|
|
|
}
|
|
|
|
|
|
|
|
const WCHAR * WINAPI DXGetErrorDescription9W(HRESULT hr)
|
|
|
|
{
|
|
|
|
static const WCHAR na[] = { 'n', '/', 'a', 0 };
|
2005-10-27 13:20:15 +02:00
|
|
|
unsigned int i, j, k = 0;
|
2006-10-08 00:50:14 +02:00
|
|
|
TRACE("(0x%08x)\n", hr);
|
2004-03-10 00:25:57 +01:00
|
|
|
|
2005-10-27 13:20:15 +02:00
|
|
|
for (i = sizeof(info)/sizeof(info[0]); i != 0; i /= 2) {
|
|
|
|
j = k + (i / 2);
|
|
|
|
if (hr == info[j].hr)
|
|
|
|
return info[j].descriptionW;
|
|
|
|
if ((unsigned int)hr > (unsigned int)info[j].hr) {
|
|
|
|
k = j + 1;
|
|
|
|
i--;
|
2004-03-10 00:25:57 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return na;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI DXTraceA(const char* strFile, DWORD dwLine, HRESULT hr, const char* strMsg, BOOL bPopMsgBox)
|
|
|
|
{
|
|
|
|
char msg[1024];
|
2006-10-08 00:50:14 +02:00
|
|
|
TRACE("(%p,%d,0x%08x,%p,%d)\n", strFile, dwLine, hr, strMsg, bPopMsgBox);
|
2004-03-10 00:25:57 +01:00
|
|
|
|
|
|
|
if (bPopMsgBox) {
|
2006-10-08 00:50:14 +02:00
|
|
|
snprintf(msg, sizeof(msg), "File: %s\nLine: %d\nError Code: %s (0x%08x)\nCalling: %s",
|
2004-03-10 00:25:57 +01:00
|
|
|
strFile, dwLine, DXGetErrorString9A(hr), hr, strMsg);
|
|
|
|
MessageBoxA(0, msg, "Unexpected error encountered", MB_OK|MB_ICONERROR);
|
|
|
|
} else {
|
2006-10-08 00:50:14 +02:00
|
|
|
snprintf(msg, sizeof(msg), "%s(%d): %s (hr=%s (0x%08x))", strFile,
|
2004-03-10 00:25:57 +01:00
|
|
|
dwLine, strMsg, DXGetErrorString9A(hr), hr);
|
|
|
|
OutputDebugStringA(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
return hr;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI DXTraceW(const char* strFile, DWORD dwLine, HRESULT hr, const WCHAR* strMsg, BOOL bPopMsgBox)
|
|
|
|
{
|
|
|
|
WCHAR msg[1024];
|
2006-10-08 00:50:14 +02:00
|
|
|
TRACE("(%p,%d,0x%08x,%p,%d)\n", strFile, dwLine, hr, strMsg, bPopMsgBox);
|
2004-03-10 00:25:57 +01:00
|
|
|
|
|
|
|
if (bPopMsgBox) {
|
2004-04-20 03:12:17 +02:00
|
|
|
static const WCHAR format[] = { 'F','i','l','e',':',' ','%','s','\\','n','L','i','n',
|
2004-03-10 00:25:57 +01:00
|
|
|
'e',':',' ','%','l','d','\\','n','E','r','r','o','r',' ','C','o',
|
|
|
|
'd','e',':',' ','%','s',' ','(','0','x','%','0','8','l','x',')',
|
|
|
|
'\\','n','C','a','l','l','i','n','g',':',' ','%','s',0 };
|
2004-04-20 03:12:17 +02:00
|
|
|
static const WCHAR caption[] = { 'U','n','e','x','p','e','c','t','e','d',' ','e','r',
|
|
|
|
'r','o','r',' ','e','n','c','o','u','n','t','e','r','e','d',0 };
|
2004-03-10 00:25:57 +01:00
|
|
|
/* FIXME: should use wsnprintf */
|
2004-04-20 03:12:17 +02:00
|
|
|
wsprintfW(msg, format, strFile, dwLine,
|
2004-03-10 00:25:57 +01:00
|
|
|
DXGetErrorString9W(hr), hr, strMsg);
|
|
|
|
MessageBoxW(0, msg, caption, MB_OK|MB_ICONERROR);
|
|
|
|
} else {
|
2004-04-20 03:12:17 +02:00
|
|
|
static const WCHAR format[] = { '%','s','(','%','l','d',')',':',' ','%','s',' ','(',
|
2004-03-10 00:25:57 +01:00
|
|
|
'h','r','=','%','s',' ','(','0','x','%','0','8','l','x',')',')',' ',
|
|
|
|
0 };
|
|
|
|
/* FIXME: should use wsnprintf */
|
2004-04-20 03:12:17 +02:00
|
|
|
wsprintfW(msg, format, strFile, dwLine, strMsg,
|
2004-03-10 00:25:57 +01:00
|
|
|
DXGetErrorString9W(hr), hr);
|
|
|
|
OutputDebugStringW(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
return hr;
|
|
|
|
}
|