BlaXuan 发表于 2022-10-9 17:11

使用-SingleProcess参数,调试Unreal Insights (短篇)

UE4.26,在用Unreal Insights加载一个录制好的.utrace文件的时候,Unreal Insights crash了。
我尝试去调试为什么会崩溃,但是发现默认通过"Open File"打开的视图,是在新的进程中,要调试的话,还需要再Attach一次,比较麻烦。



Unreal Insights - Open File的入口

通过SStartPageWindow.cpp中的代码可以看到,ShouldOpenAnalysisInSeparateProcess()方法控制了是否在新进程中加载Trace文件.
/// SStartPageWindow.cpp
void SStartPageWindow::LoadTraceFile(const FString& InTraceFile)
{
        if (FInsightsManager::Get()->ShouldOpenAnalysisInSeparateProcess())
        {
                UE_LOG(TraceInsights, Log, TEXT(" Start analysis (in separate process) for trace file: \"%s\""), *InTraceFile);
                /// 这里省略的代码就是打开新进程的代码
        }
        else
        {
                UE_LOG(TraceInsights, Log, TEXT(" Start analysis for trace file: \"%s\""), *InTraceFile);
                FInsightsManager::Get()->LoadTraceFile(InTraceFile);
        }
}

看下面的代码,发现通过在命令行中,指定"-SingleProcess"参数,就能让LoadTraceFile()方法,在当前进程中,加载Trace文件,这样调试Trace文件加载过程中的Crash,就不用再进行额外的Attach了。
// TraceInsightsModule.cpp
void FTraceInsightsModule::CreateSessionBrowser(bool bAllowDebugTools, bool bSingleProcess)
{
        FInsightsManager::Get()->SetOpenAnalysisInSeparateProcess(!bSingleProcess);
        // 省略其他代码
}

// Engine/Source/Programs/UnrealInsights/Private/UserInterfaceCommand.cpp
void FUserInterfaceCommand::InitializeSlateApplication(bool bOpenTraceFile, const TCHAR* TraceFile,const TCHAR* CompareTraceFile)
{
                        // 省略其他代码
                        const bool bSingleProcess = FParse::Param(FCommandLine::Get(), TEXT("SingleProcess"));
                        TraceInsightsModule.CreateSessionBrowser(bAllowDebugTools, bSingleProcess);
                        // 省略其他代码
}




附上一张Rider中,调试命令行参数设置的截图。在VisualStudio中的设置同理

最后,经过调试,又对比了一下官方最新的代码,发现我遇到的Crash,官方已经修复了,所以只要合并下面的commit就解决了。
Fixed depth limit for MonotonicTimeline. It will safely ignore events when the depth limit is exceeded instead of crashing.
https://github.com/EpicGames/UnrealEngine/commit/880e7db3cea3e7c446e8d89b14d69e5b1164f8a1
页: [1]
查看完整版本: 使用-SingleProcess参数,调试Unreal Insights (短篇)