Changeset 11009 for branches/DataPreprocessing/HeuristicLab.Scripting
- Timestamp:
- 06/12/14 13:26:18 (11 years ago)
- Location:
- branches/DataPreprocessing
- Files:
-
- 4 edited
- 3 copied
Legend:
- Unmodified
- Added
- Removed
-
branches/DataPreprocessing
- Property svn:ignore
-
old new 8 8 FxCopResults.txt 9 9 Google.ProtocolBuffers-0.9.1.dll 10 Google.ProtocolBuffers-2.4.1.473.dll 10 11 HeuristicLab 3.3.5.1.ReSharper.user 11 12 HeuristicLab 3.3.6.0.ReSharper.user 12 13 HeuristicLab.4.5.resharper.user 13 14 HeuristicLab.ExtLibs.6.0.ReSharper.user 15 HeuristicLab.Scripting.Development 14 16 HeuristicLab.resharper.user 15 17 ProtoGen.exe … … 17 19 _ReSharper.HeuristicLab 18 20 _ReSharper.HeuristicLab 3.3 21 _ReSharper.HeuristicLab 3.3 Tests 19 22 _ReSharper.HeuristicLab.ExtLibs 20 23 bin 21 24 protoc.exe 22 _ReSharper.HeuristicLab 3.3 Tests23 Google.ProtocolBuffers-2.4.1.473.dll
-
- Property svn:mergeinfo changed
- Property svn:ignore
-
branches/DataPreprocessing/HeuristicLab.Scripting/3.3/HeuristicLab.Scripting-3.3.csproj
r10506 r11009 85 85 </ItemGroup> 86 86 <ItemGroup> 87 <Compile Include="CSharpScript.cs" /> 88 <Compile Include="Variables.cs" /> 87 89 <Compile Include="VariableStore.cs" /> 88 90 <None Include="Plugin.cs.frame" /> 89 91 <Compile Include="Script.cs" /> 90 <Compile Include=" UserScriptBase.cs" />92 <Compile Include="CSharpScriptBase.cs" /> 91 93 <Compile Include="Plugin.cs" /> 92 94 <Compile Include="Properties\AssemblyInfo.cs" /> -
branches/DataPreprocessing/HeuristicLab.Scripting/3.3/Script.cs
r10506 r11009 29 29 using System.Reflection; 30 30 using System.Text; 31 using System.Text.RegularExpressions;32 using System.Threading;33 31 using HeuristicLab.Common; 34 32 using HeuristicLab.Common.Resources; … … 38 36 39 37 namespace HeuristicLab.Scripting { 40 [Item("Script", "An empty C# script.")]41 [Creatable("Scripts")]42 38 [StorableClass] 43 public sealed class Script : NamedItem, IStorableContent { 44 #region Constants 45 private const string ExecuteMethodName = "Execute"; 46 private const string CodeTemplate = 47 @"// use 'vars' to access global variables in the variable store 48 49 using System; 50 using System.Linq; 51 using System.Collections.Generic; 52 using HeuristicLab.Common; 53 using HeuristicLab.Core; 54 using HeuristicLab.Data; 55 56 public class UserScript : HeuristicLab.Scripting.UserScriptBase { 57 public override void Main() { 58 // type your code here 59 } 60 61 // further classes and methods 62 63 }"; 64 #endregion 39 public class Script : NamedItem { 40 protected virtual string CodeTemplate { 41 get { return string.Empty; } 42 } 65 43 66 44 #region Fields & Properties 67 private UserScriptBase compiledScript;68 69 public string Filename { get; set; }70 71 45 public static new Image StaticItemImage { 72 46 get { return VSImageLibrary.Script; } 73 }74 75 [Storable]76 private VariableStore variableStore;77 public VariableStore VariableStore {78 get { return variableStore; }79 47 } 80 48 … … 86 54 if (value == code) return; 87 55 code = value; 88 compiledScript = null;89 56 OnCodeChanged(); 90 57 } 91 }92 93 private string compilationUnitCode;94 public string CompilationUnitCode {95 get { return compilationUnitCode; }96 58 } 97 59 … … 108 70 #region Construction & Initialization 109 71 [StorableConstructor] 110 pr ivateScript(bool deserializing) : base(deserializing) { }111 pr ivateScript(Script original, Cloner cloner)72 protected Script(bool deserializing) : base(deserializing) { } 73 protected Script(Script original, Cloner cloner) 112 74 : base(original, cloner) { 113 75 code = original.code; 114 variableStore = new VariableStore();115 compilationUnitCode = original.compilationUnitCode;116 76 if (original.compileErrors != null) 117 77 compileErrors = new CompilerErrorCollection(original.compileErrors); 118 78 } 119 120 79 public Script() 121 : base("Script", "A HeuristicLab script.") { 122 code = CodeTemplate; 123 variableStore = new VariableStore(); 80 : base("Script", "An empty script.") { 81 code = string.Empty; 82 } 83 public Script(string code) 84 : this() { 85 this.code = code; 124 86 } 125 87 … … 129 91 #endregion 130 92 131 private void RegisterScriptEvents() { 132 if (compiledScript == null) return; 133 compiledScript.ConsoleOutputChanged += compiledScript_ConsoleOutputChanged; 93 #region Compilation 94 protected virtual CSharpCodeProvider CodeProvider { 95 get { 96 return new CSharpCodeProvider( 97 new Dictionary<string, string> { 98 {"CompilerVersion", "v4.0"}, // support C# 4.0 syntax 99 }); 100 } 134 101 } 135 102 136 private void DeregisterScriptEvents() { 137 if (compiledScript == null) return; 138 compiledScript.ConsoleOutputChanged -= compiledScript_ConsoleOutputChanged; 139 } 140 141 #region Compilation 142 private CSharpCodeProvider codeProvider = 143 new CSharpCodeProvider( 144 new Dictionary<string, string> { 145 { "CompilerVersion", "v4.0" }, // support C# 4.0 syntax 146 }); 147 148 private CompilerResults DoCompile() { 103 protected virtual CompilerResults DoCompile() { 149 104 var parameters = new CompilerParameters { 150 105 GenerateExecutable = false, … … 159 114 var unit = CreateCompilationUnit(); 160 115 var writer = new StringWriter(); 161 codeProvider.GenerateCodeFromCompileUnit(116 CodeProvider.GenerateCodeFromCompileUnit( 162 117 unit, 163 118 writer, … … 166 121 IndentString = " ", 167 122 }); 168 compilationUnitCode = writer.ToString(); 169 return codeProvider.CompileAssemblyFromDom(parameters, unit); 123 return CodeProvider.CompileAssemblyFromDom(parameters, unit); 170 124 } 171 125 172 public v oidCompile() {126 public virtual Assembly Compile() { 173 127 var results = DoCompile(); 174 compiledScript = null;175 128 CompileErrors = results.Errors; 176 129 if (results.Errors.HasErrors) { … … 181 134 .AppendLine(error.ErrorText); 182 135 } 183 throw new Exception(string.Format( 184 "Compilation of \"{0}\" failed:{1}{2}", 185 Name, Environment.NewLine, 186 sb.ToString())); 136 throw new Exception(string.Format("Compilation of \"{0}\" failed:{1}{2}", 137 Name, Environment.NewLine, sb.ToString())); 187 138 } else { 188 var assembly = results.CompiledAssembly; 189 var types = assembly.GetTypes(); 190 DeregisterScriptEvents(); 191 compiledScript = (UserScriptBase)Activator.CreateInstance(types[0]); 192 RegisterScriptEvents(); 139 return results.CompiledAssembly; 193 140 } 194 141 } 195 142 196 public IEnumerable<Assembly> GetAssemblies() {143 public virtual IEnumerable<Assembly> GetAssemblies() { 197 144 var assemblies = new List<Assembly>(); 198 145 foreach (var a in AppDomain.CurrentDomain.GetAssemblies()) { … … 210 157 } 211 158 212 private readonly Regex SafeTypeNameCharRegex = new Regex("[_a-zA-Z0-9]+"); 213 private readonly Regex SafeTypeNameRegex = new Regex("[_a-zA-Z][_a-zA-Z0-9]*"); 214 215 private CodeCompileUnit CreateCompilationUnit() { 159 protected virtual CodeCompileUnit CreateCompilationUnit() { 216 160 var unit = new CodeSnippetCompileUnit(code); 217 161 return unit; 218 162 } 219 220 public string CompiledTypeName {221 get {222 var sb = new StringBuilder();223 var strings = SafeTypeNameCharRegex.Matches(Name)224 .Cast<Match>()225 .Select(m => m.Value);226 foreach (string s in strings)227 sb.Append(s);228 return SafeTypeNameRegex.Match(sb.ToString()).Value;229 }230 }231 163 #endregion 232 164 233 private Thread scriptThread;234 public void Execute() {235 if (compiledScript == null) return;236 var executeMethod = typeof(UserScriptBase).GetMethod(ExecuteMethodName, BindingFlags.NonPublic | BindingFlags.Instance);237 if (executeMethod != null) {238 scriptThread = new Thread(() => {239 Exception ex = null;240 try {241 OnScriptExecutionStarted();242 executeMethod.Invoke(compiledScript, new[] { VariableStore });243 } catch (ThreadAbortException) {244 // the execution was cancelled by the user245 } catch (TargetInvocationException e) {246 ex = e.InnerException;247 } finally {248 OnScriptExecutionFinished(ex);249 }250 });251 scriptThread.Start();252 }253 }254 255 public void Kill() {256 if (scriptThread.IsAlive)257 scriptThread.Abort();258 }259 260 private void compiledScript_ConsoleOutputChanged(object sender, EventArgs<string> e) {261 OnConsoleOutputChanged(e.Value);262 }263 264 165 public event EventHandler CodeChanged; 265 pr ivatevoid OnCodeChanged() {166 protected virtual void OnCodeChanged() { 266 167 var handler = CodeChanged; 267 168 if (handler != null) handler(this, EventArgs.Empty); … … 269 170 270 171 public event EventHandler CompileErrorsChanged; 271 pr ivatevoid OnCompileErrorsChanged() {172 protected virtual void OnCompileErrorsChanged() { 272 173 var handler = CompileErrorsChanged; 273 174 if (handler != null) handler(this, EventArgs.Empty); 274 175 } 275 276 public event EventHandler ScriptExecutionStarted;277 private void OnScriptExecutionStarted() {278 var handler = ScriptExecutionStarted;279 if (handler != null) handler(this, EventArgs.Empty);280 }281 282 public event EventHandler<EventArgs<Exception>> ScriptExecutionFinished;283 private void OnScriptExecutionFinished(Exception e) {284 var handler = ScriptExecutionFinished;285 if (handler != null) handler(this, new EventArgs<Exception>(e));286 }287 288 public event EventHandler<EventArgs<string>> ConsoleOutputChanged;289 private void OnConsoleOutputChanged(string args) {290 var handler = ConsoleOutputChanged;291 if (handler != null) handler(this, new EventArgs<string>(args));292 }293 176 } 294 177 } -
branches/DataPreprocessing/HeuristicLab.Scripting/3.3/UserScriptBase.cs
r10512 r11009 52 52 var handler = ConsoleOutputChanged; 53 53 if (handler != null) handler(null, new EventArgs<string>(args)); 54 }55 56 protected class Variables : DynamicObject, IEnumerable<KeyValuePair<string, object>> {57 private readonly VariableStore variableStore;58 59 public ICollection<string> Keys {60 get { return variableStore.Keys; }61 }62 63 public ICollection<object> Values {64 get { return variableStore.Values; }65 }66 67 public Variables(VariableStore variableStore) {68 this.variableStore = variableStore;69 }70 71 public override bool TryGetMember(GetMemberBinder binder, out object result) {72 return variableStore.TryGetValue(binder.Name, out result);73 }74 75 public override bool TrySetMember(SetMemberBinder binder, object value) {76 variableStore[binder.Name] = value;77 return true;78 }79 80 public bool Contains(string variableName) {81 return variableStore.ContainsKey(variableName);82 }83 84 public IEnumerator<KeyValuePair<string, object>> GetEnumerator() {85 return variableStore.GetEnumerator();86 }87 88 IEnumerator IEnumerable.GetEnumerator() {89 return GetEnumerator();90 }91 54 } 92 55
Note: See TracChangeset
for help on using the changeset viewer.