Macros#
- ADD_PRIMITIVE_HANDLER
- Macro to add other [almost identical] variants of the add() and operator+=() functions. 
- CARBLOCAL_COMPILER_BARRIER
- Macro to creaete a memory barrier in an operation. 
- CARBLOCAL_STDSTRING_CONSTEXPR
- CARBLOCAL_UNION_CONSTEXPR
- CARBLOCAL_USE_BUILTIN_INT128
- Pretend we have builtin for documentation builds. 
- CARBONITE_MAJOR
- Defines the current major version of the Carbonite framework. 
- CARBONITE_MINOR
- Defines the current minor version of the Carbonite framework. 
- CARB_AARCH64
- A macro defined as - 1if compilation is targeting the AArch64 platform;- 0otherwise. May not be overridden on the command line or by defining before including this file. Set to- 1if- __aarch64__is defined,- 0if- __x86_64__or- _M_X64are defined, and left undefined otherwise.
- CARB_ABI
- Defined as - __cdeclon Windows and an empty define on Linux. Used to explicitly state ABI calling convention for API functions. Update: Deprecated. Define left for compatibility.
- CARB_ALIGN
- Aligns a number or pointer to the next multiple of a provided alignment. 
- CARB_ALIGNED_SIZE
- Aligns a size to the given alignment. 
- CARB_ALIGN_AS
- Defined as - alignas(T).
- CARB_ALIGN_OF
- Returns the required alignment of a type. 
- CARB_ALLOCA
- This is a wrapper for the platform-specific call to the non-standard but almost universal alloca() function. 
- CARB_ALWAYS_INLINE
- Instructs the compiler to force inline of the decorated function. 
- CARB_ANONYMOUS_VAR
- A helper macro that appends a number to the given name to create a unique name. 
- CARB_ARCH_NAME
- The name of the current architecture as a string. 
- CARB_ASAN_ENABLED
- A macro defined as - 1if the toolchain is building the current file with- -fsanitize=address, that is, if- __SANITIZE_ADDRESS__is defined;- 0otherwise. May be overridden by defining a different value before including this file or by specifying a different value on the compiler command line. Microsoft Visual Studio supports address sanitizer starting with 2019 (v16.9) by specifying- /fsanitize=addresson the compiler command line. See https://learn.microsoft.com/en-us/cpp/sanitizers/asan?view=msvc-160 .
- CARB_ASSERT
- Performs an assertion check, by default for debug builds only. 
- CARB_ASSERT_ASYNC
- A macro that is used to assert that a scope is running in task context in debug builds only. 
- CARB_ASSERT_ENABLED
- Indicates whether asserts are enabled. May be overridden by defining this before including this file. By default, is set to - CARB_DEBUG. If this is overridden to a non-zero value and- CARB_ASSERTis not defined,- CARB_ASSERTwill receive the default implementation. See.
- CARB_ASSERT_GLOBALS
- Placeholder macro for any work that needs to be done at the global level for any IAssert related functionality. 
- CARB_ASSERT_INTEROP_SAFE
- A macro to ensure interop safety by assertion. 
- CARB_ASSERT_MEMBERS_MATCH
- A helper to determine if member - A.amatches the offset and size of- B.b, causing a static assert if unmatched.
- CARB_ASSERT_STRUCTS_MATCH
- A helper to determine if the size and alignment of two given structures match, causing a static assert if unmatched. 
- CARB_ASSET
- Registers an asset type. 
- CARB_ASSUME
- A macro used to help the compiler optimize the code better, by assuming that the condition - bis true.
- CARB_ASYNC
- A macro that can be used to mark a function as async, that is, it always executes in the context of a task. 
- CARB_ATTRIBUTE
- GCC only, defined as - __attribute__((__VA_ARGS__)); ignored on non-GCC compilers.
- CARB_BINDINGS
- Declare a compilation unit as script language bindings. 
- CARB_BINDINGS_EX
- Declare a compilation unit as script language bindings. 
- CARB_BREAK_POINT
- Used to break into the debugger. 
- CARB_CACHELINE_ALIGN
- Defined as - CARB_ALIGN_AS(CARB_CACHELINE_SIZE).
- CARB_CACHELINE_SIZE
- Minimum offset between two objects to avoid false sharing, i.e. cache line size. If C++17 is not supported, falls back to the default value of 64 bytes. 
- CARB_CHECK
- Performs a runtime check assertion, by default for both debug and release builds. 
- CARB_CHECK_ASYNC
- A macro that is used to assert that a scope is running in task context in debug and checked builds. 
- CARB_CHECK_ENABLED
- Indicates whether runtime checking is enabled. May be overridden by defining this before including this file. If not overridden, this is set to - 1always. If this is a non-zero value and- CARB_CHECKis not defined,- CARB_CHECKwill receive the default implementation. See.
- CARB_CLAMP
- A macro the returns the largest of two values. 
- CARB_CLANG_ONLY
- Clang only, defined as - __VA_ARGS__; ignored on non-Clang compilers including GCC.
- CARB_COMPILER_GNUC
- A macro defined as - 1if compilation is using GNU C Compiler (GCC), that is, if- _MSC_VERis not defined but- __GNUC__is defined. May be overridden by defining a different value before including this file or by specifying a different value on the compiler command line, however, only one of- CARB_COMPILER_MSCand- CARB_COMPILER_GNUCmust be set to- 1; the other macro(s) must be set to- 0.
- CARB_COMPILER_MSC
- A macro defined as - 1if compilation is using Microsoft Visual C++, that is, if- _MSC_VERis defined. May be overridden by defining a different value before including this file or by specifying a different value on the compiler command line, however, only one of- CARB_COMPILER_MSCand- CARB_COMPILER_GNUCmust be set to- 1; the other macro(s) must be set to- 0.
- CARB_CONSTEVAL
- A macro to mark a function as compile-time-only function. 
- CARB_COUNTOF
- Returns the count of an array as a - size_tat compile time.
- CARB_COUNTOF32
- Returns the count of an array as a - uint32_tat compile time.
- CARB_CPLUSPLUS
- Toolchain-independent way to check the C++ standard / version. On windows, the value of __cplusplus is unreliable - it is defined if using C++, but is set to 199711L, regardless of what /std:c++XX is used (unless you enable a special option, /Zc:__cplusplus): https://learn.microsoft.com/en-us/cpp/build/reference/zc-cplusplus It is not a drop-in replacement for __cplusplus, as it is always defined (but may be 0) ie,. 
- CARB_CPP17_CONSTEXPR
- Defined as - constexprbecause the current compiler supports C++17.
- CARB_CPP20_CONSTEXPR
- Defined as - constexprif the current compiler supports C++20; empty otherwise.
- CARB_CPP20_LIKELY
- Defined as - [[likely]]if the current compiler supports C++20 (that is, CARB_HAS_CPP20 is non-zero) and the compiler reports the presence of the- likelyattributes.
- CARB_CPP20_UNLIKELY
- Defined as - [[unlikely]]if the current compiler supports C++20 (that is, CARB_HAS_CPP20 is non-zero) and the compiler reports the presence of the- unlikelyattributes.
- CARB_CPUID_H_INCLUDED
- CARB_CRASH_REPORTER_GLOBALS
- Defines global symbols specifically related to the crash reporter. 
- CARB_DEBUG
- A macro indicating whether the current compilation unit is built in debug mode. Always defined as either 0 or 1. Can be overridden by defining before this file is included or by passing on the compiler command line. Defined as - 0if- NDEBUGis defined;- 1otherwise.
- CARB_DECLSPEC
- MSVC only, defined as - __declspec(__VA_ARGS__); ignored on non-MSVC compilers.
- CARB_DEFAULT_INITIALIZERS
- Plugin helper macro to define boiler-plate code to register and unregister the plugin with various other components in the system (e.g. logging channels, profiler, localization, etc.). 
- CARB_DEPAREN
- De-parenthesize the contents of - pack_.- CARB_DEPAREN((x, y))becomes- x, y. An unparenthesized pack will cause cause a compilation failure; e.g.:- CARB_DEPAREN(foo)will not work, but- CARB_DEPAREN((foo))will.
- CARB_DEPRECATED
- Declares a function as deprecated. 
- CARB_DEPRECATED_IF
- Conditionally declares a function as deprecated based on a compile-time condition. 
- CARB_DETAIL_DEFINE_DEFERRED_LOAD
- Create a "deferred loader" function. 
- CARB_DIVIDE_CEIL
- Divides size by divisor and returns the closest integer greater than or equal to the division result. 
- CARB_DOC_CONSTEXPR
- Macro to work around Exhale tripping over - constexprsometimes and reporting things like:- Invalid C++ declaration: Expected identifier in nested name, got keyword: static
- CARB_DOC_ONLY
- Conditionally includes text only when documenting (i.e. when - DOXYGEN_BUILDis defined).
- CARB_DYNAMICLINK
- Conditional (import/export) dynamic linking. 
- CARB_EVENTS_TYPE_FROM_STR
- Compile-time conversion of string to carb::events::EventType . 
- CARB_EXCEPTIONS_ENABLED
- Indicates whether exceptions are enabled for the current compilation unit. Value depends on parameters passed to the compiler. 
- CARB_EXECUTABLE_EXTENSION
- The default executable file extension for the current platform. 
- CARB_EXECUTABLE_EXTENSION_WIDE
- UTF-16 version of the dynamic library extension. 
- CARB_EXPORT
- Grants a function external linkage in a dynamic library or executable. 
- CARB_EXPORTS
- Instructs CARB_DYNAMICLINK to export instead of import. 
- CARB_EXTERN_C
- Defined as - extern "C"for C++ compilation, that is, when- __cplusplusis defined; empty define otherwise.
- CARB_FAKE_PRINTF
- A printf that will never be executed but allows the compiler to test if there are format errors. 
- CARB_FALLTHROUGH
- Defined as - [[fallthrough]]because the current compiler supports C++17.
- CARB_FATAL_UNLESS
- Terminates the application if a check fails. 
- CARB_FATAL_UNLESS_ASYNC
- A macro that is used to assert that a scope is running in task context. 
- CARB_FATAL_UNLESS_ENABLED
- Indicates whether fatal condition checks are enabled. Always - 1since fatal condition checks are always enabled. See.
- CARB_FILE_DEPRECATED
- Declares a file as deprecated. 
- CARB_FLOAT_MAX
- The maximum value that can be represented by - float.
- CARB_FORMATTED
- Formats a string as if by vsnprintf and invokes a callable with the result. 
- CARB_FORMATTED_N
- Formats a string as if by vsnprintf and invokes a callable with the result and the length. 
- CARB_FORMATTED_N_SIZE
- Formats a string as if by vsnprintf and invokes a callable with the result and the length. 
- CARB_FORMATTED_SIZE
- Formats a string as if by vsnprintf and invokes a callable with the result. 
- CARB_FRAMEWORK_GLOBALS
- Defines global variables for use by Carbonite. Call this macro from the global namespace. 
- CARB_FREE
- Frees memory previously allocated using CARB_MALLOC() . 
- CARB_GLOBALS
- Defines global variables of the framework and built-in plugins. 
- CARB_GLOBALS_EX
- Defines global variables of the framework and built-in plugins. 
- CARB_GNUC_ONLY
- GCC only, defined as - gnuc_only_block; ignored on non-GCC compilers including Clang.
- CARB_HARDWARE_PAUSE
- Instructs the underlying hardware to idle the CPU pipelines and reduce the penalty from memory order violations. 
- CARB_HASH_STRING
- Computes a literal string hash at compile time. 
- CARB_HASH_TYPE
- Syntactic sugar for - CARB_HASH_STRING(CARB_STRINGIFY(T)).
- CARB_HAS_CPP14
- Always defined as - 1because the current compiler supports C++14.
- CARB_HAS_CPP17
- Always defined as - 1because the current compiler supports C++17.
- CARB_HAS_CPP20
- Defined as - 1if the current compiler supports C++20;- 0otherwise.
- CARB_HAS_RTTI
- Indicates whether RTTI is enabled. 
- CARB_HEXVERSION
- A macro to construct a hex-version. 
- CARB_HIDDEN
- Syntactic sugar for - CARB_ATTRIBUTE(visibility("hidden")); ignored on compilers other than GCC.
- CARB_IDENTITY
- Return exactly the arguments. This is useful for expansion of the tokens. 
- CARB_IF_NOT_TSAN
- Macro declaring code that should be instantiated if TSan is NOT enabled. 
- CARB_IF_TSAN
- Macro declaring code that should be instantiated if TSan is enabled. 
- CARB_IGNOREWARNING_CLANG
- For Clang only, disables a specific compiler warning for the current compilation warning configuration. Defined as - _Pragma("GCC diagnostic ignored <warning>")for Clang only; ignored by other compilers.
- CARB_IGNOREWARNING_CLANG_POP
- For Clang only, pops the compilation warning configuration previously pushed with CARB_IGNOREWARNING_CLANG_PUSH , overwriting the current state. Defined as - _Pragma("GCC diagnostic pop")for Clang only; ignored by other compilers.
- CARB_IGNOREWARNING_CLANG_PUSH
- For Clang only, pushes the current compilation warning configuration. Defined as - _Pragma("GCC diagnostic push")for Clang only; ignored by other compilers.
- CARB_IGNOREWARNING_CLANG_WITH_PUSH
- Syntactic sugar for CARB_IGNOREWARNING_CLANG_PUSH followed by CARB_IGNOREWARNING_CLANG . 
- CARB_IGNOREWARNING_GNUC
- For GCC only, disables a specific compiler warning for the current compilation warning configuration. Defined as - _Pragma("GCC diagnostic ignored <warning>")for GCC only; ignored by other compilers.
- CARB_IGNOREWARNING_GNUC_POP
- For GCC only, pops the compilation warning configuration previously pushed with CARB_IGNOREWARNING_GNUC_PUSH , overwriting the current state. Defined as - _Pragma("GCC diagnostic pop")for GCC only; ignored by other compilers.
- CARB_IGNOREWARNING_GNUC_PUSH
- For GCC only, pushes the current compilation warning configuration. Defined as - _Pragma("GCC diagnostic push")for GCC only; ignored by other compilers.
- CARB_IGNOREWARNING_GNUC_WITH_PUSH
- Syntactic sugar for CARB_IGNOREWARNING_GNUC_PUSH followed by CARB_IGNOREWARNING_GNUC . 
- CARB_IGNOREWARNING_MSC
- For MSVC only, disables a specific compiler warning for the current compilation warning configuration. Defined as - __pragma(warning(disable : <w>))for MSVC only; ignored by other compilers.
- CARB_IGNOREWARNING_MSC_POP
- For MSVC only, pops the compilation warning configuration previously pushed with CARB_IGNOREWARNING_MSC_PUSH , overwriting the current state. Defined as - __pragma(warning(pop))for MSVC only; ignored by other compilers.
- CARB_IGNOREWARNING_MSC_PUSH
- For MSVC only, pushes the current compilation warning configuration. Defined as - __pragma(warning(push))for MSVC only; ignored by other compilers.
- CARB_IGNOREWARNING_MSC_WITH_PUSH
- Syntactic sugar for CARB_IGNOREWARNING_MSC_PUSH followed by CARB_IGNOREWARNING_MSC . 
- CARB_IGNORE_DEPRECATION_BEGIN
- Begins a code block where deprecation warnings are suppressed. Must be paired with CARB_IGNORE_DEPRECATION_END. 
- CARB_IGNORE_DEPRECATION_END
- Ends a code block where deprecation warnings are suppressed. Must be paired with CARB_IGNORE_DEPRECATION_BEGIN. 
- CARB_IMPLOPTIONAL
- CARB_IMPORT
- Imports a function with external linkage from a shared object or DLL. 
- CARB_INCLUDES_MEMBER
- Returns whether it is safe to access a member of a versioned struct. 
- CARB_INCLUDE_PURIFY_TEST
- A macro that is used only for public includes to define a function which will instantiate templates. 
- CARB_IOBJECT_IMPL
- Helper macro to implement default behavior of carb::IObject interface functions IObject::addRef() and IObject::release(). 
- CARB_IS_ASYNC
- Helper macro that results in a boolean expression which is - trueif the current thread is running in task context.
- CARB_IS_SAME_SDK_VERSION
- Tests whether the Carbonite SDK headers match the version of used to build the framework. 
- CARB_JOIN
- A macro that joins two parts to create one symbol allowing one or more parameters to be a macro, as if by the - ##preprocessor operator. Example:- CARB_JOIN(test, __LINE__)on line 579 produces- test579.
- CARB_LIBRARY_EXTENSION
- The default library file extension for the current platform. 
- CARB_LIBRARY_EXTENSION_WIDE
- UTF-16 version of the dynamic library extension. 
- CARB_LIBRARY_GET_LITERAL_NAME
- A macro to build a library file's name as a string literal. 
- CARB_LIBRARY_PREFIX
- Retrieves the default library file prefix for the current platform. 
- CARB_LIKELY
- If the current compiler is GCC, defined as - __builtin_expect(!!(<expr>), 1). Otherwise, defined as- (!!(<expr>)).
- CARB_LIKELY_IF
- A helper for using both the CARB_LIKELY macro as well as the CARB_CPP20_LIKELY macro. 
- CARB_LOCALIZATION_GLOBALS
- Placeholder for global scope work that needs to be done for localization. 
- CARB_LOCALIZE
- Look up a string from the localization database for the current plugin. 
- CARB_LOG
- Logging macro if the level is dynamic. 
- CARB_LOG_ERROR
- Logging macro for static log level. 
- CARB_LOG_ERROR_ONCE
- Single-time logging macro for static log level. 
- CARB_LOG_FATAL
- Logging macro for static log level. 
- CARB_LOG_FATAL_ONCE
- Single-time logging macro for static log level. 
- CARB_LOG_GLOBALS
- Placeholder macro for any globals that must be declared for the logging system. 
- CARB_LOG_INFO
- Logging macro for static log level. 
- CARB_LOG_INFO_ONCE
- Single-time logging macro for static log level. 
- CARB_LOG_ONCE
- Single-time logging macro if the level is dynamic. 
- CARB_LOG_VERBOSE
- Logging macro for static log level. 
- CARB_LOG_VERBOSE_ONCE
- Single-time logging macro for static log level. 
- CARB_LOG_WARN
- Logging macro for static log level. 
- CARB_LOG_WARN_ONCE
- Single-time logging macro for static log level. 
- CARB_MACOS_UNIMPLEMENTED
- A macro to mark placeholder functions on MacOS while the porting effort is in progress. 
- CARB_MAKE_FOURCC
- A macro for producing a carb::FourCC value from four characters. 
- CARB_MALLOC
- Allocates memory from the heap. 
- CARB_MAX
- A macro the returns the largest of two values. 
- CARB_MAYBE_ASYNC
- A macro that can be used to mark a function as possibly async, that is, it may execute in the context of a task. 
- CARB_MAYBE_UNUSED
- Defined as - [[maybe_unused]]because the current compiler supports C++17.
- CARB_MIN
- A macro that returns the least of two values. 
- CARB_MSC_ONLY
- MSVC only, defined as - __VA_ARGS__; ignored on non-MSVC compilers.
- CARB_NAME_THREAD
- Records the name of a thread. 
- CARB_NODISCARD
- Defined as - [[nodiscard]]because the current compiler supports C++17.
- CARB_NODISCARD_MSG
- Defined as - [[nodiscard(msg)]]if the current compiler supports C++20; falls back to- [[nodiscard]]without the message pre-C++20.
- CARB_NODISCARD_TYPE
- Defined as - [[nodiscard]]because the current compiler supports C++17.
- CARB_NODISCARD_TYPE_MSG
- Defined as - [[nodiscard(msg)]]if the current compiler supports C++20; falls back to- CARB_NODISCARD_TYPEwithout the message pre-C++20.
- CARB_NOEXCEPT
- Declares that a function will not throw any exceptions. 
- CARB_NOINLINE
- A macro that declares that a function may not be inlined. 
- CARB_NOT_CLANG
- Only non-Clang compilers including GCC, defined as - __VA_ARGS__; ignored on Clang.
- CARB_NOT_GNUC
- Only non-GCC compilers including Clang, defined as - __VA_ARGS__; ignored on GCC.
- CARB_NOT_MSC
- Only non-MSVC compilers, defined as - __VA_ARGS__; ignored on MSVC.
- CARB_NO_DOC
- Declares a value or statement in a way that prevents Doxygen and Sphinx from getting confused about matching symbols. There seems to be a bug in Sphinx that prevents at least templated symbols from being matched to the ones generated by Doxygen when keywords such as - decltypeare used. This is effectively the opposite operation as CARB_DOC_ONLY() .
- CARB_NO_OPTIMIZE_GNUC_CLANG
- Disables optimizations for the function that is tagged with this attribute. This only affects the single function that it tags. Optimizations will be restored to the previous settings for the translation unit outside of the tagged function. 
- CARB_NO_UNIQUE_ADDRESS
- Defined as - [[no_unique_address]]if the current compiler supports C++20; empty otherwise.
- CARB_OFFSETOF
- Returns the offset of a member of a class at compile time. 
- CARB_OFFSETOF2
- Returns the offset of a member - mof a class- tat compile time.
- CARB_OPTIMIZE_OFF_MSC
- Turns optimizations off at the function level until a CARB_OPTIMIZE_ON_MSC() call is seen. This must be called outside of the body of any function and will remain in effect until either a CARB_OPTIMIZE_ON_MSC() call is seen or the end of the translation unit. This unfortunately needs to be a separate set of macros versus the one for GCC and Clang due to the different style of disabling and enabling optimizations under the MSC compiler. 
- CARB_OPTIMIZE_ON_MSC
- Restores previous optimizations that were temporarily disable due to an earlier call to CARB_OPTIMIZE_OFF_MSC() . This must be called outside the body of any function. If this call is not made, the previous optimization state will remain until the end of the current translation unit. 
- CARB_PLATFORM_LINUX
- A macro defined as - 1if compilation is targeting Linux;- 0otherwise. Exactly one of the- CARB_PLATFORM_*macros will be set to- 1. May be overridden by defining before this file is included or by passing on the compiler command line. By default, set to- 1if- _WIN32is not defined and- __linux__is defined.
- CARB_PLATFORM_MACOS
- A macro defined as - 1if compilation is targeting Mac OS;- 0otherwise. Exactly one of the- CARB_PLATFORM_*macros will be set to- 1. May be overridden by defining before this file is included or by passing on the compiler command line. By default, set to- 1if- _WIN32and- __linux__are not defined and- __APPLE__is defined.
- CARB_PLATFORM_NAME
- The name of the current platform as a string. 
- CARB_PLATFORM_WINDOWS
- A macro defined as - 1if compilation is targeting Windows;- 0otherwise. Exactly one of the- CARB_PLATFORM_*macros will be set to- 1. May be overridden by defining before this file is included or by passing on the compiler command line. By default, set to- 1if- _WIN32is defined.
- CARB_PLUGIN_IMPL
- Main macro to declare a plugin implementation where multiple interface versions are not required. 
- CARB_PLUGIN_IMPL_DEPS
- Macros to declare a plugin implementation dependencies. 
- CARB_PLUGIN_IMPL_EX
- Main macro to declare a plugin implementation where multiple interface versions are required. 
- CARB_PLUGIN_IMPL_MINIMAL
- Macro to declare a "minimal" plugin. 
- CARB_PLUGIN_IMPL_NO_DEPS
- Macro to declare a plugin without dependencies. 
- CARB_PLUGIN_INTERFACE
- Macro to declare a - structas a Carbonite interface.
- CARB_PLUGIN_INTERFACE_EX
- Macro to declare a - structas a Carbonite interface that allows for a different current version than latest.
- CARB_POSIX
- This is set to - _POSIX_VERSIONplatforms that are mostly-compliant with POSIX.
- CARB_PRAGMA
- Generic pragma, only to be used for pragmas that are the same on all supported compilers. 
- CARB_PRAGMA_GNUC
- GCC only, defined as - _Pragma(__VA_ARGS__); ignored on non-GCC compilers.
- CARB_PRAGMA_MSC
- MSVC only, defined as - __pragma(__VA_ARGS__); ignored on non-MSVC compilers.
- CARB_PREFETCH
- Attempts to prefetch from memory using a compiler intrinsic. 
- CARB_PRETTY_FUNCTION
- Acts as a - char[]with the current full function signature.
- CARB_PREVENT_COPY
- A macro that deletes the copy-construct and copy-assign functions for the given classname. 
- CARB_PREVENT_COPY_AND_MOVE
- Syntactic sugar for both CARB_PREVENT_COPY and CARB_PREVENT_MOVE . 
- CARB_PREVENT_MOVE
- A macro that deletes the move-construct and move-assign functions for the given classname. 
- CARB_PRINTF_FUNCTION
- Requests that the compiler validate any variadic arguments as printf-style format specifiers, if supported by the compiler. Causes a compilation error if the printf-style format specifier doesn't match the given variadic types. 
- CARB_PROFILER_GLOBALS
- Placeholder macro for any work that needs to be done at the global scope for the profiler. 
- CARB_PROFILE_ALLOC
- Records an allocation event for profilers that support them. 
- CARB_PROFILE_ALLOC_NAMED
- Records an allocation event for a named memory pool for profilers that support them. 
- CARB_PROFILE_BEGIN
- Marks the beginning of a profiling zone. 
- CARB_PROFILE_CALIBRATE_GPU_CONTEXT
- Submit context calibration information that allows correlating CPU and GPU clocks. 
- CARB_PROFILE_CREATE_GPU_CONTEXT
- Create a new GPU profiling context that allows injecting timestamps coming from a GPU in a deferred manner. 
- CARB_PROFILE_DECLARE_CHANNEL
- Declares a channel that can be used with the profiler. 
- CARB_PROFILE_DESTROY_GPU_CONTEXT
- Destroy a previously created GPU Context. 
- CARB_PROFILE_END
- Marks the end of a profiling zone previously started with CARB_PROFILE_BEGIN() . 
- CARB_PROFILE_EVENT
- Records an instant event on a thread's timeline at the current time. 
- CARB_PROFILE_EXTERN_CHANNEL
- References a channel declared in another compilation unit. 
- CARB_PROFILE_FLOW_BEGIN
- Records the beginning of a flow event on the timeline at the current time for the current thread. 
- CARB_PROFILE_FLOW_END
- Records the end of a flow event on the timeline at the current time for the current thread. 
- CARB_PROFILE_FRAME
- Inserts a frame marker for the calling thread in the profiling output, for profilers that support frame markers. 
- CARB_PROFILE_FRAME_WITH_IMAGE
- Inserts an anonymous frame marker along with an RGBA image (for profilers that support it). 
- CARB_PROFILE_FREE
- Records a free event for profilers that support them. 
- CARB_PROFILE_FREE_NAMED
- Records a free event for a named memory pool for profilers that support them. 
- CARB_PROFILE_FUNCTION
- A helper for CARB_PROFILE_ZONE() that automatically uses the function name as from - CARB_PRETTY_FUNCTION.
- CARB_PROFILE_GPU_QUERY_BEGIN
- Record the beginning of a new GPU timestamp query. 
- CARB_PROFILE_GPU_QUERY_END
- Record the end of a new GPU timestamp query. 
- CARB_PROFILE_GPU_SET_QUERY_VALUE
- Set the value we've received from the GPU for a query (begin or end) we've issued in the past. 
- CARB_PROFILE_LOCKABLE_CREATE
- Create a lockable context which we can use to tag lock operation. 
- CARB_PROFILE_LOCKABLE_DESTROY
- Destroy a lockable context. 
- CARB_PROFILE_LOCKABLE_OPERATION
- Records a lockable operation on a thread's timeline at the current time. 
- CARB_PROFILE_REGISTER_STRING
- Registers a static string for use with the profiler. 
- CARB_PROFILE_SET_CAPTURE_MASK
- A helper to set the capture mask. 
- CARB_PROFILE_SHUTDOWN
- Shuts down the profiler that has been registered with carb::profiler::registerProfilerForClient() and previously started with CARB_PROFILE_STARTUP() . 
- CARB_PROFILE_STARTUP
- Starts the profiler that has been registered with carb::profiler::registerProfilerForClient() . 
- CARB_PROFILE_VALUE
- Writes a named numeric value to the profiling output for profilers that support them. 
- CARB_PROFILE_ZONE
- Creates a profiling zone over a scope. 
- CARB_PROFILING
- When set to a non-zero value, profiling macros in include/carb/profiler/Profile.h will report to the profiler; otherwise the profiling macros have no effect. Always set to - 1by default, but may be overridden by defining a different value before including this file or by specifying a different value on the compiler command line.
- CARB_RELEASE_ASSERT
- Performs a runtime assertion, by default for both debug and release builds. 
- CARB_RELEASE_ASSERT_ASYNC
- A macro that is used to assert that a scope is running in task context in debug and release builds. 
- CARB_RELEASE_ASSERT_ENABLED
- Indicates whether release asserts are enabled. May be overridden by defining this before including this file. If not overridden, this is set to - 1always. If this is a non-zero value and- CARB_RELEASE_ASSERTis not defined,- CARB_RELEASE_ASSERTwill receive the default implementation. See.
- CARB_REQUIRE_LINKED
- Changes how the - carbReallocatesymbol is acquired.
- CARB_RESULT_USE_OMNI_RESULT_GEN
- Undocumented. 
- CARB_RETRY_EINTR
- A macro to retry operations if they return -1 and errno is set to EINTR. 
- CARB_ROUNDUP
- Rounds a given value to the next highest multiple of another given value. 
- CARB_SDK_VERSION
- Version string for this SDK build. This string is also returned by carbGetSdkVersion(). This value can be passed to CARB_IS_SAME_SDK_VERSION() to verify that the loaded version of the Carbonite framework library matches the headers that are in use. 
- CARB_STACK_ALLOC
- Attempts to allocate an array of the given type on the stack. 
- CARB_STATE
- Macro to mark static and global variables to keep them when plugin is hot-reloaded. 
- CARB_STRINGIFY
- Turns a name into a string, resolving macros (i.e. - CARB_STRINGIFY(__LINE__)on line 815 will produce- "815").
- CARB_STRNCASECMP
- compare two strings ignoring case. 
- CARB_TEGRA
- A macro defined as - 1if compilation is targeting the Tegra platform. By default set to- 1only if- __aarch64__and- __LINARO_RELEASE__are defined;- 0otherwise. May be overridden by defining a different value before including this file or by specifying a different value on the compiler command line.
- CARB_TOKENS_DEPRECATED
- Marks a function or type as deprecated with a custom message for the tokens module. 
- CARB_TOKENS_DEPRECATIONS
- Control macro for dictionary deprecations Set CARB_TOKENS_DEPRECATIONS to 0 before including this header to disable deprecation warnings. 
- CARB_TOOLCHAIN_CLANG
- A macro defined as - 1if a Clang-infrastructure toolchain is building the current file, that is, if- __clang__is defined;- 0if not. May be overridden by defining a different value before including this file or by specifying a different value on the compiler command line.
- CARB_TSAN_ENABLED
- A macro defined as - 1if the toolchain is building the current file with- -fsanitize=thread, that is, if- __SANITIZE_THREAD__is defined;- 0otherwise. May be overridden by defining a different value before including this file or by specifying a different value on the compiler command line. Microsoft Visual Studio does not support thread sanitizer.
- CARB_UINT16_MAX
- The maximum value that can be represented by - uint16_t.
- CARB_UINT32_MAX
- The maximum value that can be represented by - uint32_t.
- CARB_UINT64_MAX
- The maximum value that can be represented by - uint64_t.
- CARB_ULLONG_MAX
- The maximum value that can be represented by - unsigned long long.
- CARB_UNIMPLEMENTED
- A macro to mark functionality that has not been implemented yet. 
- CARB_UNLIKELY
- If the current compiler is GCC, defined as - __builtin_expect(!!(<expr>), 0). Otherwise, defined as- (!!(<expr>)).
- CARB_UNLIKELY_IF
- A helper for using both the CARB_UNLIKELY macro as well as the CARB_CPP20_UNLIKELY macro. 
- CARB_UNREACHABLE
- A macro used to express that the current code position is unreachable. 
- CARB_UNSUPPORTED_ARCHITECTURE
- A macro to put into the - #elsebranches when writing CPU architecture specific code.
- CARB_UNSUPPORTED_COMPILER
- A macro to put into the - #elsebranches when writing compiler specific code.
- CARB_UNSUPPORTED_PLATFORM
- A macro to put into - #elsebranches when writing platform-specific code.
- CARB_USHRT_MAX
- The maximum value that can be represented by - unsigned short.
- CARB_VERSION_ATLEAST
- A macro meant to be used in preprocessor - #ifstatements.
- CARB_VIZ
- A macro that can be used to indicate classes and members that participate in visualizers, such as carb.natvis . This is a reminder that these classes, members and types will require visualizer fixup if changes are made. 
- CARB_WARNING
- Issues a custom message as a compiler warning. 
- CARB_WEAKLINK
- Syntactic sugar for - CARB_DECLSPEC(selectany) CARB_ATTRIBUTE(weak), used to enable weak linking.
- CARB_X86_64
- A macro defined as - 1if compilation is targeting the x86-64 platform;- 0otherwise. May not be overridden on the command line or by defining before including this file. Set to- 0if- __aarch64__is defined,- 1if- __x86_64__or- _M_X64are defined, and left undefined otherwise.
- DOXYGEN_EMPTY_CLASS
- Used when declaring opaque types to prevent Doxygen from getting confused about not finding any implementation. 
- OMNI_API
- Declares a symbol that is marked as externally exported. The symbol will be exported with C decorations. On Windows, this is expected to be exported from the containing DLL. On Linux, this is exported as having default visibility from the module instead of being hidden. This export tag should only be used when tagging exported symbols from within omni.core itself. Exported symbols in other modules (such as - omniGetModuleExports()functions in implementation libraries) should use OMNI_MODULE_API instead.
- OMNI_APP_GLOBALS
- Helper macro to declare globals needed my the omni library when using the omni library in an application. 
- OMNI_ASSERT
- Like std::assert. Basically OMNI_FATAL_UNLESS, but compiles to a no-op in debug builds. 
- OMNI_ASSERT_ENABLED
- Set to 1 to indicate that assertion checks are enabled. Set to 0 if assertion checks will just be ignored. This value will always be defined regardless of the current mode. 
- OMNI_ATTR
- Provides additional contextual information to the 'omni.bind' code generation tool. This information is used to generated efficient bindings to the interface. 
- OMNI_BREAK_POINT
- Triggers a breakpoint. If no debugger is attached, the program terminates. 
- OMNI_CATCH_ABI_EXCEPTION
- Helper macro to catch exceptions and return them as omni::core::Result codes. Useful when writing ABI code. 
- OMNI_CHECK
- Checks if the given condition is true, if not, the given optional message is printed to stdout and the program is terminated. 
- OMNI_CHECK_ENABLED
- Indicates whether runtime checking is enabled. For the time being this is always set to - 1indicating that the default implementation should not be overridden. This may change in the future.
- OMNI_CORE_INIT
- Initializes the omni library along with Carbonite. Ensures that both libraries will be cleaned up upon exit. 
- OMNI_CORE_START
- Helper macro to startup the Carbonite framework and Omni type factory. 
- OMNI_CORE_STOP
- Helper macro to shutdown the Carbonite framework and Omni type factory. 
- OMNI_CORE_STOP_FOR_BINDINGS
- Helper macro to shutdown the Carbonite framework and Omni type factory, for script bindings. 
- OMNI_DECLARE_INTERFACE
- Used to forward declare an interface. 
- OMNI_DEFINE_INTERFACE_API
- Used to extend the omni.bind generated API layer. 
- OMNI_EXPORT
- Grants a function external linkage in a dynamic library or executable. 
- OMNI_EXTERN_C
- Declares a "C" exported external symbol. This uses the "C" name decoration style of adding an underscore to the start of the exported name. 
- OMNI_FAILED
- Returns - trueif the given omni::core::Result is a failure code.
- OMNI_FATAL_UNLESS
- This macro is surprisingly complex mainly because it accepts a variable number of arguments. If a single argument is given, a message in the following form is printed: 
- OMNI_FORCE_SYMBOL_LINK
- Helper to force a symbol to be linked. 
- OMNI_GENERATED_API
- Macro to access generated API of an interface. 
- OMNI_GLOBALS_ADD_DEFAULT_CHANNEL
- Adds the - name_as the default logging channel.
- OMNI_GLOBALS_ADD_DEFAULT_CHANNEL_1
- Implementation detail. Do not directly use. Use OMNI_GLOBALS_ADD_DEFAULT_CHANNEL . 
- OMNI_ILauncher_PRIpid
- Format code to use for the carb::launcher::ProcessId data type in printf() style format strings. 
- OMNI_LOG_ADD_CHANNEL
- Defines the properties of a channel and adds it to a module specific list of channels. 
- OMNI_LOG_DECLARE_CHANNEL
- Given a channel name (as a string), declares a global variable to identify the channel. 
- OMNI_LOG_DEFAULT_CHANNEL
- The default channel variable to use when no channel is supplied to the - OMNI_LOG_*macros.
- OMNI_LOG_DEFINE_CHANNEL
- Defines the properties of a channel. 
- OMNI_LOG_ERROR
- Logs a message at omni::log::Level::eError level. 
- OMNI_LOG_FATAL
- Logs a message at omni::log::Level::eFatal level. 
- OMNI_LOG_INFO
- Logs a message at omni::log::Level::eInfo level. 
- OMNI_LOG_VERBOSE
- Logs a message at omni::log::Level::eVerbose level. 
- OMNI_LOG_WARN
- Logs a message at omni::log::Level::eWarn level. 
- OMNI_LOG_WRITE
- Logs a message. 
- OMNI_MODULE_ADD_LOG_CHANNEL
- Adds a log channel to the logging system. The channel will be removed when the module is unloaded. 
- OMNI_MODULE_ADD_STRUCTURED_LOG_SCHEMA
- adds a new schema to be registered after core startup. 
- OMNI_MODULE_API
- Declares a function that is marked as externally exported. The symbol will be exported with C decorations. On Windows, this is expected to be exported from the containing DLL. On Linux, this is exported as having default visibility from the module instead of being hidden. This is intended for exported symbols in implementation libraries. 
- OMNI_MODULE_DEFINE_CARB_FUNCTIONS
- Defines default implementations of global Carbonite functions for an Omni module. 
- OMNI_MODULE_DEFINE_LOCATION_FUNCTIONS
- Defines functions centered around determining the current module's disk location. 
- OMNI_MODULE_DEFINE_OMNI_FUNCTIONS
- Defines default implementations of global omni functions for a module. 
- OMNI_MODULE_EXPORT_ENTRY_BEGIN
- Helper macro for defining an entry (i.e. omni::core::ModuleExportEntry ) in the export table (i.e. omni::core::ModuleExports ). 
- OMNI_MODULE_EXPORT_ENTRY_END
- Helper macro for defining an entry in the export table. 
- OMNI_MODULE_GET_MODULE_DEPENDENCIES
- Registers the function responsible for advertising the plugin's interface dependencies. 
- OMNI_MODULE_GLOBALS
- Helper macro to declare globals needed by modules (i.e. plugins). 
- OMNI_MODULE_GLOBALS_BUILD_CONFIG_SYMBOLS
- Defines global symbols intended to be used to statically analyze whether a given plugin is a debug or release build. In a debug build, the - g_carbIsDebugConfigsymbol will be present. In a release build, the- g_carbIsReleaseConfigsymbol will be present. These symbols are not intended to be used at runtime, but rather to be able to determine the build configuration without having to load up the module in a process first.
- OMNI_MODULE_GLOBALS_WITHOUT_CARB
- Helper macro to declare globals needed by modules (i.e. plugins). 
- OMNI_MODULE_ON_MODULE_CAN_UNLOAD
- Registers the plugin's function that determines if the plugin can be unloaded. See omni::core::OnModuleCanUnloadFn for details. 
- OMNI_MODULE_ON_MODULE_LAST_CHANCE_SHUTDOWN
- Registers the plugin's function who is responsible for cleaning up the plugin when the plugin unload is being skipped during a quick shutdown. 
- OMNI_MODULE_ON_MODULE_LOAD
- Registers the plugin's function who is responsible for advertising the available interface implementations in the plugin. 
- OMNI_MODULE_ON_MODULE_STARTED
- Registers the plugin's function that will be called once the plugin is loaded. See omni::core::OnModuleStartedFn for threading consideration with this function. 
- OMNI_MODULE_ON_MODULE_UNLOAD
- Registers the plugin's function who is responsible for cleaning up the plugin when the plugin is being unloaded. 
- OMNI_MODULE_REQUIRE_CARB_CLIENT_NAME
- Requires that the owning omni::core::ITypeFactory provides a Carbonite client name: g_carbClientName . 
- OMNI_MODULE_REQUIRE_CARB_FRAMEWORK
- Requires that the owning omni::core::ITypeFactory provides a Carbonite carb::Framework g_carbFramework . 
- OMNI_MODULE_REQUIRE_CARB_IASSERT
- Requires that the owning omni::core::ITypeFactory provides a Carbonite carb::assert::IAssert g_carbAssert . 
- OMNI_MODULE_REQUIRE_CARB_IL10N
- Requires that the owning omni::core::ITypeFactory provides a Carbonite carb::l10n::IL10n g_carbLocalization . 
- OMNI_MODULE_REQUIRE_CARB_ILOGGING
- Requires that the owning omni::core::ITypeFactory provides a Carbonite carb::logging::ILogging g_carbLogging . 
- OMNI_MODULE_REQUIRE_CARB_IPROFILER
- Requires that the owning omni::core::ITypeFactory provides a Carbonite carb::profiler::IProfiler g_carbProfiler . 
- OMNI_MODULE_SET_CARB_EXPORTS
- Helper macro to set known export fields in omniModuleGetExports() related to Carbonite. 
- OMNI_MODULE_SET_EXPORTS
- Helper macro to set known export fields in omniModuleGetExports() . 
- OMNI_MODULE_SET_EXPORTS_WITHOUT_CARB
- Helper macro to set known export fields in omniModuleGetExports() . 
- OMNI_MOF_CV
- OMNI_MOF_MOVE
- OMNI_MOF_NOEX
- OMNI_MOF_REF
- OMNI_PLATFORM_LINUX
- Set to - 1if compiling a Linux build. Set to- 0otherwise. This symbol will always be defined even when not on a Linux build. It can thus be used to pass as parameters or in if-statements to modify behavior based on the platform.
- OMNI_PLATFORM_MACOS
- Set to - 1if compiling a MacOS build. Set to- 0otherwise. This symbol will always be defined even when not on a MacOS build. It can thus be used to pass as parameters or in if-statements to modify behavior based on the platform.
- OMNI_PLATFORM_WINDOWS
- Set to - 1if compiling a Windows build. Set to- 0otherwise. This symbol will always be defined even when not on a Windows build. It can thus be used to pass as parameters or in if-statements to modify behavior based on the platform.
- OMNI_PLUGIN_IMPL_DEPS
- Provides a list of dependent interfaces for an ONI plugin. 
- OMNI_PLUGIN_IMPL_NODEPS
- Declares that the calling plugin has no dependencies on any other Carbonite or ONI interfaces. 
- OMNI_PLUGIN_INTERFACE
- Used to declare the interface description for an ONI object's API layer. 
- OMNI_POSIX
- This is set to - _POSIX_VERSIONplatforms that are mostly-compliant with POSIX.
- OMNI_PRIpid
- The printf format macro to print a process ID. 
- OMNI_PRItid
- The printf format macro to print a thread ID. 
- OMNI_PRIxpid
- The printf format macro to print a process ID in hexadecimal. 
- OMNI_PRIxtid
- The printf format macro to print a thread ID in hexadecimal. 
- OMNI_PYTHON_GLOBALS
- Declare a compilation unit as script language bindings. 
- OMNI_RETURN_ERROR
- Helper macro used to return a omni::core::Result . When in debug mode and attached to a debugger, this macro will cause a debugger break. Useful for determining the origin of an error. 
- OMNI_RETURN_IF_ARG_NULL
- Helper macro to return an appropriate omni::core::Result when the given argument is - nullptr. Useful when authoring ABI code.
- OMNI_RETURN_IF_FAILED
- If the given omni::core::Result is a failure code, calls - return resultto exit the current function.
- OMNI_STRUCTURED_LOG
- Common entry point for sending an event. 
- OMNI_STRUCTURED_LOG_ADD_SCHEMA
- Sets that a schema should be registered on module load. 
- OMNI_STRUCTURED_LOG_EVENT_ID
- Helper macro to piece together a unique event name to generate an ID from. 
- OMNI_SUCCEEDED
- Returns - trueif the given omni::core::Result is not a failure code.
- OMNI_THROW_IF_ARG_NULL
- Helper macro to throw a omni::core::ResultError exception if a function argument is - nullptr. Used heavily by omni.bind .
- OMNI_THROW_IF_FAILED
- Helper macro to convert a omni::core::Result to a omni::core::ResultError exception. Useful when authoring API code. Used heavily by omni.bind . 
- OMNI_TYPE_ID
- Returns the type id of the given type name at compile time. 
- OMNI_USE_FROM_GENERATED_API
- Used in cases when defined interface provides an overload for a function from generated API. 
- PERSISTENT_SETTINGS_PREFIX
- The settings prefix to indicate that a setting is persistent. 
- PRIdword
- A placeholder for DWORD type. 
- PRIxdword
- A placeholder for DWORD type, in hexadecimal format. 
- RSTRINGENUM_FROM_RSTRING_H
- SETTING_SEP
- The separator character used by carb.settings . 
- carb_ErrorApi
- The default version of carb::ErrorApi . 
- carb_ErrorApi_latest
- The latest possible version of carb::ErrorApi . 
- carb_Framework
- The Carbonite Framework default version. 
- carb_Framework_latest
- The latest version of the Carbonite Framework available. 
- carb_assert_IAssert
- The default version of carb::assert::IAssert . 
- carb_assert_IAssert_latest
- The latest possible version of carb::assert::IAssert . 
- carb_crashreporter_ICrashReporter
- The default current version for carb::crashreporter::ICrashReporter . 
- carb_crashreporter_ICrashReporter_latest
- Latest version for carb::crashreporter::ICrashReporter . 
- carb_dictionary_IDictionary
- Default version of the - IDictionaryinterface.
- carb_dictionary_IDictionary_latest
- Version of the - IDictionaryinterface.
- carb_eventdispatcher_IEventDispatcher
- The default version number of the carb::eventdispatcher::IEventDispatcher interface to use for this build. This macro may be overridden in the project settings to instead use the latest version of the interface. 
- carb_eventdispatcher_IEventDispatcher_latest
- The version number of the latest carb::eventdispatcher::IEventDispatcher interface. 
- carb_eventdispatcher_IMessageQueueFactory
- The version to request of the carb::eventdispatcher::IMessageQueueFactory interface. 
- carb_eventdispatcher_IMessageQueueFactory_latest
- The latest version available of the carb::eventdispatcher::IMessageQueueFactory interface. 
- carb_events_IEvents
- The default version number of the carb::events::IEvents interface to use for this build. This macro may be overridden in the project settings to instead use the latest version of the interface. 
- carb_events_IEventsAdapter
- The default version number of the carb::events::IEventsAdapter interface to use for this build. This macro may be overridden in the project settings to instead use the latest version of the interface. 
- carb_events_IEventsAdapter_latest
- The version number of the latest carb::events::IEventsAdapter interface. 
- carb_events_IEvents_latest
- The version number of the latest carb::events::IEvents interface. 
- carb_logging_ILogging
- The default current version for carb::logging::ILogging . 
- carb_logging_ILogging_latest
- Latest version for carb::logging::ILogging . 
- carb_profiler_IProfiler
- The default current version for carb::profiler::IProfiler . 
- carb_profiler_IProfiler_latest
- Latest version for carb::crashreporter::IProfiler. 
- carb_settings_ISettings
- Default version of the - ISettingsinterface.
- carb_settings_ISettings_latest
- Version of the - ISettingsinterface.
- carb_stats_IStats
- The current default IStats interface version. 
- carb_stats_IStats_latest
- Latest IStats interface version. 
- carb_tasking_ITasking
- Default version of ITasking interface to use. 
- carb_tasking_ITasking_latest
- Latest version of ITasking interface available. 
- carb_tokens_ITokens
- Default version of the - ITokensinterface.
- carb_tokens_ITokens_latest
- Version of the - ITokensinterface.
- carb_windowing_IWindowing
- The default current version of carb::windowing::IWindowing . 
- carb_windowing_IWindowing_latest
- Latest version for carb::windowing::IWindowing . 
- omni_kit_IApp
- The default current version for omni::kit::IApp . 
- omni_kit_IApp_latest
- Latest version for omni::kit::IApp .