fix: 微信小游戏文件系统缓存查询机制不生效

pull/464/head
阿枫 2025-02-10 00:43:53 +08:00 committed by GitHub
parent 30cba8ca5f
commit 37624b33d1
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 26 additions and 2 deletions

View File

@ -1,4 +1,4 @@
#if UNITY_WEBGL && WEIXINMINIGAME #if UNITY_WEBGL && WEIXINMINIGAME
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
@ -57,6 +57,7 @@ internal class WechatFileSystem : IFileSystem
private readonly Dictionary<string, string> _cacheFilePaths = new Dictionary<string, string>(10000); private readonly Dictionary<string, string> _cacheFilePaths = new Dictionary<string, string>(10000);
private WXFileSystemManager _fileSystemMgr; private WXFileSystemManager _fileSystemMgr;
private string _wxCacheRoot = string.Empty; private string _wxCacheRoot = string.Empty;
private string _recordsFilePath = string.Empty;
/// <summary> /// <summary>
/// 包裹名称 /// 包裹名称
@ -176,6 +177,7 @@ internal class WechatFileSystem : IFileSystem
{ {
PackageName = packageName; PackageName = packageName;
_wxCacheRoot = rootDirectory; _wxCacheRoot = rootDirectory;
_recordsFilePath = PathUtility.Combine(FileRoot, "__GAME_FILE_CACHE", "cache_records");
if (string.IsNullOrEmpty(_wxCacheRoot)) if (string.IsNullOrEmpty(_wxCacheRoot))
{ {
@ -190,6 +192,24 @@ internal class WechatFileSystem : IFileSystem
} }
_fileSystemMgr = WX.GetFileSystemManager(); _fileSystemMgr = WX.GetFileSystemManager();
// 读取本地文件缓存记录
if (CheckCacheFileExist(_recordsFilePath))
{
string recordText = _fileSystemMgr.ReadFileSync(_recordsFilePath, "utf8");
if (string.IsNullOrEmpty(recordText) == false)
{
string[] records = recordText.Split(',', StringSplitOptions.RemoveEmptyEntries);
foreach (var record in records)
{
_recorders.Add(record);
}
}
}
else
{
_fileSystemMgr.WriteFileSync(_recordsFilePath, string.Empty);
}
} }
public virtual void OnUpdate() public virtual void OnUpdate()
{ {
@ -276,6 +296,7 @@ internal class WechatFileSystem : IFileSystem
} }
_recorders.Add(filePath); _recorders.Add(filePath);
_fileSystemMgr.AppendFileSync(_recordsFilePath, filePath + ",");
return true; return true;
} }
public void TryRecordBundle(PackageBundle bundle) public void TryRecordBundle(PackageBundle bundle)
@ -284,11 +305,13 @@ internal class WechatFileSystem : IFileSystem
if (_recorders.Contains(filePath) == false) if (_recorders.Contains(filePath) == false)
{ {
_recorders.Add(filePath); _recorders.Add(filePath);
_fileSystemMgr.AppendFileSync(_recordsFilePath, filePath + ",");
} }
} }
public void ClearAllRecords() public void ClearAllRecords()
{ {
_recorders.Clear(); _recorders.Clear();
_fileSystemMgr.WriteFileSync(_recordsFilePath, string.Empty);
} }
public void ClearRecord(string filePath) public void ClearRecord(string filePath)
{ {
@ -296,7 +319,8 @@ internal class WechatFileSystem : IFileSystem
{ {
_recorders.Remove(filePath); _recorders.Remove(filePath);
} }
//TODO: 这里没做记录移除,因为耗时,后续可以看情况添加
} }
#endregion #endregion
} }
#endif #endif