/// <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("程序运行结束");
            }
        }