diff --git a/Plugins/Wox.Plugin.Calculator/Languages/de.xaml b/Plugins/Wox.Plugin.Calculator/Languages/de.xaml index 02c51e8c78..286e4bc9b3 100644 --- a/Plugins/Wox.Plugin.Calculator/Languages/de.xaml +++ b/Plugins/Wox.Plugin.Calculator/Languages/de.xaml @@ -4,5 +4,7 @@ Rechner Stellt mathematische Berechnungen bereit.(Versuche 5*3-2 in Wox) - + Keine Zahl (NaN) + Ausdruck falsch oder nicht vollständig (Klammern vergessen?) + Diese Zahl in die Zwischenablage kopieren \ No newline at end of file diff --git a/Plugins/Wox.Plugin.Calculator/Languages/en.xaml b/Plugins/Wox.Plugin.Calculator/Languages/en.xaml index 833a0c14bb..e354839e7c 100644 --- a/Plugins/Wox.Plugin.Calculator/Languages/en.xaml +++ b/Plugins/Wox.Plugin.Calculator/Languages/en.xaml @@ -4,5 +4,7 @@ Calculator Allows to do mathematical calculations.(Try 5*3-2 in Wox) - + Not a Number (NaN) + Expression wrong or incomplete (Did you forget some Brackets?) + Copy this Number to the clipboard \ No newline at end of file diff --git a/Plugins/Wox.Plugin.Calculator/Main.cs b/Plugins/Wox.Plugin.Calculator/Main.cs index 42f592b187..cefb686b97 100644 --- a/Plugins/Wox.Plugin.Calculator/Main.cs +++ b/Plugins/Wox.Plugin.Calculator/Main.cs @@ -1,9 +1,9 @@ using System.Collections.Generic; -using System.Globalization; using System.Runtime.InteropServices; using System.Text.RegularExpressions; using System.Windows; -using YAMP; +using Mages; +using Mages.Core; namespace Wox.Plugin.Caculator { @@ -19,15 +19,12 @@ namespace Wox.Plugin.Caculator @"[ei]|[0-9]|[\+\-\*\/\^\., ""]|[\(\)\|\!\[\]]" + @")+$", RegexOptions.Compiled); private static Regex regBrackets = new Regex(@"[\(\)\[\]]", RegexOptions.Compiled); - private static ParseContext yampContext; + private static Mages.Core.Engine magesEngine; private PluginInitContext context { get; set; } - private NumberTranslator _numberTranslator; static Main() { - yampContext = Parser.PrimaryContext; - Parser.InteractiveMode = false; - Parser.UseScripting = false; + magesEngine = new Engine(); } public List Query(Query query) @@ -38,33 +35,38 @@ namespace Wox.Plugin.Caculator try { - var result = yampContext.Run(this._numberTranslator?.Translate(query.Search) ?? query.Search); - if (result.Output != null && !string.IsNullOrEmpty(result.Result)) + var result = magesEngine.Interpret(query.Search); + + if (result.ToString() == "NaN") + result = context.API.GetTranslation("wox_plugin_calculator_not_a_number"); + + if (result is Function) + result = context.API.GetTranslation("wox_plugin_calculator_expression_not_complete"); + + + if (result != null && !string.IsNullOrEmpty(result.ToString())) { - string resultValue = this._numberTranslator?.TranslateBack(result.Result) ?? result.Result; return new List + { new Result { - new Result + Title = result.ToString(), + IcoPath = "Images/calculator.png", + Score = 300, + SubTitle = context.API.GetTranslation("wox_plugin_calculator_copy_number_to_clipboard"), + Action = c => { - Title = resultValue, - IcoPath = "Images/calculator.png", - Score = 300, - SubTitle = "Copy this number to the clipboard", - Action = c => + try { - try - { - Clipboard.SetText(resultValue); - return true; - } - catch (ExternalException e) - { - MessageBox.Show("Copy failed, please try later"); - return false; - } + Clipboard.SetText(result.ToString()); + return true; + } + catch (ExternalException e) + { + MessageBox.Show("Copy failed, please try later"); + return false; } } - }; + } }; } } catch @@ -95,7 +97,6 @@ namespace Wox.Plugin.Caculator public void Init(PluginInitContext context) { this.context = context; - this._numberTranslator = NumberTranslator.Create(CultureInfo.CurrentCulture, CultureInfo.InvariantCulture); } public string GetTranslatedPluginTitle() diff --git a/Plugins/Wox.Plugin.Calculator/Wox.Plugin.Calculator.csproj b/Plugins/Wox.Plugin.Calculator/Wox.Plugin.Calculator.csproj index c65590ea74..8fd3169a84 100644 --- a/Plugins/Wox.Plugin.Calculator/Wox.Plugin.Calculator.csproj +++ b/Plugins/Wox.Plugin.Calculator/Wox.Plugin.Calculator.csproj @@ -38,14 +38,14 @@ ..\..\packages\JetBrains.Annotations.10.3.0\lib\net\JetBrains.Annotations.dll True + + ..\..\packages\Mages.1.5.0\lib\net35\Mages.Core.dll + True + - - ..\..\packages\YAMP.1.4.0\lib\net35\YAMP.dll - True - diff --git a/Plugins/Wox.Plugin.Calculator/packages.config b/Plugins/Wox.Plugin.Calculator/packages.config index d1fce409f5..c17f6726fd 100644 --- a/Plugins/Wox.Plugin.Calculator/packages.config +++ b/Plugins/Wox.Plugin.Calculator/packages.config @@ -1,6 +1,6 @@  + - \ No newline at end of file