Manage your PDB Files
Upload the debug symbol in Windows
To get a call stack from your crash dump, the AccelByte Development Toolkit (ADT) backend needs the debug symbol information from your game or application. To get this information, upload the debug symbols, which are .pdb files and executables or .exe files in Windows, to the ADT backend.
To upload the files, perform these tasks, in this order:
- 
Extract the CrashReportClient.pakto a temporary folder.
- 
Modify the CrashReportClient.inifile from the temporary folder.
- 
Repack the CrashReportClient.pak.
- 
Parse the .pdbfiles for symbols and zip them.
- 
Archive the .exeand.pdbfile to the shipping folder in a single zip file.
- 
Upload the .exeand.pdbzip files to the ADT backend, as shown below.
Without Inline Configuration
BlackBoxCLI.exe upload
With Inline Configuration
BlackBoxCLI.exe upload --apikey asdf1234 --namespace myawesomegame --game-project D:\path\to\myawesomegame --game-engine D:\UnrealEngine\UE4.25 --game-archive D:\path\to\packaged\awesomegame --platform-name windows --platform-arch x64
Use the ADT CLI to upload the build's debug symbol
You can use the ADT CLI to upload the debug symbol for the editor and packaged builds. Upload them both the same way,
but with an additional --editor-build argument for the editor.
Without inline configuration
BlackBoxCLI.exe upload --editor-build
It takes a few minutes to compress and upload your .pdb and .exe files to ADT's backend. When the upload finishes, the
results are similar to the example below.
BlackBoxCLI.exe upload
Build ID: af59abac-f560-47b5-bf47-416128d8e282
Try to open Game Config File DefaultEngine.ini ("D:\\blackbox-sdk\\SampleGame\\Config\\DefaultEngine.ini")
Registering build...OK
Zipping executable and pdb ...
Compressing: AccelMania-Win64-DebugGame.exe [113965/113965] kB
Compressing: AccelMania-Win64-DebugGame.pdb [145764/145764] kB
Dump Symbol...
Compressing: AccelMania-Win64-DebugGame.sym [73980/73980] kB
Upload executable and pdb ...
Preparing to upload PDB files...
Uploading...
Sent: 71525/71525 KB
Upload Successful...
Preparing to upload Breakpad symbol...
Uploading...
Sent: 7307/7307 KB
Upload Successful...
Updating Crash Reporter Client...OK
Success!
You can also use these options to parse the game's executable file and upload the filtered .pdb contents to the ADT backend.
| Options | Include | Exclude | Description | 
|---|---|---|---|
| -h,--help | - | - | Print help message and exit | 
| -d,--dump-path | - | - | Specify where to dump the output JSON file. If you don't specify a path, the system won't create the dump file. | 
| -I,--game-build-stamp | - | --upload-only | Specify the game build stamp | 
| -u,--upload-only | --dump-path | --game-build-stamp | Skip the PDB parsing phase and go straight to upload, assuming JSON already exists. | 
| -Z,--zip-file-location | - | - | Path to a zip file for upload. This option expects a prepared zip file. | 
| -E, --editor-build | Upload the PDB for editor build. This option collects all the Unreal Editor's PDB files and uploads the information to ADT's backend. | ||
| --platform-arch | The platform arch of the game debug symbols to upload (e.g x64) | ||
| --platform-name | The platform name of the game debug symbols to upload, such as Windows, xsx, xboxonegdk, PS5 | 
Upload the Linux debug symbol for Unreal 5
To upload the Linux debug symbol for Unreal 5, you need an extra configuration in your game. Add the following config field and section to the DefaultEngine.ini file of your game:
[/Script/LinuxPlatform.LinuxTargetSettings]
bPreservePSYM=True
After you add this configuration file, clean any build artifacts, which are usually in the intermediate directory, before you try to build a Linux game or errors result.
Once you are ready to build your Linux game, upload the Linux debug symbol by calling the upload command for Unreal 5:
With inline configuration
BlackBoxCLI.exe upload --apikey asdf1234 --namespace myawesomegame --game-project D:\path\to\myawesomegame --game-engine D:\UnrealEngine\UE4.25 --game-archive D:\path\to\packaged\awesomegame --platform-name linux-server --platform-arch x64
Enable PDB File Generation for Shipping Builds
By default, Unreal Engine does not generate PDB files when your project is set to a Shipping build configuration. To enable this, follow these steps in the Unreal Editor:
- 
Open the Unreal Editor, click on the Edit menu, and select Project Settings from the dropdown. 
- 
In the Search bar, type "Include crash reporter" and check the box to enable it. 
- 
Then search for "Include debug files in shipping builds" and check that box as well. This will allow the Crash Reporter Client to appear. 
- 
Close the editor. The next time you create a Shipping build, PDB files will be included in the packaged output. 
Setup PSYM symbols for Linux builds
If you’re using Unreal Engine 5.1 or above, you need to modify the DefaultEngine.ini file located in <game_project>/Config and add the following:
[/Script/LinuxPlatform.LinuxTargetSettings]
bPreservePSYM=True
With this setting enabled, when you package a Linux or Linux-Server build, Unreal will generate a .psym file instead of a .debug file.
You can then upload the .psym symbol file to ADT with the Upload command from above. This ensures that whenever a crash occurs in your build, ADT can leverage the symbol file to provide detailed crash debugging.