boa
#include <iostream>
//for the type_name():
#include <type_traits>
#include <typeinfo>
#ifndef _MSC_VER
# include <cxxabi.h>
#endif
#include <memory>
#include <string>
#include <cstdlib>
template <class T>
std::string
type_name()
{
typedef typename std::remove_reference<T>::type TR;
std::unique_ptr<char, void(*)(void*)> own
(
#ifndef _MSC_VER
abi::__cxa_demangle(typeid(TR).name(), nullptr,
nullptr, nullptr),
#else
nullptr,
#endif
std::free
);
std::string r = own != nullptr ? own.get() : typeid(TR).name();
if (std::is_const<TR>::value)
r += " const";
if (std::is_volatile<TR>::value)
r += " volatile";
if (std::is_lvalue_reference<T>::value)
r += "&";
else if (std::is_rvalue_reference<T>::value)
r += "&&";
return r;
}
//used:
int main()
{
auto ci = 0;
std::cout << type_name<decltype(ci)>()<< '\n';
return 0;
}
//output:
int
e está certo mesmo... se usar o 'const int' em vez do 'auto', iremos ter o 'const int'.
este código foi testado no site: https://www.onlinegdb.com/online_c++_compiler
penso que é compatível com GCC.
muito obrigado