Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

380 lines
7.3 KiB

  1. /******************************************************************
  2. * *
  3. * CPP file for common error handling functions. *
  4. * *
  5. ******************************************************************/
  6. #ifdef USE_STDAFX
  7. # include "stdafx.h"
  8. # include "rpc.h"
  9. #else
  10. # include <windows.h>
  11. #endif
  12. #include "HrMsg.h"
  13. #include <stdio.h>
  14. #include <stdarg.h>
  15. namespace HrMsg_cpp
  16. {
  17. void __stdcall AdmtThrowErrorImpl(const _com_error& ce, LPCTSTR pszDescription);
  18. }
  19. using namespace HrMsg_cpp;
  20. //---------------------------------------------------------------------------
  21. // GetError Helper Function
  22. //---------------------------------------------------------------------------
  23. _com_error GetError(HRESULT hr)
  24. {
  25. _com_error ce(hr);
  26. IErrorInfo* pErrorInfo = NULL;
  27. if (GetErrorInfo(0, &pErrorInfo) == S_OK)
  28. {
  29. ce = _com_error(FAILED(hr) ? hr : E_FAIL, pErrorInfo);
  30. }
  31. else
  32. {
  33. ce = _com_error(FAILED(hr) ? hr : S_OK);
  34. }
  35. return ce;
  36. }
  37. //-----------------------------------------------------------------------------
  38. // Return text for hresults
  39. //-----------------------------------------------------------------------------
  40. _bstr_t __stdcall HResultToText2(HRESULT hr)
  41. {
  42. _bstr_t bstrError;
  43. LPTSTR pszError = NULL;
  44. try
  45. {
  46. switch (HRESULT_FACILITY(hr))
  47. {
  48. // case FACILITY_NULL: // 0
  49. // case FACILITY_RPC: // 1
  50. // case FACILITY_DISPATCH: // 2
  51. // case FACILITY_STORAGE: // 3
  52. case FACILITY_ITF: // 4
  53. {
  54. HMODULE hModule = LoadLibrary(_T("MSDAERR.dll"));
  55. if (hModule)
  56. {
  57. FormatMessage(
  58. FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAGE_FROM_HMODULE,
  59. hModule,
  60. hr,
  61. 0,
  62. (LPTSTR)&pszError,
  63. 0,
  64. NULL
  65. );
  66. FreeLibrary(hModule);
  67. }
  68. break;
  69. }
  70. case FACILITY_WIN32: // 7
  71. {
  72. FormatMessage(
  73. FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAGE_FROM_SYSTEM,
  74. NULL,
  75. hr,
  76. 0,
  77. (LPTSTR)&pszError,
  78. 0,
  79. NULL
  80. );
  81. break;
  82. }
  83. // case FACILITY_WINDOWS: // 8
  84. // case FACILITY_SSPI: // 9
  85. // case FACILITY_SECURITY: // 9
  86. case FACILITY_CONTROL: // 10
  87. {
  88. HMODULE hModule = LoadLibrary(_T("MSADER15.dll"));
  89. if (hModule)
  90. {
  91. FormatMessage(
  92. FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAGE_FROM_HMODULE,
  93. hModule,
  94. hr,
  95. 0,
  96. (LPTSTR)&pszError,
  97. 0,
  98. NULL
  99. );
  100. FreeLibrary(hModule);
  101. }
  102. break;
  103. }
  104. // case FACILITY_CERT: // 11
  105. // case FACILITY_INTERNET: // 12
  106. // case FACILITY_MEDIASERVER: // 13
  107. case FACILITY_MSMQ: // 14
  108. {
  109. HMODULE hModule = LoadLibrary(_T("MQUTIL.dll"));
  110. if (hModule)
  111. {
  112. FormatMessage(
  113. FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAGE_FROM_HMODULE,
  114. hModule,
  115. hr,
  116. 0,
  117. (LPTSTR)&pszError,
  118. 0,
  119. NULL
  120. );
  121. FreeLibrary(hModule);
  122. }
  123. break;
  124. }
  125. // case FACILITY_SETUPAPI: // 15
  126. // case FACILITY_SCARD: // 16
  127. // case FACILITY_COMPLUS: // 17
  128. // case FACILITY_AAF: // 18
  129. // case FACILITY_URT: // 19
  130. // case FACILITY_ACS: // 20
  131. default:
  132. {
  133. FormatMessage(
  134. FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAGE_FROM_SYSTEM,
  135. NULL,
  136. hr,
  137. 0,
  138. (LPTSTR)&pszError,
  139. 0,
  140. NULL
  141. );
  142. break;
  143. }
  144. }
  145. if (pszError)
  146. {
  147. size_t cch = _tcslen(pszError);
  148. if ((cch > 1) && (pszError[cch - 1] == _T('\n')))
  149. {
  150. pszError[cch - 1] = 0;
  151. if (pszError[cch - 2] == _T('\r'))
  152. {
  153. pszError[cch - 2] = 0;
  154. }
  155. }
  156. bstrError = pszError;
  157. }
  158. else
  159. {
  160. _TCHAR szError[32];
  161. _stprintf(szError, _T("Unknown error 0x%08lX."), hr);
  162. bstrError = szError;
  163. }
  164. }
  165. catch (...)
  166. {
  167. ;
  168. }
  169. if (pszError)
  170. {
  171. LocalFree((HLOCAL)pszError);
  172. }
  173. return bstrError;
  174. }
  175. _bstr_t FormatHRMsg(LPCTSTR pformatStr, HRESULT hr)
  176. {
  177. WCHAR sError[MAX_PATH];
  178. _com_error ce = GetError(hr);
  179. _bstr_t bstrDescription = ce.Description();
  180. if (bstrDescription.length() > 0)
  181. {
  182. swprintf(sError, pformatStr, (WCHAR*)bstrDescription);
  183. }
  184. else
  185. {
  186. swprintf(sError, pformatStr, (WCHAR*)HResultToText(hr));
  187. }
  188. return sError;
  189. }
  190. _bstr_t __stdcall HResultToText(HRESULT hr)
  191. {
  192. return GetError(hr).Description();
  193. }
  194. //---------------------------------------------------------------------------
  195. // AdmtThrowError
  196. //
  197. // Generates formatted error description and generates exception.
  198. //
  199. // 2000-??-?? Mark Oluper - initial
  200. // 2001-02-13 Mark Oluper - moved to commonlib
  201. //---------------------------------------------------------------------------
  202. void __cdecl AdmtThrowError(_com_error ce, HINSTANCE hInstance, UINT uId, ...)
  203. {
  204. _TCHAR szFormat[512];
  205. _TCHAR szDescription[1024];
  206. if (LoadString(hInstance, uId, szFormat, 512))
  207. {
  208. va_list args;
  209. va_start(args, uId);
  210. _vsntprintf(szDescription, sizeof(szDescription) / sizeof(szDescription[0]), szFormat, args);
  211. va_end(args);
  212. }
  213. else
  214. {
  215. szDescription[0] = _T('\0');
  216. }
  217. AdmtThrowErrorImpl(ce, szDescription);
  218. }
  219. void __cdecl AdmtThrowError(_com_error ce, LPCTSTR pszFormat, ...)
  220. {
  221. _TCHAR szDescription[1024];
  222. if (pszFormat)
  223. {
  224. va_list args;
  225. va_start(args, pszFormat);
  226. _vsntprintf(szDescription, sizeof(szDescription) / sizeof(szDescription[0]), pszFormat, args);
  227. va_end(args);
  228. }
  229. else
  230. {
  231. szDescription[0] = _T('\0');
  232. }
  233. AdmtThrowErrorImpl(ce, szDescription);
  234. }
  235. namespace HrMsg_cpp
  236. {
  237. //---------------------------------------------------------------------------
  238. // AdmtThrowErrorImpl
  239. //
  240. // Concatenates rich error information and throws exception.
  241. //
  242. // 2000-??-?? Mark Oluper - initial
  243. // 2001-02-13 Mark Oluper - moved to commonlib
  244. //---------------------------------------------------------------------------
  245. void __stdcall AdmtThrowErrorImpl(const _com_error& ce, LPCTSTR pszDescription)
  246. {
  247. _bstr_t bstrNewDescription;
  248. try
  249. {
  250. bstrNewDescription = pszDescription;
  251. _bstr_t bstrSource = ce.Source();
  252. if (bstrSource.length() > 0)
  253. {
  254. if (bstrNewDescription.length() > 0)
  255. {
  256. bstrNewDescription += _T(" : ");
  257. }
  258. bstrNewDescription += bstrSource;
  259. }
  260. _bstr_t bstrOldDescription = ce.Description();
  261. if (bstrOldDescription.length() > 0)
  262. {
  263. if (bstrNewDescription.length() > 0)
  264. {
  265. if (bstrSource.length() > 0)
  266. {
  267. bstrNewDescription += _T(": ");
  268. }
  269. else
  270. {
  271. bstrNewDescription += _T(" ");
  272. }
  273. }
  274. bstrNewDescription += bstrOldDescription;
  275. }
  276. else
  277. {
  278. LPCTSTR pszErrorMessage = ce.ErrorMessage();
  279. if (pszErrorMessage)
  280. {
  281. if (bstrNewDescription.length() > 0)
  282. {
  283. bstrNewDescription += _T(" : ");
  284. }
  285. bstrNewDescription += pszErrorMessage;
  286. }
  287. }
  288. }
  289. catch (...)
  290. {
  291. ;
  292. }
  293. ICreateErrorInfoPtr spCreateErrorInfo;
  294. CreateErrorInfo(&spCreateErrorInfo);
  295. if (spCreateErrorInfo)
  296. {
  297. // LPOLESTR pszProgId;
  298. // if (ProgIDFromCLSID(clsid, &pszProgId) == S_OK)
  299. // {
  300. // spCreateErrorInfo->SetSource(pszProgId);
  301. // CoTaskMemFree(pszProgId);
  302. // }
  303. // else
  304. // {
  305. spCreateErrorInfo->SetSource(L"");
  306. // }
  307. // spCreateErrorInfo->SetGUID(iid);
  308. spCreateErrorInfo->SetGUID(GUID_NULL);
  309. spCreateErrorInfo->SetDescription(bstrNewDescription);
  310. spCreateErrorInfo->SetHelpFile(L"");
  311. spCreateErrorInfo->SetHelpContext(0);
  312. }
  313. _com_raise_error(ce.Error(), IErrorInfoPtr(spCreateErrorInfo).Detach());
  314. }
  315. } // namespace