To debug a plugin during development start Cinema 4D from the used development environment. See Development for Microsoft Windows, Development for macOS and Development for Linux.
When running in debug mode, Cinema 4D will print various debug messages to the IDE output console. These messages will include information on any issues with loaded modules and components.
The behaviour of Cinema 4D can be configured using various command line arguments. An overview can be found in <C4D install dir>/resource/config.txt.
Custom command line arguments can be defined using configuration variables. See Configuration Variables.
Cinema 4D can be run in debug mode using the command line argument g_alloc=debug. In debug mode Cinema 4D will provide all kinds of additional runtime information on the system console. For example it will check for and print out memory leaks. This will slow down Cinema 4D considerably, so the debug mode might only be enabled temporarily.
The command line argument g_logfile is used to define a log file. All debug output will be written into that log file.
The command line argument g_console can be set to "true" to open a debug console window.
The argument g_enableDebugBreak can be used to disable debug stops. See Debug Stops below.
Several "output" functions allow to print debug messages:
To print data to the console window it must be converted to a maxon::String. Most MAXON API data types already provide a ToString() function so they can simply be used with DiagnosticOutput(). Primitive data types can be converted to strings using dedicated functions of the maxon::String class.
See also FormatString(), String Manual and Output Syntax.
The MAXON API error system allows functions to return explicit error states. With this error system it is possible to:
For an overview see Error System.
Assert functions like DebugAssert() allow to simply check a given condition. If the condition is not fulfilled, an error is returned automatically. See Debug and Output Functions.
It is advised to always use the Cinema 4D memory system. Allocated objects should be stored with smart pointers to avoid memory leaks. See Memory Allocation, References and Entity Creation and Destruction Manual (Classic).
The example.main example project contains the Active Object Dialog plugin. This plugin allows to inspect the currently active scene in detail. It gives access to the used scene hooks and objects inside generator caches as well as dirty flags.
When running in debug mode, Cinema 4D might trigger a debug stop in certain situations. Such a debug stop indicates a some wrong behaviour and is typically caused by incorrect arguments given to some functions. Such a debug stop is no crash; it can simply be skipped to continue a debugging sessions.
The Source Processor analyses the source code and creates new code. If the source processor detects certain errors it will print a message to the IDE's output console.
The Source Processor automatically creates code needed for interfaces and other features of the MAXON API. A programming error can result in some issues with this automatically created code and some unintuitive compile and linker errors. Typical compile errors related to such issues are collected here:
Error | Possible Cause |
---|---|
Ambiguous Symbol | When mixing classic and MAXON API code certain symbols might not be unique. Use namespaces and take a look at the order of includes. |
cannot access private member declared in class 'XXX' | A function in an implementation class is not public. |
hxx include missing for 'XXX' | A header file defining some interface must include the automatically generated .hxx files. |
Use of undeclared identifier 'tmperr_0' | Within an error scope iferr_scope ; is missing. See Error Handling. |
Ignoring return value of function declared with warn_unused_result attribute | This typically means that an maxon::Result return value is not handled correctly. See Object Use and Error Handling. |
Unused variable 'tmperr_0' | ::iferr_handle ; is used without iferr_scope_handler . See Error Handling. |
See also API Transition and Interface Basics.