2021-05-25 13:27:48 -04:00
|
|
|
// Copyright Epic Games, Inc. All Rights Reserved.
|
|
|
|
|
|
|
|
|
|
#include "DerivedDataBuildScheduler.h"
|
|
|
|
|
|
|
|
|
|
#include "DerivedDataBuildFunction.h"
|
|
|
|
|
#include "DerivedDataBuildFunctionFactory.h"
|
|
|
|
|
#include "DerivedDataBuildFunctionRegistry.h"
|
|
|
|
|
#include "Misc/Guid.h"
|
2021-07-16 01:25:15 -04:00
|
|
|
#include "Tasks/Task.h"
|
2021-05-25 13:27:48 -04:00
|
|
|
|
|
|
|
|
namespace UE::DerivedData::Private
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
class FBuildScheduler final : public IBuildScheduler
|
|
|
|
|
{
|
2021-07-16 01:25:15 -04:00
|
|
|
public:
|
|
|
|
|
void DispatchCacheQuery(IBuildJob* Job, const FBuildSchedulerParams& Params) final;
|
|
|
|
|
void DispatchCacheStore(IBuildJob* Job, const FBuildSchedulerParams& Params) final;
|
|
|
|
|
void DispatchResolveKey(IBuildJob* Job) final;
|
|
|
|
|
void DispatchResolveInputMeta(IBuildJob* Job) final;
|
|
|
|
|
void DispatchResolveInputData(IBuildJob* Job, const FBuildSchedulerParams& Params) final;
|
|
|
|
|
void DispatchExecuteRemote(IBuildJob* Job, const FBuildSchedulerParams& Params) final;
|
|
|
|
|
void DispatchExecuteLocal(IBuildJob* Job, const FBuildSchedulerParams& Params) final;
|
2021-05-25 13:27:48 -04:00
|
|
|
};
|
|
|
|
|
|
2021-07-16 01:25:15 -04:00
|
|
|
void FBuildScheduler::DispatchCacheQuery(IBuildJob* Job, const FBuildSchedulerParams& Params)
|
|
|
|
|
{
|
|
|
|
|
Job->Schedule();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void FBuildScheduler::DispatchCacheStore(IBuildJob* Job, const FBuildSchedulerParams& Params)
|
|
|
|
|
{
|
|
|
|
|
Job->Schedule();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void FBuildScheduler::DispatchResolveKey(IBuildJob* Job)
|
|
|
|
|
{
|
|
|
|
|
if (Job->GetPriority() == EPriority::Blocking)
|
|
|
|
|
{
|
|
|
|
|
Job->Schedule();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Tasks::Launch(TEXT("FBuildScheduler::DispatchResolveKey"),
|
|
|
|
|
[Job = TRequest(Job)] { Job->Schedule(); },
|
|
|
|
|
LowLevelTasks::ETaskPriority::BackgroundNormal);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void FBuildScheduler::DispatchResolveInputMeta(IBuildJob* Job)
|
|
|
|
|
{
|
|
|
|
|
if (Job->GetPriority() == EPriority::Blocking)
|
|
|
|
|
{
|
|
|
|
|
Job->Schedule();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Tasks::Launch(TEXT("FBuildScheduler::DispatchResolveInputMeta"),
|
|
|
|
|
[Job = TRequest(Job)] { Job->Schedule(); },
|
|
|
|
|
LowLevelTasks::ETaskPriority::BackgroundNormal);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void FBuildScheduler::DispatchResolveInputData(IBuildJob* Job, const FBuildSchedulerParams& Params)
|
|
|
|
|
{
|
|
|
|
|
if (Job->GetPriority() == EPriority::Blocking)
|
|
|
|
|
{
|
|
|
|
|
Job->Schedule();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Tasks::Launch(TEXT("FBuildScheduler::DispatchResolveInputData"),
|
|
|
|
|
[Job = TRequest(Job)] { Job->Schedule(); },
|
|
|
|
|
LowLevelTasks::ETaskPriority::BackgroundNormal);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void FBuildScheduler::DispatchExecuteRemote(IBuildJob* Job, const FBuildSchedulerParams& Params)
|
|
|
|
|
{
|
|
|
|
|
if (Job->GetPriority() == EPriority::Blocking)
|
|
|
|
|
{
|
|
|
|
|
Job->Schedule();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Tasks::Launch(TEXT("FBuildScheduler::DispatchExecuteRemote"),
|
|
|
|
|
[Job = TRequest(Job)] { Job->Schedule(); },
|
|
|
|
|
LowLevelTasks::ETaskPriority::BackgroundNormal);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void FBuildScheduler::DispatchExecuteLocal(IBuildJob* Job, const FBuildSchedulerParams& Params)
|
|
|
|
|
{
|
|
|
|
|
if (Job->GetPriority() == EPriority::Blocking)
|
|
|
|
|
{
|
|
|
|
|
Job->Schedule();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Tasks::Launch(TEXT("FBuildScheduler::DispatchExecuteLocal"),
|
|
|
|
|
[Job = TRequest(Job)] { Job->Schedule(); },
|
|
|
|
|
LowLevelTasks::ETaskPriority::BackgroundNormal);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-25 13:27:48 -04:00
|
|
|
IBuildScheduler* CreateBuildScheduler()
|
|
|
|
|
{
|
|
|
|
|
return new FBuildScheduler();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // UE::DerivedData::Private
|