You've already forked UnrealEngineUWP
mirror of
https://github.com/izzy2lost/UnrealEngineUWP.git
synced 2026-03-26 18:15:20 -07:00
#rnx #rb none #jira none #ROBOMERGE-OWNER: ryan.durand #ROBOMERGE-AUTHOR: ryan.durand #ROBOMERGE-SOURCE: CL 10869242 in //Fortnite/Release-12.00/... via CL 10869536 #ROBOMERGE-BOT: FORTNITE (Main -> Dev-EngineMerge) (v613-10869866) [CL 10870955 by Ryan Durand in Main branch]
101 lines
2.6 KiB
C++
101 lines
2.6 KiB
C++
// Copyright Epic Games, Inc. All Rights Reserved.
|
|
|
|
#include "LiveCodingManifest.h"
|
|
#include "Misc/FileHelper.h"
|
|
|
|
bool FLiveCodingManifest::Read(const TCHAR* FileName, FString& OutFailReason)
|
|
{
|
|
// Read the file to a string
|
|
FString FileContents;
|
|
if (!FFileHelper::LoadFileToString(FileContents, FileName))
|
|
{
|
|
OutFailReason = FString::Printf(TEXT("Unable to read from %s"), FileName);
|
|
return false;
|
|
}
|
|
|
|
// Deserialize a JSON object from the string
|
|
TSharedPtr< FJsonObject > Object;
|
|
TSharedRef< TJsonReader<> > Reader = TJsonReaderFactory<>::Create(FileContents);
|
|
if ( !FJsonSerializer::Deserialize(Reader, Object) || !Object.IsValid() )
|
|
{
|
|
OutFailReason = FString::Printf(TEXT("Unable to parse %s"), FileName);
|
|
return false;
|
|
}
|
|
|
|
// Parse the data
|
|
if (!Parse(*Object, OutFailReason))
|
|
{
|
|
OutFailReason = FString::Printf(TEXT("Unable to parse %s (%s)"), FileName, *OutFailReason);
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
bool FLiveCodingManifest::Parse(FJsonObject& Object, FString& OutFailReason)
|
|
{
|
|
if (!Object.TryGetStringField(TEXT("LinkerPath"), LinkerPath))
|
|
{
|
|
OutFailReason = TEXT("missing LinkerPath field");
|
|
return false;
|
|
}
|
|
|
|
const TSharedPtr<FJsonObject>* EnvironmentObject;
|
|
if (Object.TryGetObjectField(TEXT("LinkerEnvironment"), EnvironmentObject))
|
|
{
|
|
for(const TPair<FString, TSharedPtr<FJsonValue>>& Pair : EnvironmentObject->Get()->Values)
|
|
{
|
|
const FJsonValue* Value = Pair.Value.Get();
|
|
if (Value->Type == EJson::String)
|
|
{
|
|
LinkerEnvironment.Add(Pair.Key, Value->AsString());
|
|
}
|
|
}
|
|
}
|
|
|
|
const TArray<TSharedPtr<FJsonValue>>* ModulesArray;
|
|
if (!Object.TryGetArrayField(TEXT("Modules"), ModulesArray))
|
|
{
|
|
OutFailReason = TEXT("missing Modules field");
|
|
return false;
|
|
}
|
|
|
|
for (const TSharedPtr<FJsonValue>& ModuleValue : *ModulesArray)
|
|
{
|
|
if (ModuleValue->Type != EJson::Object)
|
|
{
|
|
OutFailReason = TEXT("invalid module object");
|
|
return false;
|
|
}
|
|
|
|
const FJsonObject& ModuleObject = *ModuleValue->AsObject();
|
|
|
|
FString OutputFile;
|
|
if (!ModuleObject.TryGetStringField(TEXT("Output"), OutputFile))
|
|
{
|
|
OutFailReason = TEXT("missing module 'Output' field");
|
|
return false;
|
|
}
|
|
|
|
const TArray<TSharedPtr<FJsonValue>>* Inputs;
|
|
if (!ModuleObject.TryGetArrayField(TEXT("Inputs"), Inputs))
|
|
{
|
|
OutFailReason = TEXT("missing module 'Inputs' field");
|
|
return false;
|
|
}
|
|
|
|
TArray<FString>& InputFiles = BinaryToObjectFiles.Add(OutputFile);
|
|
for (const TSharedPtr<FJsonValue>& Input : *Inputs)
|
|
{
|
|
if (Input->Type != EJson::String)
|
|
{
|
|
OutFailReason = TEXT("invalid module input field");
|
|
return false;
|
|
}
|
|
InputFiles.Add(Input->AsString());
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|