blob: a374d7f1798e4147d806615459e53508f00e25fe [file] [log] [blame]
#ifndef THIRD_PARTY_GBMCWEB_INCLUDE_SOURCE_LOCATION_H_
#define THIRD_PARTY_GBMCWEB_INCLUDE_SOURCE_LOCATION_H_
// As of clang-12, clang still doesn't support std::source_location, which
// means that clang-tidy also doesn't support std::source_location.
// Inside the libstdc++ implementation of <source_location> is this check of
// __builtin_source_location to determine if the compiler supports the
// necessary bits for std::source_location, and if not the header ends up doing
// nothing. Use this same builtin-check to detect when we're running under
// an "older" clang and fallback to std::experimental::source_location instead.
#if __has_builtin(__builtin_source_location)
#include <source_location> // NOLINT
namespace bmcweb {
using source_location = std::source_location;
} // namespace bmcweb
#else
#include <experimental/source_location>
namespace bmcweb {
using source_location = std::experimental::source_location;
} // namespace bmcweb
#endif
#endif // THIRD_PARTY_GBMCWEB_INCLUDE_SOURCE_LOCATION_H_