aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Tango.Scripting
diff options
context:
space:
mode:
authorAvi Levkovich <avi@twine-s.com>2020-04-21 14:21:19 +0300
committerAvi Levkovich <avi@twine-s.com>2020-04-21 14:21:19 +0300
commitcd728bf3a7d1db76747cb18bcfe396c83d690e86 (patch)
tree99347262eef3f175a7ff1441b6c5a031be74d26f /Software/Visual_Studio/Tango.Scripting
parent7fe23e68512e2462de107e76ae3a92ddd381ac77 (diff)
parent97a784b6ce43960bdb92465b08f26d3562a4f202 (diff)
downloadTango-cd728bf3a7d1db76747cb18bcfe396c83d690e86.tar.gz
Tango-cd728bf3a7d1db76747cb18bcfe396c83d690e86.zip
Merge branch 'master' of https://twinetfs.visualstudio.com/_git/Tango
Diffstat (limited to 'Software/Visual_Studio/Tango.Scripting')
-rw-r--r--Software/Visual_Studio/Tango.Scripting/ExpressionGenerator.cs22
-rw-r--r--Software/Visual_Studio/Tango.Scripting/Tango.Scripting.csproj3
2 files changed, 24 insertions, 1 deletions
diff --git a/Software/Visual_Studio/Tango.Scripting/ExpressionGenerator.cs b/Software/Visual_Studio/Tango.Scripting/ExpressionGenerator.cs
new file mode 100644
index 000000000..8db917a10
--- /dev/null
+++ b/Software/Visual_Studio/Tango.Scripting/ExpressionGenerator.cs
@@ -0,0 +1,22 @@
+using Microsoft.CodeAnalysis.CSharp.Scripting;
+using Microsoft.CodeAnalysis.Scripting;
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Linq.Expressions;
+using System.Reflection;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Tango.Scripting
+{
+ public static class ExpressionGenerator
+ {
+ public static Func<T, bool> GenerateExpression<T>(String body, params Assembly[] assemblies)
+ {
+ var options = ScriptOptions.Default.AddReferences(assemblies);
+ Func<T, bool> func = CSharpScript.EvaluateAsync<Func<T, bool>>(body, options).Result;
+ return func;
+ }
+ }
+}
diff --git a/Software/Visual_Studio/Tango.Scripting/Tango.Scripting.csproj b/Software/Visual_Studio/Tango.Scripting/Tango.Scripting.csproj
index f8dbc66c0..718bd96ce 100644
--- a/Software/Visual_Studio/Tango.Scripting/Tango.Scripting.csproj
+++ b/Software/Visual_Studio/Tango.Scripting/Tango.Scripting.csproj
@@ -141,6 +141,7 @@
<Link>GlobalVersionInfo.cs</Link>
</Compile>
<Compile Include="CompilerError.cs" />
+ <Compile Include="ExpressionGenerator.cs" />
<Compile Include="Properties\AssemblyInfo.cs" />
<Compile Include="ScriptEngine.cs" />
<Compile Include="OnExecuteParameters.cs" />
@@ -175,7 +176,7 @@
<Import Project="..\packages\Costura.Fody.1.6.2\build\dotnet\Costura.Fody.targets" Condition="Exists('..\packages\Costura.Fody.1.6.2\build\dotnet\Costura.Fody.targets')" />
<ProjectExtensions>
<VisualStudio>
- <UserProperties BuildVersion_StartDate="2000/1/1" BuildVersion_UseGlobalSettings="False" BuildVersion_BuildVersioningStyle="None.None.Increment.TimeStamp" BuildVersion_UpdateAssemblyVersion="True" BuildVersion_AssemblyInfoFilename="Properties\AssemblyInfo.cs" />
+ <UserProperties BuildVersion_AssemblyInfoFilename="Properties\AssemblyInfo.cs" BuildVersion_UpdateAssemblyVersion="True" BuildVersion_BuildVersioningStyle="None.None.Increment.TimeStamp" BuildVersion_UseGlobalSettings="False" BuildVersion_StartDate="2000/1/1" />
</VisualStudio>
</ProjectExtensions>
</Project> \ No newline at end of file