========
|
ABI tags
|
========
|
|
Introduction
|
============
|
|
This text tries to describe gcc semantic for mangling "abi_tag" attributes
|
described in https://gcc.gnu.org/onlinedocs/gcc/C_002b_002b-Attributes.html
|
|
There is no guarantee the following rules are correct, complete or make sense
|
in any way as they were determined empirically by experiments with gcc5.
|
|
Declaration
|
===========
|
|
ABI tags are declared in an abi_tag attribute and can be applied to a
|
function, variable, class or inline namespace declaration. The attribute takes
|
one or more strings (called tags); the order does not matter.
|
|
See https://gcc.gnu.org/onlinedocs/gcc/C_002b_002b-Attributes.html for
|
details.
|
|
Tags on an inline namespace are called "implicit tags", all other tags are
|
"explicit tags".
|
|
Mangling
|
========
|
|
All tags that are "active" on an <unqualified-name> are emitted after the
|
<unqualified-name>, before <template-args> or <discriminator>, and are part of
|
the same <substitution> the <unqualified-name> is.
|
|
They are mangled as:
|
|
.. code-block:: none
|
|
<abi-tags> ::= <abi-tag>* # sort by name
|
<abi-tag> ::= B <tag source-name>
|
|
Example:
|
|
.. code-block:: c++
|
|
__attribute__((abi_tag("test")))
|
void Func();
|
// gets mangled as: _Z4FuncB4testv (prettified as `Func[abi:test]()`)
|
|
Active tags
|
===========
|
|
A namespace does not have any active tags. For types (class / struct / union /
|
enum), the explicit tags are the active tags.
|
|
For variables and functions, the active tags are the explicit tags plus any
|
"required tags" which are not in the "available tags" set:
|
|
.. code-block:: none
|
|
derived-tags := (required-tags - available-tags)
|
active-tags := explicit-tags + derived-tags
|
|
Required tags for a function
|
============================
|
|
If a function is used as a local scope for another name, and is part of
|
another function as local scope, it doesn't have any required tags.
|
|
If a function is used as a local scope for a guard variable name, it doesn't
|
have any required tags.
|
|
Otherwise the function requires any implicit or explicit tag used in the name
|
for the return type.
|
|
Example:
|
|
.. code-block:: c++
|
|
namespace A {
|
inline namespace B __attribute__((abi_tag)) {
|
struct C { int x; };
|
}
|
}
|
|
A::C foo(); // gets mangled as: _Z3fooB1Bv (prettified as `foo[abi:B]()`)
|
|
Required tags for a variable
|
============================
|
|
A variable requires any implicit or explicit tag used in its type.
|
|
Available tags
|
==============
|
|
All tags used in the prefix and in the template arguments for a name are
|
available. Also, for functions, all tags from the <bare-function-type>
|
(which might include the return type for template functions) are available.
|
|
For <local-name>s all active tags used in the local part (<function-
|
encoding>) are available, but not implicit tags which were not active.
|
|
Implicit and explicit tags used in the <unqualified-name> for a function (as
|
in the type of a cast operator) are NOT available.
|
|
Example: a cast operator to std::string (which is
|
std::__cxx11::basic_string<...>) will use 'cxx11' as an active tag, as it is
|
required from the return type `std::string` but not available.
|