OLD | NEW |
---|---|
1 // Copyright 2014 The Crashpad Authors. All rights reserved. | 1 // Copyright 2014 The Crashpad Authors. All rights reserved. |
2 // | 2 // |
3 // Licensed under the Apache License, Version 2.0 (the "License"); | 3 // Licensed under the Apache License, Version 2.0 (the "License"); |
4 // you may not use this file except in compliance with the License. | 4 // you may not use this file except in compliance with the License. |
5 // You may obtain a copy of the License at | 5 // You may obtain a copy of the License at |
6 // | 6 // |
7 // http://www.apache.org/licenses/LICENSE-2.0 | 7 // http://www.apache.org/licenses/LICENSE-2.0 |
8 // | 8 // |
9 // Unless required by applicable law or agreed to in writing, software | 9 // Unless required by applicable law or agreed to in writing, software |
10 // distributed under the License is distributed on an "AS IS" BASIS, | 10 // distributed under the License is distributed on an "AS IS" BASIS, |
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
12 // See the License for the specific language governing permissions and | 12 // See the License for the specific language governing permissions and |
13 // limitations under the License. | 13 // limitations under the License. |
14 | 14 |
15 #ifndef CRASHPAD_UTIL_MISC_INITIALIZATION_INITIALIZATION_STATE_DCHECK_H_ | 15 #ifndef CRASHPAD_UTIL_MISC_INITIALIZATION_INITIALIZATION_STATE_DCHECK_H_ |
16 #define CRASHPAD_UTIL_MISC_INITIALIZATION_INITIALIZATION_STATE_DCHECK_H_ | 16 #define CRASHPAD_UTIL_MISC_INITIALIZATION_INITIALIZATION_STATE_DCHECK_H_ |
17 | 17 |
18 //! \file | 18 //! \file |
19 | 19 |
20 #include "base/basictypes.h" | 20 #include "base/basictypes.h" |
21 #include "base/compiler_specific.h" | |
21 #include "base/logging.h" | 22 #include "base/logging.h" |
23 #include "build/build_config.h" | |
22 #include "util/misc/initialization_state.h" | 24 #include "util/misc/initialization_state.h" |
23 | 25 |
24 namespace crashpad { | 26 namespace crashpad { |
25 | 27 |
26 #if DCHECK_IS_ON || DOXYGEN | 28 #if DCHECK_IS_ON || DOXYGEN |
27 | 29 |
28 //! \brief Tracks whether data are initialized, triggering a DCHECK assertion | 30 //! \brief Tracks whether data are initialized, triggering a DCHECK assertion |
29 //! on an invalid data access. | 31 //! on an invalid data access. |
30 //! | 32 //! |
31 //! Put an InitializationStateDcheck member into a class to help DCHECK that | 33 //! Put an InitializationStateDcheck member into a class to help DCHECK that |
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
147 //! \param[in] initialization_state_dcheck A crashpad::InitializationStateDcheck | 149 //! \param[in] initialization_state_dcheck A crashpad::InitializationStateDcheck |
148 //! object. | 150 //! object. |
149 //! | 151 //! |
150 //! \sa crashpad::InitializationStateDcheck | 152 //! \sa crashpad::InitializationStateDcheck |
151 #define INITIALIZATION_STATE_DCHECK_VALID(initialization_state_dcheck) \ | 153 #define INITIALIZATION_STATE_DCHECK_VALID(initialization_state_dcheck) \ |
152 DCHECK_EQ((initialization_state_dcheck).state(), \ | 154 DCHECK_EQ((initialization_state_dcheck).state(), \ |
153 (initialization_state_dcheck).kStateValid) | 155 (initialization_state_dcheck).kStateValid) |
154 | 156 |
155 #else | 157 #else |
156 | 158 |
159 #if defined(COMPILER_MSVC) | |
160 // bool[0] (below) is not accepted by MSVC. | |
161 struct InitializationStateDcheck { | |
162 }; | |
163 #else | |
157 // Since this is to be used as a DCHECK (for debugging), it should be | 164 // Since this is to be used as a DCHECK (for debugging), it should be |
158 // non-intrusive in non-DCHECK (non-debug, release) builds. An empty struct | 165 // non-intrusive in non-DCHECK (non-debug, release) builds. An empty struct |
159 // would still have a nonzero size (rationale: | 166 // would still have a nonzero size (rationale: |
160 // http://www.stroustrup.com/bs_faq2.html#sizeof-empty). Zero-length arrays are | 167 // http://www.stroustrup.com/bs_faq2.html#sizeof-empty). Zero-length arrays are |
161 // technically invalid according to the standard, but clang and g++ accept them | 168 // technically invalid according to the standard, but clang and g++ accept them |
162 // without complaint even with warnings turned up. They take up no space at all, | 169 // without complaint even with warnings turned up. They take up no space at all, |
163 // and they can be “initialized” with the same () syntax used to initialize | 170 // and they can be “initialized” with the same () syntax used to initialize |
164 // objects of the DCHECK_IS_ON InitializationStateDcheck class above. | 171 // objects of the DCHECK_IS_ON InitializationStateDcheck class above. |
165 using InitializationStateDcheck = bool[0]; | 172 using InitializationStateDcheck = bool[0]; |
173 #endif // COMPILER_MSVC | |
166 | 174 |
167 namespace internal { | 175 namespace internal { |
Mark Mentovai
2015/02/11 21:37:54
Delete this whole thing now too, it’s unused.
scottmg
2015/02/11 21:38:55
Done.
| |
168 | 176 |
169 // This function exists to make use of the InitializationStateDcheck object so | 177 // This function exists to make use of the InitializationStateDcheck object so |
170 // that it appears to be used. It always returns true, so that it can be used | 178 // that it appears to be used. It always returns true, so that it can be used |
171 // as the argument to a no-op DCHECK. | 179 // as the argument to a no-op DCHECK. |
172 inline bool EatInitializationState(const InitializationStateDcheck*) { | 180 inline bool EatInitializationState(const InitializationStateDcheck*) { |
173 return true; | 181 return true; |
174 } | 182 } |
175 | 183 |
176 } // namepspace internal | 184 } // namepspace internal |
177 | 185 |
178 // The contents of these DCHECKs will never be evaluated, but they make use of | 186 // Avoid triggering warnings by repurposing these macros when DCHECKs are |
179 // initialization_state_dcheck to avoid triggering -Wunused-private-field | 187 // disabled. |
180 // warnings. | |
181 #define INITIALIZATION_STATE_SET_INITIALIZING(initialization_state_dcheck) \ | 188 #define INITIALIZATION_STATE_SET_INITIALIZING(initialization_state_dcheck) \ |
182 DCHECK(::crashpad::internal::EatInitializationState( \ | 189 ALLOW_UNUSED_LOCAL(initialization_state_dcheck) |
183 &(initialization_state_dcheck))) | |
184 #define INITIALIZATION_STATE_SET_VALID(initialization_state_dcheck) \ | 190 #define INITIALIZATION_STATE_SET_VALID(initialization_state_dcheck) \ |
185 DCHECK(::crashpad::internal::EatInitializationState( \ | 191 ALLOW_UNUSED_LOCAL(initialization_state_dcheck) |
186 &(initialization_state_dcheck))) | |
187 #define INITIALIZATION_STATE_DCHECK_VALID(initialization_state_dcheck) \ | 192 #define INITIALIZATION_STATE_DCHECK_VALID(initialization_state_dcheck) \ |
188 DCHECK(::crashpad::internal::EatInitializationState( \ | 193 ALLOW_UNUSED_LOCAL(initialization_state_dcheck) |
189 &(initialization_state_dcheck))) | |
190 | 194 |
191 #endif | 195 #endif |
192 | 196 |
193 } // namespace crashpad | 197 } // namespace crashpad |
194 | 198 |
195 #endif // CRASHPAD_UTIL_MISC_INITIALIZATION_INITIALIZATION_STATE_DCHECK_H_ | 199 #endif // CRASHPAD_UTIL_MISC_INITIALIZATION_INITIALIZATION_STATE_DCHECK_H_ |
OLD | NEW |