Cinema 4D R20 introduced significant changes of the C++ API. The new Maxon API was introduced, which is fundamentally different that the previous, classic, API. The Cinema API is still available in the cinema.framework, but several components of the Cinema API have been replaced with new Maxon API components.
Any plugin that was written for an earlier SDK (R19 or older) must be adapted and re-compiled to work with Cinema 4D R20.
Since Cinema 4D R20 the SDK does no longer contain any project files. The project files for frameworks, plugins and solutions must be created using the project Tool. See Project Tool.
The source processor is part of the tool chain to build a plugin (see Source Processor). This source processor checks the source code and creates automatically additional code. The processor also checks the code style according to the level that is set in the project's projectdefinition.txt file (see Project Tool).
The naming scheme of string resource folders was changed. The resource folder that was named "strings_us" is now named "strings_en-US". See Plugin Resources.
The complete Maxon API is defined in the maxon namespace. In contrast, the Cinema API is defined in the global namespace. To avoid collisions and ambiguity it might be necessary to use fully qualified names.
Wherever possible unneeded includes and umbrella includes were removed. It might be necessary to add additional includes to include specific header files explicitly.
The global resources instances has been renamed to g_resource.
Simple enumerations were reformatted as enumeration classes. Since "0" is not a valid enumeration value name it has been replaced with "NONE".
The macro ENUM_END_FLAGS() has been removed. If you have a custom enumeration you have to use MAXON_ENUM_LIST() or MAXON_ENUM_FLAGS().
The Maxon API introduces new data types and replaces or extends Cinema API data types:
The Maxon API error system allows functions to return an explicit error state. Several functions of the Cinema API have been replaced with new functions that do return such an error state e.g. NewObj() or maxon::BaseArray::Append(). It is needed to handle this error state. See Error Handling.
The error system also allows to re-write functions so they return error states. This is extremely helpful to find the source of any error and to write stable code.
Several functions have been renamed to follow a consistent terminology. Functions like "Content()" that check if a given instance has any content have been renamed to "IsPopulated()" and "IsEmpty()".
Cinema 4D R20 introduced a new, complex and adaptable logger system. The standard console is just one of many available loggers now. One can write messages to the standard console using ApplicationOutput() instead of GePrint(). See LoggerInterface Manual.