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