fix: username

This commit is contained in:
xkeyC 2025-12-17 22:28:12 +08:00
parent 750f3b1fee
commit dc163d790c

View File

@ -259,8 +259,7 @@ class _SessionInfo {
///
class YearlyReportAnalyzer {
//
static final _characterNamePattern = RegExp(r'name\s+(\w+)\s+signedIn');
static final _characterNamePattern = RegExp(r'name\s+([^-]+)');
static final _vehicleDestructionPattern = RegExp(
r"Vehicle\s+'([^']+)'.*?" //
r"in zone\s+'([^']+)'.*?" // Zone
@ -274,7 +273,6 @@ class YearlyReportAnalyzer {
);
// Legacy ()
static final _legacyCharacterNamePattern = RegExp(r"name\s+([^-]+)");
static final _legacyActorDeathPattern = RegExp(
r"CActor::Kill: '([^']+)'.*?" // ID
r"in zone '([^']+)'.*?" //
@ -315,16 +313,16 @@ class YearlyReportAnalyzer {
stats.hasCrash = true;
}
// ()
var nameMatch = _characterNamePattern.firstMatch(line);
nameMatch ??= _legacyCharacterNamePattern.firstMatch(line);
//
if (line.contains('AccountLoginCharacterStatus_Character')) {
final nameMatch = _characterNamePattern.firstMatch(line);
if (nameMatch != null) {
final playerName = nameMatch.group(1)?.trim();
if (playerName != null &&
playerName.isNotEmpty &&
!playerName.contains(' ') &&
!playerName.contains('/') &&
!playerName.contains(r'\') &&
!playerName.contains(r'\\') &&
!playerName.contains('.')) {
stats.currentPlayerName = playerName;
// ()
@ -334,6 +332,7 @@ class YearlyReportAnalyzer {
stats.firstPlayerName ??= playerName;
}
}
}
//
if (lineTime != null && lineTime.year == targetYear) {
@ -358,9 +357,12 @@ class YearlyReportAnalyzer {
final vehicleName = controlMatch.group(1);
if (vehicleName != null) {
final cleanVehicleName = GameLogAnalyzer.removeVehicleId(vehicleName);
// "Default"
if (cleanVehicleName != 'Default') {
stats.vehiclePiloted[cleanVehicleName] = (stats.vehiclePiloted[cleanVehicleName] ?? 0) + 1;
}
}
}
// ()
var deathMatch = _actorDeathPattern.firstMatch(line);