clang-tidy: add Chrome-inspired checks
[lttng-tools.git] / src / common / format.hpp
CommitLineData
05aa7e19
JG
1/*
2 * Copyright (C) 2022 Jérémie Galarneau <jeremie.galarneau@efficios.com>
3 *
4 * SPDX-License-Identifier: LGPL-2.1-only
5 *
6 */
7#ifndef LTTNG_FORMAT_H
8#define LTTNG_FORMAT_H
9
10#include <common/macros.hpp>
11
5bb4ff54
JG
12#include <string>
13#include <cxxabi.h>
14
05aa7e19
JG
15DIAGNOSTIC_PUSH
16DIAGNOSTIC_IGNORE_SUGGEST_ATTRIBUTE_FORMAT
17DIAGNOSTIC_IGNORE_DUPLICATED_BRANCHES
18#define FMT_HEADER_ONLY
19#include <vendor/fmt/core.h>
20DIAGNOSTIC_POP
21
11bcbf89
JG
22/*
23 * Due to a bug in g++ < 7.1, this specialization must be enclosed in the fmt namespace,
24 * see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=56480.
25 */
e2c2bec2 26namespace fmt {
5bb4ff54 27template <>
e2c2bec2 28struct formatter<std::type_info> : formatter<std::string> {
5bb4ff54
JG
29 template <typename FormatCtx>
30 typename FormatCtx::iterator format(const std::type_info& type_info, FormatCtx& ctx)
31 {
32 int status;
cd9adb8b
JG
33 auto demangled_name =
34 abi::__cxa_demangle(type_info.name(), nullptr, nullptr, &status);
e2c2bec2
JR
35 auto it = status == 0 ? formatter<std::string>::format(demangled_name, ctx) :
36 formatter<std::string>::format(type_info.name(), ctx);
5bb4ff54
JG
37
38 free(demangled_name);
39 return it;
40 }
41};
e2c2bec2 42} /* namespace fmt */
5bb4ff54 43
05aa7e19 44#endif /* LTTNG_FORMAT_H */
This page took 0.02697 seconds and 4 git commands to generate.