Profiler (Mono)
A Rust (language) native high-speed and lightweight Mono profiler with the ability to profile game assemblies, Carbon, plugins, modules & extensions at high depth.
Last updated
A Rust (language) native high-speed and lightweight Mono profiler with the ability to profile game assemblies, Carbon, plugins, modules & extensions at high depth.
Last updated
The Mono Profiler is a Carbon built-in feature, offering high performance and convenience, making it ideal for profiling the game, plugins, and more - efficiently.
You may profile the following:
Game assemblies (Assembly-CSharp, Facepunch.*, Rust.*, Unity*, System, etc.)
Carbon assemblies (Carbon.Common, Carbon.Compat, etc.)
Plugin assemblies
Module assemblies
Extension assemblies
The configuration for the profiler is located atcarbon/config.profiler.json
.
NOTE
To enable profiling with full selection for one or more categories, use a wildcard/star ( * ).
IMPORTANT
Remove the // comments from the JSON if you're willing to override it locally with it.
They're used when starting or stopping the profiler when processing is executed.
When the profiler is recording, this flag will terminate recording and discard collected stack and data processed natively.
Requires the Calls
flag to be set. The profiler will keep track of the memory of each call in the stack.
NOTICE
This flag will significantly affect performance due to having to calculate the time taken on each call.
Requires the Calls
flag to be set. The profiler will keep track of the timing & duration information for each call in the stack.
Whether method calls should be tracked by the current stack.
As posted under commands, we provide simplified commands for easy and quick management of the profiling process.
Switches in brackets [ ] means that the switch is optional.