======== 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 are emitted after the , before or , and are part of the same the is. They are mangled as: .. code-block:: none ::= * # sort by name ::= B 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 (which might include the return type for template functions) are available. For s all active tags used in the local part () are available, but not implicit tags which were not active. Implicit and explicit tags used in the 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.