aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Scripting/Tango.Scripting/ScriptSession.cs
diff options
context:
space:
mode:
authorShai Frieder <Shai.Frieder@twine-s.com>2019-04-15 11:44:09 +0300
committerShai Frieder <Shai.Frieder@twine-s.com>2019-04-15 11:44:09 +0300
commit64e2776e794d752daaeb06121492744266f65a23 (patch)
tree00bed37becbcea5b31b9879c7341c7f0e2bb3ce1 /Software/Visual_Studio/Scripting/Tango.Scripting/ScriptSession.cs
parent49db61f198119289433e1f2e35b97e011c47aefe (diff)
parentaa5ba8c457c3722cf215c2992a0b03f310afd1c1 (diff)
downloadTango-64e2776e794d752daaeb06121492744266f65a23.tar.gz
Tango-64e2776e794d752daaeb06121492744266f65a23.zip
Merge branch 'master' of https://twinetfs.visualstudio.com/_git/Tango
Diffstat (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting/ScriptSession.cs')
-rw-r--r--Software/Visual_Studio/Scripting/Tango.Scripting/ScriptSession.cs58
1 files changed, 58 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting/ScriptSession.cs b/Software/Visual_Studio/Scripting/Tango.Scripting/ScriptSession.cs
new file mode 100644
index 000000000..647ec7d87
--- /dev/null
+++ b/Software/Visual_Studio/Scripting/Tango.Scripting/ScriptSession.cs
@@ -0,0 +1,58 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Tango.Scripting
+{
+ public class ScriptSession
+ {
+ private Action _abortAction;
+
+ public event EventHandler<ScriptSessionStateChangedEventArgs> StateChanged;
+
+ public Script Script { get; private set; }
+
+ public String EffectiveCode { get; set; }
+
+ public ScriptSessionState State { get; set; }
+
+ public ScriptSession(Script script, String effectiveCode, Action abortAction)
+ {
+ _abortAction = abortAction;
+ Script = script;
+ EffectiveCode = effectiveCode;
+ }
+
+ public void Abort()
+ {
+ _abortAction();
+ State = ScriptSessionState.Aborted;
+ RaiseStateChanged();
+ }
+
+ internal void Failed(Exception ex)
+ {
+ State = ScriptSessionState.Failed;
+ RaiseStateChanged(null, ex);
+ }
+
+ internal void Completed(object returnValue)
+ {
+ State = ScriptSessionState.Completed;
+ RaiseStateChanged(returnValue, null);
+ }
+
+ private void RaiseStateChanged(object returnValue = null, Exception ex = null)
+ {
+ StateChanged?.Invoke(this,
+ new ScriptSessionStateChangedEventArgs()
+ {
+ ReturnValue = returnValue,
+ State = State,
+ Exception = ex
+ });
+ }
+ }
+}