D ABI parameters#

void TARGET_D_CPU_VERSIONS(void)#

Declare all environmental version identifiers relating to the target CPU using the function builtin_version, which takes a string representing the name of the version. Version identifiers predefined by this hook apply to all modules that are being compiled and imported.

void TARGET_D_OS_VERSIONS(void)#

Similarly to TARGET_D_CPU_VERSIONS, but is used for versions relating to the target operating system.

void TARGET_D_REGISTER_CPU_TARGET_INFO(void)#

Register all target information keys relating to the target CPU using the function d_add_target_info_handlers, which takes a struct d_target_info_spec (defined in d/d-target.h). The keys added by this hook are made available at compile time by the __traits(getTargetInfo) extension, the result is an expression describing the requested target information.

void TARGET_D_REGISTER_OS_TARGET_INFO(void)#

Same as TARGET_D_CPU_TARGET_INFO, but is used for keys relating to the target operating system.

const char *TARGET_D_MINFO_SECTION#

Contains the name of the section in which module info references should be placed. By default, the compiler puts all module info symbols in the "minfo" section. Define this macro to override the string if a different section name should be used. This section is expected to be bracketed by two symbols TARGET_D_MINFO_SECTION_START and TARGET_D_MINFO_SECTION_END to indicate the start and end address of the section, so that the runtime library can collect all modules for each loaded shared library and executable. Setting the value to NULL disables the use of sections for storing module info altogether.

const char *TARGET_D_MINFO_SECTION_START#

If TARGET_D_MINFO_SECTION is defined, then this must also be defined as the name of the symbol indicating the start address of the module info section

const char *TARGET_D_MINFO_SECTION_END#

If TARGET_D_MINFO_SECTION is defined, then this must also be defined as the name of the symbol indicating the end address of the module info section

bool TARGET_D_HAS_STDCALL_CONVENTION(unsigned int *link_system, unsigned int *link_windows)#

Returns true if the target supports the stdcall calling convention. The hook should also set link_system to 1 if the stdcall attribute should be applied to functions with extern(System) linkage, and link_windows to 1 to apply stdcall to functions with extern(Windows) linkage.

bool TARGET_D_TEMPLATES_ALWAYS_COMDAT#

This flag is true if instantiated functions and variables are always COMDAT if they have external linkage. If this flag is false, then instantiated decls will be emitted as weak symbols. The default is false.