From cee0e2974b47e020f12dd1dc36a730f838d13966 Mon Sep 17 00:00:00 2001 From: Klenje Date: Mon, 27 Oct 2014 21:57:38 +0100 Subject: [PATCH] Improve regexp Avoid calling the static method at each iteration --- KeeStatsExt.cs | 2 +- StatComputer.cs | 21 ++++++++++++++------- 2 files changed, 15 insertions(+), 8 deletions(-) diff --git a/KeeStatsExt.cs b/KeeStatsExt.cs index 90caca1..0cc8c2d 100644 --- a/KeeStatsExt.cs +++ b/KeeStatsExt.cs @@ -66,7 +66,7 @@ public override bool Initialize(IPluginHost host) tsMenu.Add(m_tsSeparator); m_tsmiStats = new ToolStripMenuItem(); - m_tsmiStats.Text = "View stats..."; + m_tsmiStats.Text = "&View stats..."; tsMenu.Add(m_tsmiStats); m_tsmiStats.Click += OnMenuViewStats; diff --git a/StatComputer.cs b/StatComputer.cs index b58b4e2..1ca70fa 100644 --- a/StatComputer.cs +++ b/StatComputer.cs @@ -86,7 +86,14 @@ public static bool ComputeStats(PwGroup group, ref List genericStats, const string alphanumericOnlyPattern = "^(?=.*[A-Za-z])(?=.*[0-9])[A-Za-z0-9]+$"; const string notAlphanumericOnlyPattern = "^[^A-Za-z0-9]+$"; - Dictionary passwords = new Dictionary(); + var refRegex = new System.Text.RegularExpressions.Regex(refPattern); + var lowercaseOnlyRegex = new System.Text.RegularExpressions.Regex(lowercaseOnlyPattern); + var uppercaseOnlyRegex = new System.Text.RegularExpressions.Regex(uppercaseOnlyPattern); + var numericOnlyRegex = new System.Text.RegularExpressions.Regex(numericOnlyPattern); + var alphanumericOnlyRegex = new System.Text.RegularExpressions.Regex(alphanumericOnlyPattern); + var notAlphanumericOnlyRegex = new System.Text.RegularExpressions.Regex(notAlphanumericOnlyPattern); + + var passwords = new Dictionary(); foreach (PwEntry aPasswordObject in group.GetEntries(isRecursive)) { try { @@ -105,22 +112,22 @@ public static bool ComputeStats(PwGroup group, ref List genericStats, emptyPasswords++; continue; } - if (System.Text.RegularExpressions.Regex.IsMatch(thePasswordString, refPattern)) { + if (refRegex.IsMatch(thePasswordString)) { referencedPasswords++; continue; } // quality stats on password content. Currently exlusive content. Doesn't scale currently - if (System.Text.RegularExpressions.Regex.IsMatch(thePasswordString, lowercaseOnlyPattern)) { + if (lowercaseOnlyRegex.IsMatch(thePasswordString)) { // only lowercase lowercaseOnlyPasswords++; - } else if (System.Text.RegularExpressions.Regex.IsMatch(thePasswordString, uppercaseOnlyPattern)) { + } else if (uppercaseOnlyRegex.IsMatch(thePasswordString)) { uppercaseOnlyPasswords++; - } else if (System.Text.RegularExpressions.Regex.IsMatch(thePasswordString, numericOnlyPattern)) { + } else if (numericOnlyRegex.IsMatch(thePasswordString)) { numericOnlyPasswords++; - } else if (System.Text.RegularExpressions.Regex.IsMatch(thePasswordString, alphanumericOnlyPattern)) { + } else if (alphanumericOnlyRegex.IsMatch(thePasswordString)) { alphanumericOnlyPasswords++; - } else if (System.Text.RegularExpressions.Regex.IsMatch(thePasswordString, notAlphanumericOnlyPattern)) { + } else if (notAlphanumericOnlyRegex.IsMatch(thePasswordString)) { notAlphanumericOnlyPasswords++; }