Modify ISaveDataFileSystemCreator

This commit is contained in:
Alex Barney 2021-04-29 16:10:55 -07:00
parent 649c72e5e6
commit 25b94292b3
3 changed files with 39 additions and 25 deletions

View file

@ -9,10 +9,10 @@ namespace LibHac.FsSrv.FsCreator
{
Result CreateFile(out IFile file, IFileSystem sourceFileSystem, ulong saveDataId, OpenMode openMode);
Result Create(out IFileSystem fileSystem,
out ReferenceCountedDisposable<ISaveDataExtraDataAccessor> extraDataAccessor, IFileSystem sourceFileSystem,
ulong saveDataId, bool allowDirectorySaveData, bool useDeviceUniqueMac, SaveDataType type,
ISaveDataCommitTimeStampGetter timeStampGetter);
Result Create(out ReferenceCountedDisposable<IFileSystem> fileSystem,
out ReferenceCountedDisposable<ISaveDataExtraDataAccessor> extraDataAccessor,
ReferenceCountedDisposable<IFileSystem> sourceFileSystem, ulong saveDataId, bool allowDirectorySaveData,
bool useDeviceUniqueMac, SaveDataType type, ISaveDataCommitTimeStampGetter timeStampGetter);
void SetSdCardEncryptionSeed(ReadOnlySpan<byte> seed);
}

View file

@ -28,16 +28,16 @@ namespace LibHac.FsSrv.FsCreator
throw new NotImplementedException();
}
public Result Create(out IFileSystem fileSystem,
out ReferenceCountedDisposable<ISaveDataExtraDataAccessor> extraDataAccessor, IFileSystem sourceFileSystem,
ulong saveDataId, bool allowDirectorySaveData, bool useDeviceUniqueMac, SaveDataType type,
ISaveDataCommitTimeStampGetter timeStampGetter)
public Result Create(out ReferenceCountedDisposable<IFileSystem> fileSystem,
out ReferenceCountedDisposable<ISaveDataExtraDataAccessor> extraDataAccessor,
ReferenceCountedDisposable<IFileSystem> sourceFileSystem, ulong saveDataId, bool allowDirectorySaveData,
bool useDeviceUniqueMac, SaveDataType type, ISaveDataCommitTimeStampGetter timeStampGetter)
{
UnsafeHelpers.SkipParamInit(out fileSystem, out extraDataAccessor);
var saveDataPath = $"/{saveDataId:x16}".ToU8String();
Result rc = sourceFileSystem.GetEntryType(out DirectoryEntryType entryType, saveDataPath);
Result rc = sourceFileSystem.Target.GetEntryType(out DirectoryEntryType entryType, saveDataPath);
if (rc.IsFailure())
{
return ResultFs.PathNotFound.Includes(rc) ? ResultFs.TargetNotFound.LogConverted(rc) : rc;
@ -48,30 +48,43 @@ namespace LibHac.FsSrv.FsCreator
case DirectoryEntryType.Directory:
if (!allowDirectorySaveData) return ResultFs.InvalidSaveDataEntryType.Log();
rc = SubdirectoryFileSystem.CreateNew(out SubdirectoryFileSystem subDirFs, sourceFileSystem,
saveDataPath);
if (rc.IsFailure()) return rc;
var subDirFs = new SubdirectoryFileSystem(ref sourceFileSystem);
rc = subDirFs.Initialize(saveDataPath);
if (rc.IsFailure())
{
subDirFs.Dispose();
return rc;
}
bool isPersistentSaveData = type != SaveDataType.Temporary;
bool isUserSaveData = type == SaveDataType.Account || type == SaveDataType.Device;
rc = DirectorySaveDataFileSystem.CreateNew(out DirectorySaveDataFileSystem saveFs, subDirFs,
isPersistentSaveData, isUserSaveData, true);
timeStampGetter, _randomGenerator, isPersistentSaveData, isUserSaveData, true, null);
if (rc.IsFailure()) return rc;
fileSystem = saveFs;
// Todo: Dummy ISaveDataExtraDataAccessor
ReferenceCountedDisposable<DirectorySaveDataFileSystem> sharedSaveFs = null;
try
{
sharedSaveFs = new ReferenceCountedDisposable<DirectorySaveDataFileSystem>(saveFs);
fileSystem = sharedSaveFs.AddReference<IFileSystem>();
extraDataAccessor = sharedSaveFs.AddReference<ISaveDataExtraDataAccessor>();
return Result.Success;
}
finally
{
sharedSaveFs?.Dispose();
}
case DirectoryEntryType.File:
rc = sourceFileSystem.OpenFile(out IFile saveDataFile, saveDataPath, OpenMode.ReadWrite);
rc = sourceFileSystem.Target.OpenFile(out IFile saveDataFile, saveDataPath, OpenMode.ReadWrite);
if (rc.IsFailure()) return rc;
var saveDataStorage = new DisposingFileStorage(saveDataFile);
fileSystem = new SaveDataFileSystem(_keySet, saveDataStorage, IntegrityCheckLevel.ErrorOnInvalid,
false);
fileSystem = new ReferenceCountedDisposable<IFileSystem>(new SaveDataFileSystem(_keySet,
saveDataStorage, IntegrityCheckLevel.ErrorOnInvalid, false));
// Todo: ISaveDataExtraDataAccessor

View file

@ -146,18 +146,18 @@ namespace LibHac.FsSrv
// ReSharper disable once ConditionIsAlwaysTrueOrFalse
if (saveDataFs is null)
{
ReferenceCountedDisposable<IFileSystem> saveFs = null;
ReferenceCountedDisposable<ISaveDataExtraDataAccessor> extraDataAccessor = null;
try
{
// Todo: Update ISaveDataFileSystemCreator
bool useDeviceUniqueMac = IsDeviceUniqueMac(spaceId);
rc = _config.SaveFsCreator.Create(out IFileSystem saveFs,
out extraDataAccessor, saveDirectoryFs.Target, saveDataId,
allowDirectorySaveData, useDeviceUniqueMac, type, _timeStampGetter);
rc = _config.SaveFsCreator.Create(out saveFs, out extraDataAccessor, saveDirectoryFs,
saveDataId, allowDirectorySaveData, useDeviceUniqueMac, type, _timeStampGetter);
if (rc.IsFailure()) return rc;
saveDataFs = new ReferenceCountedDisposable<IFileSystem>(saveFs);
saveDataFs = Shared.Move(ref saveFs);
if (cacheExtraData)
{
@ -166,6 +166,7 @@ namespace LibHac.FsSrv
}
finally
{
saveFs?.Dispose();
extraDataAccessor?.Dispose();
}
}