mirror of
https://github.com/fmtlib/fmt.git
synced 2025-07-31 03:07:36 +02:00
Use typeid() only if it's available
On MSVC it is always available, otherwise it depends on whether RTTI is enabled.
This commit is contained in:
committed by
Victor Zverovich
parent
61fb3a15ff
commit
179c7e5a66
@ -44,6 +44,24 @@
|
||||
# endif
|
||||
#endif
|
||||
|
||||
// Check if typeid is available.
|
||||
#ifndef FMT_USE_TYPEID
|
||||
// In MSVC, typeid() is available with or without RTTI.
|
||||
# if defined(_MSC_VER)
|
||||
# define FMT_USE_TYPEID 1
|
||||
# elif defined(__RTTI) // EDG compilers.
|
||||
# define FMT_USE_TYPEID 1
|
||||
# elif defined(__INTEL_RTTI__) // Intel compiler.
|
||||
# define FMT_USE_TYPEID 1
|
||||
# elif defined(__GXX_RTTI) // G++.
|
||||
# define FMT_USE_TYPEID 1
|
||||
# elif FMT_HAS_FEATURE(cxx_rtti) // Clang.
|
||||
# define FMT_USE_TYPEID 1
|
||||
# else
|
||||
# define FMT_USE_TYPEID 0
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifdef __cpp_lib_filesystem
|
||||
FMT_BEGIN_NAMESPACE
|
||||
|
||||
@ -274,7 +292,7 @@ struct formatter<
|
||||
if (it == end || *it == '}') return it;
|
||||
if (*it == 't') {
|
||||
++it;
|
||||
with_typename_ = true;
|
||||
with_typename_ = FMT_USE_TYPEID != 0;
|
||||
}
|
||||
return it;
|
||||
}
|
||||
@ -287,6 +305,7 @@ struct formatter<
|
||||
if (!with_typename_)
|
||||
return detail::write_bytes(out, string_view(ex.what()), spec);
|
||||
|
||||
#if FMT_USE_TYPEID
|
||||
const std::type_info& ti = typeid(ex);
|
||||
# ifdef FMT_HAS_ABI_CXA_DEMANGLE
|
||||
int status = 0;
|
||||
@ -342,6 +361,7 @@ struct formatter<
|
||||
out = detail::write_bytes(out, string_view(ex.what()), spec);
|
||||
|
||||
return out;
|
||||
#endif
|
||||
}
|
||||
};
|
||||
FMT_END_NAMESPACE
|
||||
|
Reference in New Issue
Block a user