| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087 | using Aitex.Common.Util;using Aitex.Core.RT.DataCenter;using Aitex.Core.RT.Log;using Aitex.Core.RT.SCCore;using Aitex.Core.Util;using Aitex.Core.Utilities;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.IOCore;using MECF.Framework.RT.Core.IoProviders;using System;using System.Collections.Generic;using System.Linq;using System.Reflection;using System.Threading;using System.Threading.Tasks;using System.Xml;using System.Xml.Serialization;using Aitex.Core.RT.Event;using MECF.Framework.Common.SCCore;using SciChart.Core.Messaging;using MECF.Framework.Common.Utilities;using System.IO;namespace MECF.Framework.Common.FAServices{    /// <summary>    /// 所有ID 的命名规则:    ///    /// Module(1-399) + Type(1-80)  + Unit(1-99) + Parameter (1-999)    ///    /// 最小 1 01 01 001  = 10101001    ///    /// 最大 399 99 99 999 = 3 999 999 999    ///    /// "PPP" 一部分的就是按参数  module=1, type=1, unit=1, parameter="AAA"    ///       ///     /// </summary>    ///    ///    [Serializable]    [XmlRoot("DataItems")]    public class VIDItem    {        private string name;        [XmlAttribute("Name")]        public string Name        {            get { return name; }            set            {                name = value;                AnalyseName(value);            }        }        [XmlAttribute("Index")]        public long Index { get; set; }        [XmlAttribute("DataType")]        public string DataType { get; set; }        [XmlArray("LinkableVID")]        public int[] LinkableVid { get; set; }        [XmlAttribute("Description")]        public string Description { get; set; }        [XmlAttribute("Module")]        public string Module { get; set; } = "";        [XmlAttribute("Type")]        public string Type { get; set; } = "";        [XmlAttribute("Unit")]        public string Unit { get; set; } = "";        [XmlAttribute("Parameter")]        public string Parameter { get; set; }        private int moduleIndex;        [XmlIgnore]        public int ModuleIndex        {            get { return moduleIndex; }            set            {                moduleIndex = value;            }        }        private int typeIndex;        [XmlIgnore]        public int TypeIndex        {            get { return typeIndex; }            set            {                typeIndex = value;            }        }        private int unitIndex;        [XmlIgnore]        public int UnitIndex        {            get { return unitIndex; }            set            {                unitIndex = value;            }        }        private int parameterIndex;        [XmlIgnore]        public int ParameterIndex        {            get { return parameterIndex; }            set            {                parameterIndex = value;            }        }        void AnalyseName(string name)        {            if (string.IsNullOrEmpty(name))                return;            string[] names = name.Split('.');            Module = ModuleName.System.ToString();            if (names.Length >= 1)            {                Parameter = names[names.Length - 1];                if (names.Length >= 2)                {                    Module = names[0];                    ModuleIndex = (Enum.TryParse(Module, out ModuleName moduleIndex) ? (int)moduleIndex : 0) + 1;                    if (names.Length >= 3)                    {                        Unit = names[names.Length - 2];                        if (names.Length >= 4)                        {                            for (int j = 1; j < names.Length - 2; j++)                            {                                Type += names[j];                                if (j != names.Length - 3)                                    Type += ".";                            }                        }                    }                }            }        }    }    public enum VIDTypeEnum    {        SVID,        DVID,        CEID,        ALID,        ECID,    }    public class VIDGenerator    {        public string Type { get; set; }        public string SourceFileName { get; set; }        public List<VIDItem> VIDList = new List<VIDItem>();        public Dictionary<string, int> _moduleIndex = new Dictionary<string, int>();        public Dictionary<string, Dictionary<string, Dictionary<string, Dictionary<string, long>>>> moduleTypeUnitParamIndex = new Dictionary<string, Dictionary<string, Dictionary<string, Dictionary<string, long>>>>();        public Dictionary<string, long> _index = new Dictionary<string, long>();        private string _defaultPathFile;        private string _type;        public VIDGenerator(string type, string defaultPathFile)        {            _type = type;            _defaultPathFile = defaultPathFile;        }        public void Initialize()        {            XmlDocument xml = new XmlDocument();            try            {                EnumLoop<ModuleName>.ForEach((item) =>                {                    moduleTypeUnitParamIndex[item.ToString()] = new Dictionary<string, Dictionary<string, Dictionary<string, long>>>();                });                xml.Load(_defaultPathFile);                VIDList = CustomXmlSerializer.Deserialize<List<VIDItem>>(xml.OuterXml);                foreach (var VIDItem in VIDList)                {                    //_moduleTypeIndex[VIDItem.Type] = VIDItem.TypeIndex;                    //_moduleTypeUnitIndex[VIDItem.Unit] = VIDItem.UnitIndex;                    //_parameterIndex[VIDItem.Parameter] = VIDItem.ParameterIndex;                    if (!moduleTypeUnitParamIndex.ContainsKey(VIDItem.Module))                    {                        moduleTypeUnitParamIndex[VIDItem.Module] = new Dictionary<string, Dictionary<string, Dictionary<string, long>>>();                    }                    if (!moduleTypeUnitParamIndex[VIDItem.Module].ContainsKey(VIDItem.Type))                    {                        moduleTypeUnitParamIndex[VIDItem.Module][VIDItem.Type] = new Dictionary<string, Dictionary<string, long>>();                    }                    if (!moduleTypeUnitParamIndex[VIDItem.Module][VIDItem.Type].ContainsKey(VIDItem.Unit))                    {                        moduleTypeUnitParamIndex[VIDItem.Module][VIDItem.Type][VIDItem.Unit] = new Dictionary<string, long>();                    }                    moduleTypeUnitParamIndex[VIDItem.Module][VIDItem.Type][VIDItem.Unit][VIDItem.Parameter] = VIDItem.Index;                    _index[VIDItem.Name] = VIDItem.Index;                }                //XmlNodeList itemNodes = xml.SelectNodes("DataItems/DataItem");                //foreach (var itemNode in itemNodes)                //{                //    XmlElement element = itemNode as XmlElement;                //    if (element == null)                //        continue;                //    string name = element.GetAttribute("name").Trim();                //    string index = element.GetAttribute("index").Trim();                //    if (string.IsNullOrEmpty(name) || string.IsNullOrEmpty(index) || (index.Length != 9 && index.Length != 8))                //        continue;                //    var item = ParseName(name);                //    _moduleTypeIndex[$"{item.Item1}.{item.Item2}"] = int.Parse(index.Substring(index.Length - 7, 2));                //    _moduleTypeUnitIndex[$"{item.Item1}.{item.Item2}.{item.Item3}"] = int.Parse(index.Substring(index.Length - 5, 2));                //    _parameterIndex[$"{item.Item1}.{item.Item2}.{item.Item3}.{item.Item4}"] =                //        int.Parse(index.Substring(index.Length - 3, 3));                //    if (!_max.ContainsKey($"{item.Item1}"))                //        _max[$"{item.Item1}"] = 0;                //    _max[$"{item.Item1}"] =                //        Math.Max(_moduleTypeIndex[$"{item.Item1}.{item.Item2}"], _max[$"{item.Item1}"]);                //    if (!_max.ContainsKey($"{item.Item1}.{item.Item2}"))                //        _max[$"{item.Item1}.{item.Item2}"] = 0;                //    _max[$"{item.Item1}.{item.Item2}"] =                //        Math.Max(_moduleTypeUnitIndex[$"{item.Item1}.{item.Item2}.{item.Item3}"], _max[$"{item.Item1}.{item.Item2}"]);                //    if (!_max.ContainsKey($"{item.Item1}.{item.Item2}.{item.Item3}"))                //        _max[$"{item.Item1}.{item.Item2}.{item.Item3}"] = 0;                //    _max[$"{item.Item1}.{item.Item2}.{item.Item3}"] =                //        Math.Max(_parameterIndex[$"{item.Item1}.{item.Item2}.{item.Item3}.{item.Item4}"], _max[$"{item.Item1}.{item.Item2}.{item.Item3}"]);                //    _index[name] = int.Parse(index);                //}            }            catch (Exception ex)            {                LOG.Write(ex);            }            EnumLoop<ModuleName>.ForEach((item) =>            {                _moduleIndex[item.ToString()] = ((int)item) + 1;            });        }        public Tuple<string, string, string, string> ParseName(string name)        {            if (string.IsNullOrEmpty(name))                return null;            string module = ModuleName.System.ToString();            string type = "";            string unit = "";            string parameter = "";            string[] names = name.Split('.');            if (names.Length >= 1)            {                parameter = names[names.Length - 1];                if (names.Length >= 2)                {                    if (_moduleIndex.ContainsKey(names[0]))                    {                        module = names[0];                        if (names.Length >= 3)                        {                            unit = names[names.Length - 2];                            if (names.Length >= 4)                            {                                for (int j = 1; j < names.Length - 2; j++)                                {                                    type += names[j];                                    if (j != names.Length - 3)                                        type += ".";                                }                            }                        }                    }                    else                    {                        //module = module;                        unit = names[names.Length - 2];                        if (names.Length >= 3)                        {                            for (int j = 0; j < names.Length - 2; j++)                            {                                type += names[j];                                if (j != names.Length - 3)                                    type += ".";                            }                        }                    }                }            }            return Tuple.Create(module, type, unit, parameter);        }        public void GenerateId(List<VIDItem> dataList)        {            List<VIDItem> newList = new List<VIDItem>();            foreach (var data in dataList)            {                if (!_index.ContainsKey(data.Name))                    newList.Add(data);            }            if (newList.Count > 0)            {                AssignNewId(newList);                VIDList = VIDList.Concat(newList).OrderBy(x => x.Index).ToList();                if (File.Exists(_defaultPathFile))                    CustomXmlSerializer.Serialize(VIDList, _defaultPathFile);            }        }        private void AssignNewId(List<VIDItem> dataList)        {            if (dataList.Count == 0)                return;            dataList = dataList.OrderBy(x => x.Name).ToList();            foreach (var data in dataList)            {                data.Name = data.Name;                if (!moduleTypeUnitParamIndex.ContainsKey(data.Module))                {                    moduleTypeUnitParamIndex[data.Module] = new Dictionary<string, Dictionary<string, Dictionary<string, long>>>();                    moduleTypeUnitParamIndex[data.Module][data.Type] = new Dictionary<string, Dictionary<string, long>>();                    moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit] = new Dictionary<string, long>();                    data.ModuleIndex = moduleTypeUnitParamIndex.Keys.ToList().FindIndex(x => x == data.Module) + 1;                    data.TypeIndex = 1;                    data.UnitIndex = 1;                    data.ParameterIndex = 1;                    moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter] = long.Parse($"{ data.ModuleIndex}{data.TypeIndex.ToString().PadLeft(2, '0')}{data.UnitIndex.ToString().PadLeft(2, '0')}{ data.ParameterIndex.ToString().PadLeft(3, '0')}");                    data.Index = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter];                    continue;                }                if (!moduleTypeUnitParamIndex[data.Module].ContainsKey(data.Type))                {                    moduleTypeUnitParamIndex[data.Module][data.Type] = new Dictionary<string, Dictionary<string, long>>();                    moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit] = new Dictionary<string, long>();                    data.ModuleIndex = moduleTypeUnitParamIndex.Keys.ToList().FindIndex(x => x == data.Module) + 1;                    data.TypeIndex = moduleTypeUnitParamIndex[data.Module].Count;                    data.UnitIndex = 1;                    data.ParameterIndex = 1;                    moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter] = long.Parse($"{ data.ModuleIndex}{data.TypeIndex.ToString().PadLeft(2, '0')}{data.UnitIndex.ToString().PadLeft(2, '0')}{ data.ParameterIndex.ToString().PadLeft(3, '0')}");                    data.Index = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter];                    continue;                }                if (!moduleTypeUnitParamIndex[data.Module][data.Type].ContainsKey(data.Unit))                {                    moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit] = new Dictionary<string, long>();                    data.ModuleIndex = moduleTypeUnitParamIndex.Keys.ToList().FindIndex(x => x == data.Module) + 1;                    data.TypeIndex = moduleTypeUnitParamIndex[data.Module].Keys.ToList().FindIndex(x => x == data.Type) + 2;                    data.UnitIndex = moduleTypeUnitParamIndex[data.Module][data.Type].Count;                    data.ParameterIndex = 1;                    moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter] = long.Parse($"{ data.ModuleIndex}{data.TypeIndex.ToString().PadLeft(2, '0')}{data.UnitIndex.ToString().PadLeft(2, '0')}{ data.ParameterIndex.ToString().PadLeft(3, '0')}");                    data.Index = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter];                    continue;                }                moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter] = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit].Last().Value + 1;                data.Index = moduleTypeUnitParamIndex[data.Module][data.Type][data.Unit][data.Parameter];            }            //XmlDocument xml = new XmlDocument();            //try            //{            //    xml.Load(_defaultPathFile);            //    XmlNode itemNodes = xml.SelectSingleNode("DataItems");            //    itemNodes.RemoveAll();            //    Dictionary<int, string> orderedName = _index.OrderBy(o => o.Value).ToDictionary(p => p.Value, o => o.Key);            //    foreach (var name in orderedName)            //    {            //        XmlElement subNode = xml.CreateElement("DataItem");            //        subNode.SetAttribute("name", name.Value);            //        subNode.SetAttribute("index", name.Key.ToString());            //        itemNodes.AppendChild(subNode);            //    }            //    xml.Save(_defaultPathFile);            //}            //catch (Exception ex)            //{            //    LOG.Write(ex);            //}        }    }    public class VIDManager : Singleton<VIDManager>    {        public void Initialize(string equipName, bool enableGem300Events = false, bool needReGenerateGemModelXml = false)        {            if (!System.Diagnostics.Debugger.IsAttached)                return;            //SVID            var svid = new VIDGenerator("SVID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_SVID.xml");            svid.Initialize();            svid.GenerateId(Singleton<DataManager>.Instance.VidDataList);            ExportSvid(svid.VIDList, true, true);            //ECID            var ecid = new VIDGenerator("ECID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_ECID.xml");            ecid.Initialize();            ecid.GenerateId(SystemConfigManager.Instance.VidConfigList);            ExportEcid(ecid.VIDList);            //CEID            List<VIDItem> ceids = new List<VIDItem>();            foreach (var eventItem in Singleton<EventManager>.Instance.VidEventList)            {                if (UniversalEvents.UniversalEventsDictionary.ContainsKey(eventItem.Name))                {                    ceids.Add(UniversalEvents.UniversalEventsDictionary[eventItem.Name]);                }                else if (enableGem300Events && Gem300Events.Gem300EventsDictionary.ContainsKey(eventItem.Name))                {                    ceids.Add(Gem300Events.Gem300EventsDictionary[eventItem.Name]);                }            }            ceids = ceids.OrderBy(x => x.Index).ToList();            CustomXmlSerializer.Serialize(ceids, $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_CEID.xml");            ExportCeid(ceids);            //ALID            var alid = new VIDGenerator("ALID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_ALID.xml");            alid.Initialize();            alid.GenerateId(Singleton<EventManager>.Instance.VidAlarmList);            ExportAlid(alid.VIDList);            //DVID, to be designed            Dictionary<string, VIDItem> dvids = new Dictionary<string, VIDItem>();            foreach (var eventItem in ceids)            {                if (eventItem.LinkableVid == null)                    continue;                foreach (var LinkableVid in eventItem.LinkableVid)                {                    string dvidName = ((DataVariables.DataName)LinkableVid).ToString();                    if (DataVariables.DataVariablesDictionary.ContainsKey(dvidName))                        dvids[dvidName] = DataVariables.DataVariablesDictionary[dvidName];                }            }            var dvidList = dvids.Values.ToList().OrderBy(x => x.Index).ToList();            CustomXmlSerializer.Serialize(dvidList, $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_DVID.xml");            ExportDvid(dvidList);            //ReGenerate GemModel.Xml            if (needReGenerateGemModelXml)                ReGenerateGemModelXml(svid.VIDList, ecid.VIDList, dvidList, ceids, alid.VIDList, equipName);        }        private List<VIDItem> OriginalSvids = new List<VIDItem>()        {            new VIDItem(){Name = "AlarmsEnabled",Index = 1,DataType = "List"},            new VIDItem(){Name = "AlarmsSet",Index = 2,DataType = "List"},            new VIDItem(){Name = "Clock",Index = 3,DataType = "Ascii"},            new VIDItem(){Name = "ControlState",Index = 4,DataType = "U4"},            new VIDItem(){Name = "EventsEnabled",Index = 5,DataType = "List"},            new VIDItem(){Name = "PPExecName",Index = 6,DataType = "Ascii"},            new VIDItem(){Name = "PreviousProcessState",Index = 7,DataType = "U1"},            new VIDItem(){Name = "ProcessState",Index = 8,DataType = "U1"},            new VIDItem(){Name = "SpoolCountActual",Index = 9,DataType = "U4"},            new VIDItem(){Name = "SpoolCountTotal",Index = 10,DataType = "U4"},            new VIDItem(){Name = "SpoolFullTime",Index = 11,DataType = "Ascii"},            new VIDItem(){Name = "SpoolStartTime",Index = 12,DataType = "Ascii"},            new VIDItem(){Name = "SpoolState",Index = 13,DataType = "Ascii"},            new VIDItem(){Name = "SpoolSubstate",Index = 14,DataType = "Ascii"},        };        private List<VIDItem> OriginalEcids = new List<VIDItem>()        {            new VIDItem(){Name = "EstablishCommunicationsTimeout",Index = 2000,DataType = "U2",Description = "2"},            new VIDItem(){Name = "MaxSpoolTransmit",Index = 2001,DataType = "U4",Description = "100"},            new VIDItem(){Name = "OverWriteSpool",Index = 2003,DataType = "Boolean",Description = "FALSE"},            new VIDItem(){Name = "MaxSpoolCapacity",Index = 2005,DataType = "U4",Description = "100"},            new VIDItem(){Name = "SpoolEnabled",Index = 2006,DataType = "Boolean",Description = "False"},            new VIDItem(){Name = "TimeFormat",Index = 2007,DataType = "U1",Description = "0"},        };        private void ExportAlid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)        {            var lists = dataList.OrderBy(x => x.ModuleIndex).ThenBy(x => x.Name).ToList();            bool? result = defaultPath;            string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";            if (!defaultPath)            {                Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();                dlg.DefaultExt = ".xlsx"; // Default file extension                 dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";                dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension                 result = dlg.ShowDialog();// Show open file dialog box                savePath = dlg.FileName;            }            if (result == true)            {                System.Data.DataSet ds = new System.Data.DataSet();                ds.Tables.Add(new System.Data.DataTable("ALID(Alarm ID)"));                ds.Tables[0].Columns.Add("ALID");                ds.Tables[0].Columns.Add("Name");                ds.Tables[0].Columns.Add("Description");                Dictionary<int, int> IdDictionary = new Dictionary<int, int>();                foreach (var item in lists)                {                    var row = ds.Tables[0].NewRow();                    if (!IdDictionary.ContainsKey(item.ModuleIndex))                        IdDictionary[item.ModuleIndex] = 0;                    row[0] = item.Index;                    row[1] = item.Name;                    if (string.IsNullOrEmpty(item.Description))                    {                        var arr = item.Name.Split('.');                        for (int i = 0; i < arr.Length; i++)                            row[2] += $"{arr[i]} ";                    }                    else                    {                        row[2] = item.Description;                    }                    ds.Tables[0].Rows.Add(row);                }                if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))                {                    LOG.Write($"Export failed, {reason}");                    return;                }                LOG.Write($"Export succeed, file save as {savePath}");            }        }        private void ExportCeid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)        {            var lists = dataList.OrderBy(x => x.Index).ToList();            bool? result = defaultPath;            string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";            if (!defaultPath)            {                Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();                dlg.DefaultExt = ".xlsx"; // Default file extension                 dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";                dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension                 result = dlg.ShowDialog();// Show open file dialog box                savePath = dlg.FileName;            }            if (result == true)            {                System.Data.DataSet ds = new System.Data.DataSet();                ds.Tables.Add(new System.Data.DataTable("CEID(Collection Events)"));                ds.Tables[0].Columns.Add("CEID");                ds.Tables[0].Columns.Add("Name");                ds.Tables[0].Columns.Add("LinkableVID");                ds.Tables[0].Columns.Add("Description");                Dictionary<int, int> IdDictionary = new Dictionary<int, int>();                foreach (var item in lists)                {                    var row = ds.Tables[0].NewRow();                    if (!IdDictionary.ContainsKey(item.ModuleIndex))                        IdDictionary[item.ModuleIndex] = 0;                    row[0] = item.Index;                    row[1] = item.Name;                    if (item.LinkableVid != null)                    {                        string LinkableVidDescription = String.Empty;                        for (int i = 0; i < item.LinkableVid.Length; i++)                        {                            LinkableVidDescription += $"{(DataVariables.DataName)item.LinkableVid[i]} = {item.LinkableVid[i]} \r\n";                        }                        row[2] = LinkableVidDescription;                    }                    if (string.IsNullOrEmpty(item.Description))                    {                        var arr = item.Name.Split('.');                        for (int i = 0; i < arr.Length; i++)                            row[3] += $"{arr[i]} ";                    }                    else                    {                        row[3] = item.Description;                    }                    ds.Tables[0].Rows.Add(row);                }                if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))                {                    LOG.Write($"Export failed, {reason}");                    return;                }                LOG.Write($"Export succeed, file save as {savePath}");            }        }        private void ExportEcid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)        {            var lists = dataList.OrderBy(x => x.Index).ToList();            bool? result = defaultPath;            string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";            if (!defaultPath)            {                Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();                dlg.DefaultExt = ".xlsx"; // Default file extension                 dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";                dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension                 result = dlg.ShowDialog();// Show open file dialog box                savePath = dlg.FileName;            }            if (result == true)            {                System.Data.DataSet ds = new System.Data.DataSet();                ds.Tables.Add(new System.Data.DataTable("ECID(Equipment Constant)"));                ds.Tables[0].Columns.Add("ECID");                ds.Tables[0].Columns.Add("Name");                ds.Tables[0].Columns.Add("Format");                ds.Tables[0].Columns.Add("Description");                Dictionary<int, int> IdDictionary = new Dictionary<int, int>();                foreach (var item in lists)                {                    var row = ds.Tables[0].NewRow();                    if (!IdDictionary.ContainsKey(item.ModuleIndex))                        IdDictionary[item.ModuleIndex] = 0;                    row[0] = item.Index;                    row[1] = item.Name;                    row[2] = VIDItemType2GemDataType(item.DataType);                    if (string.IsNullOrEmpty(item.Description))                    {                        var arr = item.Name.Split('.');                        for (int i = 0; i < arr.Length; i++)                            row[3] += $"{arr[i]} ";                    }                    else                    {                        row[3] = item.Description;                    }                    ds.Tables[0].Rows.Add(row);                }                if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))                {                    LOG.Write($"Export failed, {reason}");                    return;                }                LOG.Write($"Export succeed, file save as {savePath}");            }        }        private void ExportSvid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)        {            var lists = dataList.OrderBy(x => x.Index).ToList();            bool? result = defaultPath;            string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";            if (!defaultPath)            {                Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();                dlg.DefaultExt = ".xlsx"; // Default file extension                 dlg.FileName = $"Chamber_Status_Variable_{DateTime.Now:yyyyMMdd_HHmmss}";                dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension                 result = dlg.ShowDialog();// Show open file dialog box                savePath = dlg.FileName;            }            if (result == true)            {                System.Data.DataSet ds = new System.Data.DataSet();                ds.Tables.Add(new System.Data.DataTable("SVID(Status Variable)"));                ds.Tables[0].Columns.Add("SVID");                ds.Tables[0].Columns.Add("Name");                ds.Tables[0].Columns.Add("Format");                ds.Tables[0].Columns.Add("Description");                Dictionary<int, int> IdDictionary = new Dictionary<int, int>();                foreach (var item in lists)                {                    var row = ds.Tables[0].NewRow();                    if (!IdDictionary.ContainsKey(item.ModuleIndex))                        IdDictionary[item.ModuleIndex] = 0;                    row[0] = item.Index;                    row[1] = item.Name;                    row[2] = VIDItemType2GemDataType(item.DataType);                    if (string.IsNullOrEmpty(item.Description))                    {                        var arr = item.Name.Split('.');                        for (int i = 0; i < arr.Length; i++)                            row[3] += $"{arr[i]} ";                    }                    else                    {                        row[3] = item.Description;                    }                    ds.Tables[0].Rows.Add(row);                }                if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))                {                    LOG.Write($"Export failed, {reason}");                    return;                }                LOG.Write($"Export succeed, file save as {savePath}");            }        }        private void ExportDvid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)        {            var lists = dataList.OrderBy(x => x.Index).ToList();            bool? result = defaultPath;            string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";            if (!defaultPath)            {                Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();                dlg.DefaultExt = ".xlsx"; // Default file extension                 dlg.FileName = $"Data_Variable_{DateTime.Now:yyyyMMdd_HHmmss}";                dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension                 result = dlg.ShowDialog();// Show open file dialog box                savePath = dlg.FileName;            }            if (result == true)            {                System.Data.DataSet ds = new System.Data.DataSet();                ds.Tables.Add(new System.Data.DataTable("DVID(Data Variable)"));                ds.Tables[0].Columns.Add("DVID");                ds.Tables[0].Columns.Add("Name");                ds.Tables[0].Columns.Add("Format");                ds.Tables[0].Columns.Add("Description");                Dictionary<int, int> IdDictionary = new Dictionary<int, int>();                foreach (var item in lists)                {                    var row = ds.Tables[0].NewRow();                    if (!IdDictionary.ContainsKey(item.ModuleIndex))                        IdDictionary[item.ModuleIndex] = 0;                    row[0] = item.Index;                    row[1] = item.Name;                    row[2] = VIDItemType2GemDataType(item.DataType);                    if (string.IsNullOrEmpty(item.Description))                    {                        var arr = item.Name.Split('.');                        for (int i = 0; i < arr.Length; i++)                            row[3] += $"{arr[i]} ";                    }                    else                    {                        row[3] = item.Description;                    }                    ds.Tables[0].Rows.Add(row);                }                if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))                {                    LOG.Write($"Export failed, {reason}");                    return;                }                LOG.Write($"Export succeed, file save as {savePath}");            }        }        private void ReGenerateGemModelXml(List<VIDItem> Svids, List<VIDItem> Ecids, List<VIDItem> Dvids, List<VIDItem> Ceids, List<VIDItem> Alids, string equipName)        {            XmlDocument xml = new XmlDocument();            string _defaultPathFile = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}{equipName}GemModel.xml";            try            {                xml.Load(_defaultPathFile);                if (Svids != null)                {                    XmlNode itemNodes = xml.SelectSingleNode("Equipment/StatusVariables");                    itemNodes.RemoveAll();                    foreach (var svid in OriginalSvids)                    {                        XmlElement subNode = xml.CreateElement("SVID");                        subNode.SetAttribute("id", svid.Index.ToString());                        subNode.SetAttribute("valueType", svid.DataType);                        subNode.SetAttribute("logicalName", svid.Name);                        subNode.SetAttribute("value", "");                        subNode.SetAttribute("eventTrigger", "");                        subNode.SetAttribute("units", "");                        subNode.SetAttribute("description", svid.Description);                        subNode.SetAttribute("isArray", "false");                        itemNodes.AppendChild(subNode);                    }                    foreach (var svid in Svids)                    {                        XmlElement subNode = xml.CreateElement("SVID");                        subNode.SetAttribute("id", svid.Index.ToString());                        subNode.SetAttribute("valueType", VIDItemType2GemDataType(svid.DataType));                        subNode.SetAttribute("logicalName", svid.Name);                        subNode.SetAttribute("value", "");                        subNode.SetAttribute("eventTrigger", "");                        subNode.SetAttribute("units", "");                        subNode.SetAttribute("description", svid.Description);                        subNode.SetAttribute("isArray", "false");                        itemNodes.AppendChild(subNode);                    }                }                if (Ecids != null)                {                    XmlNode itemNodes = xml.SelectSingleNode("Equipment/EquipmentConstants");                    itemNodes.RemoveAll();                    foreach (var ecid in OriginalEcids)                    {                        XmlElement subNode = xml.CreateElement("ECID");                        subNode.SetAttribute("id", ecid.Index.ToString());                        subNode.SetAttribute("valueType", ecid.DataType);                        subNode.SetAttribute("logicalName", ecid.Name);                        subNode.SetAttribute("value", ecid.Description);                        subNode.SetAttribute("min", "0");                        subNode.SetAttribute("max", "100");                        subNode.SetAttribute("eventTrigger", "");                        subNode.SetAttribute("units", "");                        subNode.SetAttribute("description", "");                        subNode.SetAttribute("isArray", "false");                        itemNodes.AppendChild(subNode);                    }                    foreach (var ecid in Ecids)                    {                        XmlElement subNode = xml.CreateElement("ECID");                        subNode.SetAttribute("id", ecid.Index.ToString());                        subNode.SetAttribute("valueType", VIDItemType2GemDataType(ecid.DataType));                        subNode.SetAttribute("logicalName", ecid.Name);                        subNode.SetAttribute("value", "");                        subNode.SetAttribute("min", "");                        subNode.SetAttribute("max", "");                        subNode.SetAttribute("eventTrigger", "");                        subNode.SetAttribute("units", "");                        subNode.SetAttribute("description", ecid.Description);                        subNode.SetAttribute("isArray", "false");                        itemNodes.AppendChild(subNode);                    }                }                if (Dvids != null)                {                    XmlNode itemNodes = xml.SelectSingleNode("Equipment/DataVariables");                    itemNodes.RemoveAll();                    foreach (var dvids in Dvids)                    {                        if (dvids.Index < 500)                            continue;                        XmlElement subNode = xml.CreateElement("DVID");                        subNode.SetAttribute("id", dvids.Index.ToString());                        subNode.SetAttribute("valueType", VIDItemType2GemDataType(dvids.DataType));                        subNode.SetAttribute("logicalName", dvids.Name);                        subNode.SetAttribute("value", "");                        subNode.SetAttribute("eventTrigger", "");                        subNode.SetAttribute("description", dvids.Description);                        subNode.SetAttribute("isArray", "false");                        itemNodes.AppendChild(subNode);                    }                }                if (Ceids != null)                {                    int reportID = 0;                    Dictionary<string, int> reportDictionary = new Dictionary<string, int>();                    XmlNode RPTIDNodes = xml.SelectSingleNode("Equipment/DataCollections/RPTIDs");                    RPTIDNodes.RemoveAll();                    foreach (var ceid in Ceids)                    {                        XmlElement RPTID = xml.CreateElement("RPTID");                        if (ceid.LinkableVid != null)                        {                            string reportKey = string.Join(",", ceid.LinkableVid);                            if (!reportDictionary.ContainsKey(reportKey))                            {                                reportID += 1;                                reportDictionary[reportKey] = reportID;                                RPTID.SetAttribute("id", reportID.ToString());                                RPTID.SetAttribute("logicalName", $"DefaultDefinedReport_{reportID}");                                foreach (var vid in ceid.LinkableVid)                                {                                    XmlElement ReportVariable = xml.CreateElement("ReportVariable");                                    ReportVariable.SetAttribute("id", vid.ToString());                                    ReportVariable.SetAttribute("varType", vid < 500 ? "StatusVariable" : "DataVariable");                                    ReportVariable.SetAttribute("logicalName", ((DataVariables.DataName)vid).ToString());                                    RPTID.AppendChild(ReportVariable);                                }                                RPTIDNodes.AppendChild(RPTID);                            }                        }                    }                    XmlNode CEIDNodes = xml.SelectSingleNode("Equipment/DataCollections/CEIDs");                    CEIDNodes.RemoveAll();                    foreach (var ceid in Ceids)                    {                        XmlElement CEID = xml.CreateElement("CEID");                        CEID.SetAttribute("id", ceid.Index.ToString());                        CEID.SetAttribute("logicalName", ceid.Name);                        CEID.SetAttribute("description", ceid.Description);                        CEID.SetAttribute("enabled", "true");                        if (ceid.LinkableVid != null)                        {                            string reportKey = string.Join(",", ceid.LinkableVid);                            XmlElement RPTID = xml.CreateElement("RPTID");                            RPTID.SetAttribute("id", reportDictionary[reportKey].ToString());                            RPTID.SetAttribute("logicalName", $"DefaultDefinedReport_{reportDictionary[reportKey]}");                            foreach (var vid in ceid.LinkableVid)                            {                                XmlElement ReportVariable = xml.CreateElement("ReportVariable");                                ReportVariable.SetAttribute("id", vid.ToString());                                ReportVariable.SetAttribute("varType", vid < 500 ? "StatusVariable" : "DataVariable");                                ReportVariable.SetAttribute("logicalName", ((DataVariables.DataName)vid).ToString());                                RPTID.AppendChild(ReportVariable);                            }                            CEID.AppendChild(RPTID);                        }                        CEIDNodes.AppendChild(CEID);                    }                }                if (Alids != null)                {                    XmlNode itemNodes = xml.SelectSingleNode("Equipment/Alarms");                    itemNodes.RemoveAll();                    foreach (var alid in Alids)                    {                        XmlElement subNode = xml.CreateElement("ALID");                        subNode.SetAttribute("id", alid.Index.ToString());                        subNode.SetAttribute("logicalName", alid.Name);                        subNode.SetAttribute("description", alid.Description);                        subNode.SetAttribute("category", "EquipmentStatusWarning");                        subNode.SetAttribute("enabled", "false");                        subNode.SetAttribute("eventSet", "1" + alid.Index);                        subNode.SetAttribute("eventClear", "2" + alid.Index);                        itemNodes.AppendChild(subNode);                    }                }                xml.Save(_defaultPathFile);            }            catch (Exception ex)            {                LOG.Write(ex);            }        }        string VIDItemType2GemDataType(string VIDItemType)        {            switch (VIDItemType.Replace("System.", ""))            {                case "List":                    return "List";                case "I1":                    return "I1";                case "I4":                    return "I4";                case "U1":                    return "U1";                case "U2":                    return "U2";                case "U4":                    return "U4";                case "Int":                case "Integer":                    return "I4";                case "Bool":                case "Boolean":                    return "Boolean";                case "Float":                case "Single":                case "Double":                case "F8":                    return "F8";                case "Binary":                    return "Binary";                default:                    return "Ascii";            }        }    }}
 |