Chromium Code Reviews| 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" |
| 22 #include "util/misc/initialization_state.h" | 23 #include "util/misc/initialization_state.h" |
| 23 | 24 |
| 24 namespace crashpad { | 25 namespace crashpad { |
| 25 | 26 |
| 26 #if DCHECK_IS_ON || DOXYGEN | 27 #if DCHECK_IS_ON || DOXYGEN |
| 27 | 28 |
| 28 //! \brief Tracks whether data are initialized, triggering a DCHECK assertion | 29 //! \brief Tracks whether data are initialized, triggering a DCHECK assertion |
| 29 //! on an invalid data access. | 30 //! on an invalid data access. |
| 30 //! | 31 //! |
| (...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 148 //! object. | 149 //! object. |
| 149 //! | 150 //! |
| 150 //! \sa crashpad::InitializationStateDcheck | 151 //! \sa crashpad::InitializationStateDcheck |
| 151 #define INITIALIZATION_STATE_DCHECK_VALID(initialization_state_dcheck) \ | 152 #define INITIALIZATION_STATE_DCHECK_VALID(initialization_state_dcheck) \ |
| 152 DCHECK_EQ((initialization_state_dcheck).state(), \ | 153 DCHECK_EQ((initialization_state_dcheck).state(), \ |
| 153 (initialization_state_dcheck).kStateValid) | 154 (initialization_state_dcheck).kStateValid) |
| 154 | 155 |
| 155 #else | 156 #else |
| 156 | 157 |
| 157 // Since this is to be used as a DCHECK (for debugging), it should be | 158 // 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 | 159 // non-intrusive in non-DCHECK (non-debug, release) builds. |
| 159 // would still have a nonzero size (rationale: | 160 struct InitializationStateDcheck { |
|
Mark Mentovai
2015/02/11 20:47:12
This comment explains why this wasn’t done before.
scottmg
2015/02/11 21:03:31
Done.
It seemed unnecessarily tricky to me given
| |
| 160 // http://www.stroustrup.com/bs_faq2.html#sizeof-empty). Zero-length arrays are | 161 }; |
| 161 // 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, | |
| 163 // and they can be “initialized” with the same () syntax used to initialize | |
| 164 // objects of the DCHECK_IS_ON InitializationStateDcheck class above. | |
| 165 using InitializationStateDcheck = bool[0]; | |
| 166 | 162 |
| 167 namespace internal { | 163 namespace internal { |
| 168 | 164 |
| 169 // This function exists to make use of the InitializationStateDcheck object so | 165 // 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 | 166 // 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. | 167 // as the argument to a no-op DCHECK. |
| 172 inline bool EatInitializationState(const InitializationStateDcheck*) { | 168 inline bool EatInitializationState(const InitializationStateDcheck*) { |
| 173 return true; | 169 return true; |
| 174 } | 170 } |
| 175 | 171 |
| 176 } // namepspace internal | 172 } // namepspace internal |
| 177 | 173 |
| 178 // The contents of these DCHECKs will never be evaluated, but they make use of | 174 // Avoid triggering warnings by making repurposing these macros when DCHECKs are |
| 179 // initialization_state_dcheck to avoid triggering -Wunused-private-field | 175 // disabled. |
| 180 // warnings. | |
| 181 #define INITIALIZATION_STATE_SET_INITIALIZING(initialization_state_dcheck) \ | 176 #define INITIALIZATION_STATE_SET_INITIALIZING(initialization_state_dcheck) \ |
| 182 DCHECK(::crashpad::internal::EatInitializationState( \ | 177 ALLOW_UNUSED_LOCAL(initialization_state_dcheck) |
| 183 &(initialization_state_dcheck))) | |
| 184 #define INITIALIZATION_STATE_SET_VALID(initialization_state_dcheck) \ | 178 #define INITIALIZATION_STATE_SET_VALID(initialization_state_dcheck) \ |
| 185 DCHECK(::crashpad::internal::EatInitializationState( \ | 179 ALLOW_UNUSED_LOCAL(initialization_state_dcheck) |
| 186 &(initialization_state_dcheck))) | |
| 187 #define INITIALIZATION_STATE_DCHECK_VALID(initialization_state_dcheck) \ | 180 #define INITIALIZATION_STATE_DCHECK_VALID(initialization_state_dcheck) \ |
| 188 DCHECK(::crashpad::internal::EatInitializationState( \ | 181 ALLOW_UNUSED_LOCAL(initialization_state_dcheck) |
| 189 &(initialization_state_dcheck))) | |
| 190 | 182 |
| 191 #endif | 183 #endif |
| 192 | 184 |
| 193 } // namespace crashpad | 185 } // namespace crashpad |
| 194 | 186 |
| 195 #endif // CRASHPAD_UTIL_MISC_INITIALIZATION_INITIALIZATION_STATE_DCHECK_H_ | 187 #endif // CRASHPAD_UTIL_MISC_INITIALIZATION_INITIALIZATION_STATE_DCHECK_H_ |
| OLD | NEW |