Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef BASE_COMPILER_SPECIFIC_H_ | 5 #ifndef BASE_COMPILER_SPECIFIC_H_ |
| 6 #define BASE_COMPILER_SPECIFIC_H_ | 6 #define BASE_COMPILER_SPECIFIC_H_ |
| 7 | 7 |
| 8 #include "build/build_config.h" | 8 #include "build/build_config.h" |
| 9 | 9 |
| 10 #if defined(COMPILER_MSVC) | 10 #if defined(COMPILER_MSVC) |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 64 #define MSVC_SUPPRESS_WARNING(n) | 64 #define MSVC_SUPPRESS_WARNING(n) |
| 65 #define MSVC_PUSH_DISABLE_WARNING(n) | 65 #define MSVC_PUSH_DISABLE_WARNING(n) |
| 66 #define MSVC_PUSH_WARNING_LEVEL(n) | 66 #define MSVC_PUSH_WARNING_LEVEL(n) |
| 67 #define MSVC_POP_WARNING() | 67 #define MSVC_POP_WARNING() |
| 68 #define MSVC_DISABLE_OPTIMIZE() | 68 #define MSVC_DISABLE_OPTIMIZE() |
| 69 #define MSVC_ENABLE_OPTIMIZE() | 69 #define MSVC_ENABLE_OPTIMIZE() |
| 70 #define NON_EXPORTED_BASE(code) code | 70 #define NON_EXPORTED_BASE(code) code |
| 71 | 71 |
| 72 #endif // COMPILER_MSVC | 72 #endif // COMPILER_MSVC |
| 73 | 73 |
| 74 | |
| 75 // Annotate a variable indicating it's ok if the variable is not used. | 74 // Annotate a variable indicating it's ok if the variable is not used. |
| 76 // (Typically used to silence a compiler warning when the assignment | 75 // (Typically used to silence a compiler warning when the assignment |
| 77 // is important for some other reason.) | 76 // is important for some other reason.) |
| 78 // Use like: | 77 // Use like: |
| 79 // int x = ...; | 78 // int x = ...; |
| 80 // ALLOW_UNUSED_LOCAL(x); | 79 // ALLOW_UNUSED_LOCAL(x); |
| 80 // | |
| 81 // The common-case implementation references |x| in such a way that it's never | |
| 82 // evaluated. Static analysis builds still see this as not referencing |x|, so | |
| 83 // in such cases we reference it directly to make the compiler happy, at the | |
| 84 // risk of unintended side effects. | |
| 85 #if defined(__clang_analyzer__) | |
| 86 | |
| 87 #define ALLOW_UNUSED_LOCAL(x) (void)x | |
| 88 | |
| 89 #else // !defined(__clang_analyzer__) | |
| 90 | |
| 81 #define ALLOW_UNUSED_LOCAL(x) false ? (void)x : (void)0 | 91 #define ALLOW_UNUSED_LOCAL(x) false ? (void)x : (void)0 |
|
Nico
2017/04/25 15:48:52
What was the problem with making this use `(void)x
Kevin Marshall
2017/04/25 17:17:31
When I asked pkasting (author of the original #def
| |
| 82 | 92 |
| 93 #endif // defined(__clang_analyzer__) | |
| 94 | |
| 83 // Annotate a typedef or function indicating it's ok if it's not used. | 95 // Annotate a typedef or function indicating it's ok if it's not used. |
| 84 // Use like: | 96 // Use like: |
| 85 // typedef Foo Bar ALLOW_UNUSED_TYPE; | 97 // typedef Foo Bar ALLOW_UNUSED_TYPE; |
| 86 #if defined(COMPILER_GCC) || defined(__clang__) | 98 #if defined(COMPILER_GCC) || defined(__clang__) |
| 87 #define ALLOW_UNUSED_TYPE __attribute__((unused)) | 99 #define ALLOW_UNUSED_TYPE __attribute__((unused)) |
| 88 #else | 100 #else |
| 89 #define ALLOW_UNUSED_TYPE | 101 #define ALLOW_UNUSED_TYPE |
| 90 #endif | 102 #endif |
| 91 | 103 |
| 92 // Annotate a function indicating it should not be inlined. | 104 // Annotate a function indicating it should not be inlined. |
| (...skipping 131 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 224 | 236 |
| 225 // Compiler feature-detection. | 237 // Compiler feature-detection. |
| 226 // clang.llvm.org/docs/LanguageExtensions.html#has-feature-and-has-extension | 238 // clang.llvm.org/docs/LanguageExtensions.html#has-feature-and-has-extension |
| 227 #if defined(__has_feature) | 239 #if defined(__has_feature) |
| 228 #define HAS_FEATURE(FEATURE) __has_feature(FEATURE) | 240 #define HAS_FEATURE(FEATURE) __has_feature(FEATURE) |
| 229 #else | 241 #else |
| 230 #define HAS_FEATURE(FEATURE) 0 | 242 #define HAS_FEATURE(FEATURE) 0 |
| 231 #endif | 243 #endif |
| 232 | 244 |
| 233 #endif // BASE_COMPILER_SPECIFIC_H_ | 245 #endif // BASE_COMPILER_SPECIFIC_H_ |
| OLD | NEW |