fix: YearlyReportData error

This commit is contained in:
xkeyC 2025-12-18 11:14:22 +08:00
parent 00e8b0c303
commit 4b2ac25c1f

View File

@ -285,11 +285,11 @@ class YearlyReportAnalyzer {
static Future<_LogFileStats> _analyzeLogFile(File logFile, int targetYear) async {
final stats = _LogFileStats();
if (!(await logFile.exists())) {
return stats;
}
try {
if (!(await logFile.exists())) {
return stats;
}
final content = utf8.decode(await logFile.readAsBytes(), allowMalformed: true);
final lines = content.split('\n');
@ -472,33 +472,53 @@ class YearlyReportAnalyzer {
//
for (final installPath in gameInstallPaths) {
final installDir = Directory(installPath);
try {
final installDir = Directory(installPath);
//
if (!await installDir.exists()) {
continue;
}
final gameLogFile = File('$installPath/Game.log');
final logBackupsDir = Directory('$installPath/logbackups');
// Game.log
if (await gameLogFile.exists()) {
allLogFiles.add(gameLogFile);
}
//
if (await logBackupsDir.exists()) {
await for (final entity in logBackupsDir.list()) {
if (entity is File && entity.path.endsWith('.log')) {
allLogFiles.add(entity);
}
//
if (!await installDir.exists()) {
continue;
}
final gameLogFile = File('$installPath/Game.log');
final logBackupsDir = Directory('$installPath/logbackups');
// Game.log
try {
if (await gameLogFile.exists()) {
allLogFiles.add(gameLogFile);
}
} catch (_) {
//
}
//
try {
if (await logBackupsDir.exists()) {
await for (final entity in logBackupsDir.list()) {
if (entity is File && entity.path.endsWith('.log')) {
allLogFiles.add(entity);
}
}
}
} catch (_) {
//
}
} catch (_) {
//
continue;
}
}
//
final futures = allLogFiles.map((file) => _analyzeLogFile(file, targetYear));
// 使
final futures = allLogFiles.map((file) async {
try {
return await _analyzeLogFile(file, targetYear);
} catch (_) {
//
return _LogFileStats();
}
});
final allStatsRaw = await Future.wait(futures);
// : 使 uniqueKey ( + )