|
NAMEllvm-cxxmap - Mangled name remapping toolSYNOPSISllvm-cxxmap [options] symbol-file-1 symbol-file-2DESCRIPTIONThe llvm-cxxmap tool performs fuzzy matching of C++ mangled names, based on a file describing name components that should be considered equivalent.The symbol files should contain a list of C++ mangled names (one per line). Blank lines and lines starting with # are ignored. The output is a list of pairs of equivalent symbols, one per line, of the form <symbol-1> <symbol-2> where <symbol-1> is a symbol from symbol-file-1 and <symbol-2> is a symbol from symbol-file-2. Mappings for which the two symbols are identical are omitted. OPTIONS
REMAPPING FILEThe remapping file is a text file containing lines of the formfragmentkind fragment1 fragment2 where fragmentkind is one of name, type, or encoding, indicating whether the following mangled name fragments are <name>s, <type>s, or <encoding>s, respectively. Blank lines and lines starting with # are ignored. Unmangled C names can be expressed as an encoding that is a (length-prefixed) <source-name>: # C function "void foo_bar()" is remapped to C++ function "void foo::bar()". encoding 7foo_bar _Z3foo3barv For convenience, built-in <substitution>s such as St and Ss are accepted as <name>s (even though they technically are not <name>s). For example, to specify that absl::string_view and std::string_view should be treated as equivalent, the following remapping file could be used: # absl::string_view is considered equivalent to std::string_view type N4absl11string_viewE St17basic_string_viewIcSt11char_traitsIcEE # std:: might be std::__1:: in libc++ or std::__cxx11:: in libstdc++ name St St3__1 name St St7__cxx11 NOTE: Symbol remapping is currently only supported for C++
mangled names following the Itanium C++ ABI mangling scheme. This covers all
C++ targets supported by Clang other than Windows targets.
AUTHORMaintained by the LLVM Team (https://llvm.org/).COPYRIGHT2003-2022, LLVM Project
Visit the GSP FreeBSD Man Page Interface. |