| // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef BASE_COMPILER_SPECIFIC_H_ |
| #define BASE_COMPILER_SPECIFIC_H_ |
| |
| #include "util/build_config.h" |
| |
| #if defined(COMPILER_MSVC) |
| |
| // For _Printf_format_string_. |
| #include <sal.h> |
| |
| #else // Not MSVC |
| |
| #define _Printf_format_string_ |
| |
| #endif // COMPILER_MSVC |
| |
| #if COMPILER_GCC && defined(NDEBUG) |
| #define ALWAYS_INLINE inline __attribute__((__always_inline__)) |
| #elif COMPILER_MSVC && defined(NDEBUG) |
| #define ALWAYS_INLINE __forceinline |
| #else |
| #define ALWAYS_INLINE inline |
| #endif |
| |
| // Annotate a function indicating the caller must examine the return value. |
| // Use like: |
| // int foo() WARN_UNUSED_RESULT; |
| // To explicitly ignore a result, see |ignore_result()| in base/macros.h. |
| #undef WARN_UNUSED_RESULT |
| #if defined(COMPILER_GCC) || defined(__clang__) |
| #define WARN_UNUSED_RESULT __attribute__((warn_unused_result)) |
| #else |
| #define WARN_UNUSED_RESULT |
| #endif |
| |
| // Tell the compiler a function is using a printf-style format string. |
| // |format_param| is the one-based index of the format string parameter; |
| // |dots_param| is the one-based index of the "..." parameter. |
| // For v*printf functions (which take a va_list), pass 0 for dots_param. |
| // (This is undocumented but matches what the system C headers do.) |
| #if defined(COMPILER_GCC) || defined(__clang__) |
| #define PRINTF_FORMAT(format_param, dots_param) \ |
| __attribute__((format(printf, format_param, dots_param))) |
| #else |
| #define PRINTF_FORMAT(format_param, dots_param) |
| #endif |
| |
| // Macro for hinting that an expression is likely to be false. |
| #if !defined(UNLIKELY) |
| #if defined(COMPILER_GCC) || defined(__clang__) |
| #define UNLIKELY(x) __builtin_expect(!!(x), 0) |
| #else |
| #define UNLIKELY(x) (x) |
| #endif // defined(COMPILER_GCC) |
| #endif // !defined(UNLIKELY) |
| |
| #if !defined(LIKELY) |
| #if defined(COMPILER_GCC) || defined(__clang__) |
| #define LIKELY(x) __builtin_expect(!!(x), 1) |
| #else |
| #define LIKELY(x) (x) |
| #endif // defined(COMPILER_GCC) |
| #endif // !defined(LIKELY) |
| |
| // Macro for telling -Wimplicit-fallthrough that a fallthrough is intentional. |
| #if defined(__clang__) |
| #define FALLTHROUGH [[clang::fallthrough]] |
| #else |
| #define FALLTHROUGH |
| #endif |
| |
| #endif // BASE_COMPILER_SPECIFIC_H_ |