Diligent Engine  v.2.4.g
D3DErrors.hpp
Go to the documentation of this file.
1 /*
2  * Copyright 2019-2021 Diligent Graphics LLC
3  * Copyright 2015-2019 Egor Yusov
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * In no event and under no legal theory, whether in tort (including negligence),
18  * contract, or otherwise, unless required by applicable law (such as deliberate
19  * and grossly negligent acts) or agreed to in writing, shall any Contributor be
20  * liable for any damages, including any direct, indirect, special, incidental,
21  * or consequential damages of any character arising as a result of this License or
22  * out of the use or inability to use the software (including but not limited to damages
23  * for loss of goodwill, work stoppage, computer failure or malfunction, or any and
24  * all other commercial damages or losses), even if such Contributor has been advised
25  * of the possibility of such damages.
26  */
27 
28 #pragma once
29 
30 #include <string.h>
31 
32 #include "Errors.hpp"
33 
36 
37 namespace Diligent
38 {
39 
42 {
43 public:
44  ComErrorDesc(HRESULT hr)
45  {
46  auto NumCharsWritten = FormatMessageA(
47  FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
48  NULL,
49  hr,
50  MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
51  m_Msg,
52  _countof(m_Msg),
53  NULL);
54 
55  if (NumCharsWritten == 0)
56  {
57  strcpy_s(m_Msg, _countof(m_Msg), "Unknown error");
58  }
59  else
60  {
61  auto nLen = strlen(m_Msg);
62  if (nLen > 1 && m_Msg[nLen - 1] == '\n')
63  {
64  m_Msg[nLen - 1] = 0;
65  if (m_Msg[nLen - 2] == '\r')
66  {
67  m_Msg[nLen - 2] = 0;
68  }
69  }
70  }
71  }
72 
73  const char* Get() { return m_Msg; }
74 
75 private:
76  char m_Msg[4096];
77 };
78 
79 } // namespace Diligent
80 
81 
82 #define CHECK_D3D_RESULT_THROW(Expr, Message) \
83  do \
84  { \
85  HRESULT _hr_ = Expr; \
86  if (FAILED(_hr_)) \
87  { \
88  ComErrorDesc ErrDesc(_hr_); \
89  LOG_ERROR_AND_THROW(Message, "\nHRESULT Desc: ", ErrDesc.Get()); \
90  } \
91  } while (false)
92 
93 #define CHECK_D3D_RESULT_THROW_EX(Expr, ...) \
94  do \
95  { \
96  HRESULT _hr_ = Expr; \
97  if (FAILED(_hr_)) \
98  { \
99  auto msg = Diligent::FormatString(__VA_ARGS__); \
100  ComErrorDesc ErrDesc(_hr_); \
101  LOG_ERROR_AND_THROW(msg, "\nHRESULT Desc: ", ErrDesc.Get()); \
102  } \
103  } while (false)
104 
105 #define LOG_D3D_ERROR(Expr, Message) \
106  do \
107  { \
108  HRESULT _hr_ = Expr; \
109  if (FAILED(_hr_)) \
110  { \
111  ComErrorDesc ErrDesc(_hr_); \
112  LOG_ERROR_MESSAGE(Message, "\nHRESULT Desc: ", ErrDesc.Get()); \
113  } \
114  } while (false)
Diligent::ComErrorDesc::ComErrorDesc
ComErrorDesc(HRESULT hr)
Definition: D3DErrors.hpp:44
Diligent::ComErrorDesc::Get
const char * Get()
Definition: D3DErrors.hpp:73
Diligent::ComErrorDesc
Helper class that provides description of a COM error.
Definition: D3DErrors.hpp:41
_countof
#define _countof(_Array)
Definition: AndroidPlatformDefinitions.h:38
Diligent
The library uses Direct3D-style math:
Definition: AdvancedMath.hpp:37
Errors.hpp