/// <summary> /// 运行脚本 /// </summary> /// <param name="m"></param> public override Task <bool> RunScript(IScriptLayout m) { if (scriptRunThread != null && scriptRunThread.IsCompleted == false) { return(null); } scriptRunThread = new Task <bool>((obj) => { IsRunning = true; IScriptLayout ml = obj as IScriptLayout; WriteStreamCallBack wrs = ml.ComipleMessageCall; try { isStop = false; //初始化flag isDebugMode = false; Init(ml); wrs?.Invoke("赋值属性完成,开始执行脚本"); foreach (var currentbox in ml.Itemboxs) { //RunningFunction(currentbox, wrs, ml); //ml.SetFunctionBoxRun(Colors.Red, currentbox); if (currentbox.BoxType == ItemBoxEnum.FUNCTION) { Dofunction(currentbox, wrs, ml); } else if (currentbox.BoxType == ItemBoxEnum.IF) { DoIfFunction(currentbox, wrs, ml); } else if (currentbox.BoxType == ItemBoxEnum.WHILE) { DoWhileFunction(currentbox, wrs, ml); } //ml.SetFunctionBoxStop(Colors.White, currentbox); } return(true); } catch (Exception ex) { wrs?.Invoke("脚本运行失败"); Log.ScriptLog.Log.Write(new LogMessage("脚本运行失败", ex)); return(false); } finally { manager.Clear(); wrs?.Invoke("程序运行结束"); IsRunning = false; } }, m); scriptRunThread.Start(); return(scriptRunThread); }
/// <summary> /// 执行准确的函数 /// </summary> /// <param name="box"></param> protected void Dofunction(ItemBox box, WriteStreamCallBack wrs, IScriptLayout ml) { if (isStop) { throw new Exception("主动停止了脚本!"); } ml.SetFunctionBoxRun(box); ScriptInput si = new ScriptInput(); foreach (var item in box.InputDatas) { if (item.PIEnum != ParaItemEnum.INPUT) { si.SetValue(item.Name, GetValue(item as ParatItem)); } } ScriptOutput so = RunScript(box, si); //ScriptOutput so = null; ////////////////////////////////////待修改 if (so != null) { if (so.LogMessage != null && so.LogMessage.Equals("") == false) { wrs?.Invoke(so.LogMessage); } foreach (var item in box.OutDatas) { if (item.PIEnum != ParaItemEnum.OUTPUT) { item.Value = so.GetValue(item.Name); SetValue(item as ParatItem); } } } //检测是否需要断点停止 checkScriptRunForStopPoint(box, si, null); if (so != null) { so.Dispose(); so = null; } si.Dispose(); si = null; ml.SetFunctionBoxStop(box); }
/// <summary> /// 运行脚本 /// </summary> /// <param name="ml"></param> public static void RunScript(MainLayout ml, WriteStreamCallBack wrs, IList <IPropertyIt> propertys, WriteStreamCallBack runover = null) { ScriptObjectManager sm = new ScriptObjectManager(); if (propertys.Count > 0) { foreach (var item in propertys) { ScriptOutput so = new ScriptOutput(); so.SetValue(item.Name, item.Value); sm.SetValue(item.Id, so); } } try { IItemBox currentib = (ml.MainIb as LineItemBox).Next(0); IItemBox next = null; while (currentib != null) { ml.SetFunctionBoxRun(System.Windows.Media.Colors.Red, currentib); next = DoFunction(currentib as ItemBox, sm, wrs); ml.SetFunctionBoxStop(System.Windows.Media.Colors.White, currentib); currentib = next; } } catch (Exception ex) { wrs?.Invoke("脚本运行失败"); Log.Write(new LogMessage("脚本运行失败", ex)); } finally { sm.Dispose(); sm = null; runover?.Invoke("程序运行结束"); } }