About
The Maxon API makes heavy use of C++ preprocessor macros. These macros are used to automatically create code or to mark parts of the code (e.g. in interfaces). The macros described on this page are relevant for every kind of development. Other specialised macros exist for special tasks.
Object Use
Under Xcode / GCC the compiler can check if the return value of a function is used or not. If a return value that should be used is not used, a compile error is thrown.
- MAXON_WARN_UNUSED: If the return value of this function is not used, a compile error is thrown.
- ::MAXON_WARN_MUTE_UNUSED: The compile error thrown by MAXON_WARN_UNUSED is muted.
- Note
- Do not use these macros to mute errors returned with the error system. Instead use iferr_cannot_fail() or iferr_ignore(). See Error Handling.
bool Bool
boolean type, possible values are only false/true, 8 bit
Definition: apibase.h:189
#define MAXON_WARN_UNUSED
Definition: compilerdetection.h:271
    
 
  
  CriticalFunction();
 
  
 
  
  MAXON_WARN_MUTE_UNUSED CriticalFunction();
 
- MAXON_WARN_UNUSED_CLASS: If a class marked with this macro is used as a return value but this return value is not used, an error is thrown.
 
{
};
 
static CriticalInfo GetCriticalInfo();
int32_t Int32
32 bit signed integer datatype.
Definition: apibase.h:184
#define MAXON_WARN_UNUSED_CLASS
Definition: compilerdetection.h:272
    
  
 
  
  GetCriticalInfo();
 
  
  const CriticalInfo info = GetCriticalInfo();
 
 
#define DiagnosticOutput(formatString,...)
Definition: debugdiagnostics.h:170
 If a variable is declared but not used this will trigger a compile warning. This warning can be suppressed with this function:
- maxon::UseVariable(): Uses the given variable.
- Note
- Using maxon::UseVariable() will not cause any performance penalty.
  
 
  {
    
  }
 
  {
    
    UseVariable(number);
  }
Int64 Int
signed 32/64 bit int, size depends on the platform
Definition: apibase.h:196
#define MAXON_SCOPE
Definition: apibase.h:2936
Program Flow and Structure
These macros are used to mark certain parts of the source code:
- MAXON_SCOPE: Marks a block of code that is scoped for a certain reason.
- MAXON_UNLIKELY: Marks an unlikely branch for branch prediction.
- MAXON_LIKELY: Marks a likely branch for branch prediction.
  
  
 
  {
 
    number++;
 
  }
 
  {
 
    number++;
 
  }
#define iferr_return
Definition: resultbase.h:1511
  
 
  {
    number = 100;
  }
#define MAXON_UNLIKELY(...)
Definition: compilerdetection.h:391
 Switch-case statements can be improved with:
  
 
  enum class MyEnum
  {
    A,
    C
  };
 
 
  switch (value)
  {
    case MyEnum::A:
      break;
      break;
    default:
      break;
  }
#define ApplicationOutput(formatString,...)
Definition: debugdiagnostics.h:204
#define MAXON_SWITCH_CHECKALLENUMS_BEGIN
Definition: compilerdetection.h:348
#define MAXON_SWITCH_CHECKALLENUMS_END
Definition: compilerdetection.h:349
B
Definition: unicodeutils.h:3
Finally
The code defined in a "finally" block is executed when the program flow leaves the current scope.
- finally: Defines a code block which is executed when the scope is left.
- finally_once: Returns a maxon::FinallyOnce object that can be used to disable the code block execution.
 
{
 
 
  {
    
  };
 
 
}
#define NewMemClear(T, cnt)
Definition: defaultallocator.h:216
#define finally
Definition: finally.h:64
char Char
signed 8 bit character
Definition: apibase.h:192
return OK
Definition: apibase.h:2785
void DeleteMem(T *&p)
Definition: defaultallocator.h:269
#define iferr_scope
Definition: resultbase.h:1376
  
Enummerations
 
enum class PRIMARY_COLOR
{
 
enum class QUALITY
{
  A = (1 << 0), 
  C = (1 << 2), 
  D = (1 << 3), 
NONE
Definition: asset_browser.h:1
#define MAXON_ENUM_LIST(E,...)
Definition: enumflags.h:122
#define MAXON_ENUM_FLAGS(E,...)
Definition: enumflags.h:172
RED
Definition: lib_birender.h:26
BLUE
Definition: lib_birender.h:28
GREEN
Definition: lib_birender.h:27
    
 
  
 
  
 
  
 
 
  
 
  
  const QUALITY qualities = QUALITY::A | 
QUALITY::B;
 
 
  
 
  if (qualities & QUALITY::A)
 
  if (!(qualities & QUALITY::D))
Classes and Functions
The following macros are used to declare classes and their functions:
These macros are used to implement certain operators automatically:
 
class NumberClass
{
public:
  {
    _number = v;
  }
 
  
 
  
 
  
 
  
 
  {
    return &_number;
  }
 
  {
  }
 
private:
};
#define MAXON_IMPLICIT
Definition: apibase.h:180
const ARG & src
Definition: apibase.h:2751
#define MAXON_OPERATOR_EQUALITY_HASHCODE(T,...)
Definition: classhelpers.h:593
#define MAXON_NONCONST_COUNTERPART(...)
Definition: classhelpers.h:655
#define MAXON_COPY_MEMBERS(...)
Definition: classhelpers.h:501
#define MAXON_OPERATOR_COPY_ASSIGNMENT(TypeName)
Definition: classhelpers.h:416
    
  
 
  NumberClass someNumber(1);
 
  
  maxon::Int* 
const number = someNumber.GetNumber();
 
  *number = *number + 1;
 
  
  const maxon::Int* 
const res = someNumber.GetNumber();
 
 
  
 
  
  NumberClass someOtherNumber(0);
  someOtherNumber = someNumber;
UInt64 UInt
unsigned 32/64 bit int, size depends on the platform
Definition: apibase.h:197
Utility
Other utility macros exist:
  
 
  
 
  
 
 
Definition: string.h:1287
Float64 Float
Definition: apibase.h:205
#define MAXON_HASHCODE(...)
MAXON_HASHCODE computes the hash code of the arguments based on DefaultCompare::GetCombinedHashCode.
Definition: classhelpers.h:511
Further Reading