Using static Regex functions that take in a pattern is bad because the pattern constantly needs to be re-parsed. With https://github.com/space-wizards/RobustToolbox/pull/5107, the engine has an analyzer to warn for this practice now. This commit brings most of content up to snuff already, though some of the tricker code I left for somebody else.
33 lines
1.0 KiB
C#
33 lines
1.0 KiB
C#
using System.Text.RegularExpressions;
|
|
using Content.Server.Speech.Components;
|
|
|
|
namespace Content.Server.Speech.EntitySystems;
|
|
|
|
public sealed class SouthernAccentSystem : EntitySystem
|
|
{
|
|
private static readonly Regex RegexIng = new(@"ing\b");
|
|
private static readonly Regex RegexAnd = new(@"\band\b");
|
|
private static readonly Regex RegexDve = new("d've");
|
|
|
|
[Dependency] private readonly ReplacementAccentSystem _replacement = default!;
|
|
|
|
public override void Initialize()
|
|
{
|
|
base.Initialize();
|
|
SubscribeLocalEvent<SouthernAccentComponent, AccentGetEvent>(OnAccent);
|
|
}
|
|
|
|
private void OnAccent(EntityUid uid, SouthernAccentComponent component, AccentGetEvent args)
|
|
{
|
|
var message = args.Message;
|
|
|
|
message = _replacement.ApplyReplacements(message, "southern");
|
|
|
|
//They shoulda started runnin' an' hidin' from me!
|
|
message = RegexIng.Replace(message, "in'");
|
|
message = RegexAnd.Replace(message, "an'");
|
|
message = RegexDve.Replace(message, "da");
|
|
args.Message = message;
|
|
}
|
|
};
|