diff --git a/Plugins/Wox.Plugin.Program/Logger/ProgramLogger.cs b/Plugins/Wox.Plugin.Program/Logger/ProgramLogger.cs index e3dec0dfa3..587aba6857 100644 --- a/Plugins/Wox.Plugin.Program/Logger/ProgramLogger.cs +++ b/Plugins/Wox.Plugin.Program/Logger/ProgramLogger.cs @@ -41,21 +41,13 @@ namespace Wox.Plugin.Program.Logger } /// - /// Please follow exception format, there are four parts to an error message that need to be specified: - /// |class name|calling method name|loading program path|user friendly message that explains the error - /// => Example: |Win32|LnkProgram|c:\..\chrome.exe|Permission denied on directory, but Wox should continue + /// Logs an exception /// [MethodImpl(MethodImplOptions.Synchronized)] - internal static void LogException(string message, Exception e) + internal static void LogException(string classname, string callingMethodName, string loadingProgramPath, + string interpretationMessage, Exception e) { - //Index 0 is always empty. - var parts = message.Split('|'); - var classname = parts[1]; - var callingMethodName = parts[2]; - var loadingProgramPath = parts[3]; - var interpretationMessage = parts[4]; - - Debug.WriteLine($"ERROR{message}"); + Debug.WriteLine($"ERROR{classname}|{callingMethodName}|{loadingProgramPath}|{interpretationMessage}"); var logger = LogManager.GetLogger(""); @@ -79,16 +71,16 @@ namespace Wox.Plugin.Program.Logger calledMethod = string.IsNullOrEmpty(calledMethod) ? "Not available" : calledMethod; logger.Error($"\nException full name: {e.GetType().FullName}" - + $"\nError status: {errorStatus}" - + $"\nClass name: {classname}" - + $"\nCalling method: {callingMethodName}" - + $"\nProgram path: {loadingProgramPath}" - + $"\nInnerException number: {innerExceptionNumber}" - + $"\nException message: {e.Message}" - + $"\nException error type: HResult {e.HResult}" - + $"\nException thrown in called method: {calledMethod}" - + $"\nPossible interpretation of the error: {interpretationMessage}" - + $"\nPossible resolution: {possibleResolution}"); + + $"\nError status: {errorStatus}" + + $"\nClass name: {classname}" + + $"\nCalling method: {callingMethodName}" + + $"\nProgram path: {loadingProgramPath}" + + $"\nInnerException number: {innerExceptionNumber}" + + $"\nException message: {e.Message}" + + $"\nException error type: HResult {e.HResult}" + + $"\nException thrown in called method: {calledMethod}" + + $"\nPossible interpretation of the error: {interpretationMessage}" + + $"\nPossible resolution: {possibleResolution}"); innerExceptionNumber++; e = e.InnerException; @@ -97,6 +89,29 @@ namespace Wox.Plugin.Program.Logger logger.Error("------------- END Wox.Plugin.Program exception -------------"); } + /// + /// Please follow exception format: |class name|calling method name|loading program path|user friendly message that explains the error + /// => Example: |Win32|LnkProgram|c:\..\chrome.exe|Permission denied on directory, but Wox should continue + /// + [MethodImpl(MethodImplOptions.Synchronized)] + internal static void LogException(string message, Exception e) + { + //Index 0 is always empty. + var parts = message.Split('|'); + if (parts.Length < 4) + { + var logger = LogManager.GetLogger(""); + logger.Error(e, $"fail to log exception in program logger, parts length is too small: {parts.Length}, message: {message}"); + } + + var classname = parts[1]; + var callingMethodName = parts[2]; + var loadingProgramPath = parts[3]; + var interpretationMessage = parts[4]; + + LogException(classname, callingMethodName, loadingProgramPath, interpretationMessage, e); + } + private static bool IsKnownWinProgramError(Exception e, string callingMethodName) { if (e.TargetSite?.Name == "GetDescription" && callingMethodName == "LnkProgram") diff --git a/Plugins/Wox.Plugin.Program/Main.cs b/Plugins/Wox.Plugin.Program/Main.cs index 0a6f37a4a0..e165a10826 100644 --- a/Plugins/Wox.Plugin.Program/Main.cs +++ b/Plugins/Wox.Plugin.Program/Main.cs @@ -90,9 +90,10 @@ namespace Wox.Plugin.Program public static void IndexWin32Programs() { + var win32S = Win32.All(_settings); lock (IndexLock) { - _win32s = Win32.All(_settings); + _win32s = win32S; } } @@ -101,17 +102,18 @@ namespace Wox.Plugin.Program var windows10 = new Version(10, 0); var support = Environment.OSVersion.Version.Major >= windows10.Major; + var applications = support ? UWP.All() : new UWP.Application[] { }; lock (IndexLock) { - _uwps = support ? UWP.All() : new UWP.Application[] { }; + _uwps = applications; } } public static void IndexPrograms() { - var t1 = Task.Run(() => { IndexWin32Programs(); }); + var t1 = Task.Run(()=>IndexWin32Programs()); - var t2 = Task.Run(() => { IndexUWPPrograms(); }); + var t2 = Task.Run(()=>IndexUWPPrograms()); Task.WaitAll(t1, t2); diff --git a/Plugins/Wox.Plugin.Program/Programs/UWP.cs b/Plugins/Wox.Plugin.Program/Programs/UWP.cs index 60f978b9dc..77d33e2e2f 100644 --- a/Plugins/Wox.Plugin.Program/Programs/UWP.cs +++ b/Plugins/Wox.Plugin.Program/Programs/UWP.cs @@ -165,9 +165,9 @@ namespace Wox.Plugin.Program.Programs } #endif #if DEBUG //make developer aware and implement handling - catch(Exception e) + catch { - throw e; + throw; } #endif return u.Apps; @@ -207,7 +207,7 @@ namespace Wox.Plugin.Program.Programs } catch (Exception e) { - ProgramLogger.LogException("|UWP|CurrentUserPackages|Not available|An unexpected error occured and " + ProgramLogger.LogException("UWP" ,"CurrentUserPackages", $"id","An unexpected error occured and " + $"unable to verify if package is valid", e); return false; } @@ -230,8 +230,7 @@ namespace Wox.Plugin.Program.Programs public override bool Equals(object obj) { - var uwp = obj as UWP; - if (uwp != null) + if (obj is UWP uwp) { return FamilyName.Equals(uwp.FamilyName); } diff --git a/Wox.Infrastructure/Alphabet.cs b/Wox.Infrastructure/Alphabet.cs index 157d1c9f1f..d7fae882cb 100644 --- a/Wox.Infrastructure/Alphabet.cs +++ b/Wox.Infrastructure/Alphabet.cs @@ -6,6 +6,7 @@ using hyjiacan.util.p4n; using hyjiacan.util.p4n.format; using Wox.Infrastructure.Logger; using Wox.Infrastructure.Storage; +using Wox.Infrastructure.UserSettings; namespace Wox.Infrastructure { @@ -14,9 +15,11 @@ namespace Wox.Infrastructure private static readonly HanyuPinyinOutputFormat Format = new HanyuPinyinOutputFormat(); private static ConcurrentDictionary PinyinCache; private static BinaryStorage> _pinyinStorage; + private static Settings _settings; - public static void Initialize() + public static void Initialize(Settings settings) { + _settings = settings; Format.setToneType(HanyuPinyinToneType.WITHOUT_TONE); Stopwatch.Normal("|Wox.Infrastructure.Alphabet.Initialize|Preload pinyin cache", () => @@ -34,12 +37,20 @@ namespace Wox.Infrastructure _pinyinStorage.Save(PinyinCache); } + private static string[] EmptyStringArray = new string[0]; + private static string[][] Empty2DStringArray = new string[0][]; + /// /// replace chinese character with pinyin, non chinese character won't be modified /// should be word or sentence, instead of single character. e.g. 微软 /// public static string[] Pinyin(string word) { + if (!_settings.ShouldUsePinyin) + { + return EmptyStringArray; + } + var pinyin = word.Select(c => { var pinyins = PinyinHelper.toHanyuPinyinStringArray(c); @@ -57,7 +68,7 @@ namespace Wox.Infrastructure /// public static string[][] PinyinComination(string characters) { - if (!string.IsNullOrEmpty(characters)) + if (_settings.ShouldUsePinyin && !string.IsNullOrEmpty(characters)) { if (!PinyinCache.ContainsKey(characters)) { @@ -89,7 +100,7 @@ namespace Wox.Infrastructure } else { - return new string[][] { }; + return Empty2DStringArray; } } @@ -101,6 +112,17 @@ namespace Wox.Infrastructure public static bool ContainsChinese(string word) { + if (!_settings.ShouldUsePinyin) + { + return false; + } + + if (word.Length > 40) + { + Log.Debug($"|Wox.Infrastructure.StringMatcher.ScoreForPinyin|skip too long string: {word}"); + return false; + } + var chinese = word.Select(PinyinHelper.toHanyuPinyinStringArray) .Any(p => p != null); return chinese; @@ -108,6 +130,11 @@ namespace Wox.Infrastructure private static string[] Combination(string[] array1, string[] array2) { + if (!_settings.ShouldUsePinyin) + { + return EmptyStringArray; + } + var combination = ( from a1 in array1 from a2 in array2 diff --git a/Wox.Infrastructure/StringMatcher.cs b/Wox.Infrastructure/StringMatcher.cs index 9c49b4119b..5b82b18918 100644 --- a/Wox.Infrastructure/StringMatcher.cs +++ b/Wox.Infrastructure/StringMatcher.cs @@ -131,12 +131,6 @@ namespace Wox.Infrastructure { if (!string.IsNullOrEmpty(source) && !string.IsNullOrEmpty(target)) { - if(source.Length > 40) - { - Log.Debug($"|Wox.Infrastructure.StringMatcher.ScoreForPinyin|skip too long string: {source}"); - return 0; - } - if (Alphabet.ContainsChinese(source)) { var combination = Alphabet.PinyinComination(source); diff --git a/Wox.Infrastructure/UserSettings/Settings.cs b/Wox.Infrastructure/UserSettings/Settings.cs index 75f4393575..7371ea5d05 100644 --- a/Wox.Infrastructure/UserSettings/Settings.cs +++ b/Wox.Infrastructure/UserSettings/Settings.cs @@ -21,6 +21,11 @@ namespace Wox.Infrastructure.UserSettings public string ResultFontWeight { get; set; } public string ResultFontStretch { get; set; } + /// + /// when false Alphabet static service will always return empty results + /// + public bool ShouldUsePinyin { get; set; } = true; + private string _querySearchPrecision { get; set; } = StringMatcher.SearchPrecisionScore.Regular.ToString(); public string QuerySearchPrecision { diff --git a/Wox/App.xaml.cs b/Wox/App.xaml.cs index b66549b38a..0ec1614bf9 100644 --- a/Wox/App.xaml.cs +++ b/Wox/App.xaml.cs @@ -49,11 +49,12 @@ namespace Wox RegisterDispatcherUnhandledException(); ImageLoader.Initialize(); - Alphabet.Initialize(); _settingsVM = new SettingWindowViewModel(); _settings = _settingsVM.Settings; + Alphabet.Initialize(_settings); + StringMatcher.UserSettingSearchPrecision = _settings.QuerySearchPrecision; PluginManager.LoadPlugins(_settings.PluginSettings); diff --git a/Wox/Languages/en.xaml b/Wox/Languages/en.xaml index ae8041121c..dca044dc11 100644 --- a/Wox/Languages/en.xaml +++ b/Wox/Languages/en.xaml @@ -34,6 +34,7 @@ Hide Wox on startup Hide tray icon Query Search Precision + Should Use Pinyin Plugin diff --git a/Wox/SettingWindow.xaml b/Wox/SettingWindow.xaml index 86d6a345a9..9a5146c7ee 100644 --- a/Wox/SettingWindow.xaml +++ b/Wox/SettingWindow.xaml @@ -55,6 +55,9 @@ Checked="OnAutoStartupChecked" Unchecked="OnAutoStartupUncheck"> + + +