Allow logs of package .exe (packaged from editor)

I want to allow logs on the .exe(s) I produce when I package my game from editor.

Currently if I lauch any of the produced .exe. The game run as expected but my …/AppData\Local\MYGAME\Saved\Logs remains empty

I have tried: https://dev.epicgames.com/community/learning/knowledge-base/vzvZ/unreal-engine-enabling-logging-in-shipping-builds?locale=

However I get:

Targets with a unique build environment cannot be built with an installed engine.

Please note that I have also added:

[Core.Log]
LogInit=Verbose
LogWarning=Verbose
LogError=Verbose
LogPerformance=Verbose

Can you help me ? My issue is not the error itself (I can revert it), my issue is that I really need the logs for my packaged .exe (ideally packaged from editor)

Finally I have resolved my self to use Game Logs System (GLS): Real-Time Log Management for Shipping Builds on Mobile and Console Platforms | Community tutorial.

I have installed the plugin, change the build settings and performed the proper imports. But when I try to perform (runtime, I manage to build the code)

#include <GLSMacroses.h>
...
if (GetWorld())
	{
		GLS_LOG_STRING(GetWorld(), LogTemp, Warning, TEXT("Direct log entry without formatting"));
	}
	else
	{
		UE_LOG(LogTemp, Warning, TEXT(" WORLD EMPTY "));
	}

I get a EXCEPTION_ACCESS_VIOLATION for GLS_LOG_STRING (Source\Runtime\Core\Public\Delegates\DelegateInstancesImpl.h:650).

If someone can help me with that it would help me.

1 Like

Ok I can now use GLS with my shipping.exe. I can copy the log from the overlay log and use it. Unfortunately I was not able to pinpoint any default location for the logs so I can only use the copy logs buttons from the overlay.

Quickly here is my solution (useful if you wish logs via GLS overlay in your shipping.exe):

  1. Install Game Logs System (GLS): Real-Time Log Management for Shipping Builds on Mobile and Console Platforms | Community tutorial (it cost 8$ or 30$ depending on your need.
  2. Change your game YourGame.Build.cs to add “GLS” support (like in https://www.youtube.com/watch?v=oQdnRjIzvhI&t=57s)
  3. Enable shipping logs (like in https://www.youtube.com/watch?v=oQdnRjIzvhI&t=57s)
  4. Add include <GLSMacroses.h> in your .h
  5. Use GLS_LOG instead of UE_LOG. FString Message = TEXT("Hourra!"); GLS_LOG(this, LogTemp, Warning, TEXT("GLS IS WORKING: %s"), *Message); //GLS_LOG_STRING(this, LogTemp, Verbose, TEXT("Direct log entry without formatting"));
  6. Build your project.
  7. Package your project.
  8. In your game, go in game (on my side I needed to left my main menu). Press alt+shift+g AND HOLD 1 second (holding is important, I was not holding long enough at first).
  9. You should now have access to GLS log.

Here are additional steps I took but I think they were useless with this solution (I share them just in case it might had have an impact)

  • In Packaging settings… I have ‘Include Debug Files in Shipping Builds’
  • In my build.cs, I added
    PublicDefinitions.Add("UE_BUILD_SHIPPING=1"); PublicDefinitions.Add("ALLOW_CONSOLE=1"); PublicDefinitions.Add("USE_LOGGING_IN_SHIPPING=1");
  • I also added (DefaultGame.ini under [/Script/GLS.GLSSettings] that you get when installing the plugin and saving a conf as default)
    `
    [Core.Log]
    LogInit=Verbose
    LogWarning=Verbose
    LogError=Verbose
    LogPerformance=Verbose

`

I will close it as the solution. Even though I am really surprise it is that complicated to activate logs for shipping configuration (I know this is for performance but we should have the option to choose).

If anyone using a similar approach found GLS log location, please tell me. Paying for such a need feels ridiculous, I was starting to consider simply adding some code to write to a file instead

1 Like

Thank you @greg700000 for using our plugin!

It was specifically designed to handle logging tasks in builds of any configuration. The issues you encountered have given us valuable insights, and we’ll definitely work on improving the plugin to make it even simpler and more convenient to use in future updates.

We truly appreciate your feedback and the effort you’ve put into solving the challenges you faced. If you have more thoughts or suggestions, don’t hesitate to share them—we’re always open to making things better!

Unreal Engine intentionally disables logging in shipping builds. This is because all builds delivered to marketplaces for end users must have logging disabled to ensure maximum performance of the game.

In professional studios, it’s common to use engine builds compiled from source, which can be downloaded from Epic Games’ GitHub repository. By using a source-built engine, you can build your game in the TEST configuration, which allows logging functionality. Additionally, the source engine can be modified to enable logging in the shipping configuration, if necessary.

However, it’s crucial to remember that any build submitted to a marketplace must have logging disabled.

For example, in GLS, there is a build flag -gls_disable. If this flag is passed when building the project, GLS will be completely disabled and unavailable in the build, even if you’ve enabled logging for the shipping configuration in the .ini file.

We hope this clarifies the situation! If you have any further questions, feel free to ask.