#region << 版 本 注 释 >>
/*----------------------------------------------------------------
 * 命名空间:WIDESEAWCS_Communicator
 * 创建者:胡童庆
 * 创建时间:2024/8/2 16:13:36
 * 版本:V1.0.0
 * 描述:基础通讯抽象类,封装连接、断开连接、读取、写入等方法
 *
 * ----------------------------------------------------------------
 * 修改人:
 * 修改时间:
 * 版本:V1.0.1
 * 修改说明:
 * 
 *----------------------------------------------------------------*/
#endregion << 版 本 注 释 >>
using HslCommunication;
using HslCommunication.LogNet;
using System.Diagnostics.CodeAnalysis;
namespace WIDESEAWCS_Communicator
{
    public abstract class BaseCommunicator: IDisposable
    {
        /// 
        /// 构造函数
        /// 
        protected BaseCommunicator()
        {
        }
        /// 
        /// 日志记录实例对象
        /// 
        public abstract ILogNet LogNet { get; }
        /// 
        /// 设备名称
        /// 
        public abstract string Name { get; }
        ///   
        /// 获取当前通讯器是否已连接到PLC。  
        /// 
        public abstract bool IsConnected { get; }
        ///   
        /// 连接到PLC。
        ///   
        /// 如果连接成功则返回true,否则返回false。  
        public abstract bool Connect();
        ///   
        /// 断开与工业设备的连接。  
        ///   
        /// 如果成功断开连接则返回true,如果已经是断开状态则返回false。  
        public abstract bool Disconnect();
        ///   
        /// 从PLC读取数据。  
        ///   
        /// 源地址,具体格式取决于使用的工业协议。  
        /// 要读取的数据长度。  
        /// 读取到的数据,如果读取失败则可能返回null或空数组。  
        public abstract byte[] Read(string address, int length);
        /// 
        /// 从PLC读取数据。
        /// 
        /// 读取数据的类型泛型。
        /// 源地址,具体格式取决于使用的工业协议。
        /// 读取到的数据,如果读取失败则可能返回null或抛出异常。
        public abstract T Read(string address);
        /// 
        /// 从PLC读取数据。
        /// 
        /// 源地址,具体格式取决于使用的工业协议。
        /// 数据类型。
        /// 读取到的数据,如果读取失败则可能返回null或抛出异常。
        public abstract object ReadAsObj(string address, string dataType);
        ///   
        /// 向PLC写入数据。  
        ///   
        /// 源地址,具体格式取决于使用的工业协议。  
        /// 要写入的数据。  
        /// 如果写入成功则返回true,否则抛出异常。  
        public abstract bool Write(string address, byte[] data);
        /// 
        /// 向PLC写入数据。  
        /// 
        /// 读取数据的类型泛型。
        /// 源地址,具体格式取决于使用的工业协议。
        /// 要写入的数据。
        /// 如果写入成功则返回true,否则抛出异常。
        public abstract bool Write(string address, T value) where T : notnull;
        /// 
        /// 向PLC写入数据。
        /// 
        /// 源地址,具体格式取决于使用的工业协议。
        /// 要写入的数据类型。
        /// 要写入的数据。
        /// 如果写入成功则返回true,失败则抛出异常。
        /// 
        public abstract bool WriteObj(string address, string dataType, object value);
        /// 
        /// 等待指定地址的泛型类型值为指定的值
        /// 
        /// 指定的值的类型泛型。
        /// 源地址,具体格式取决于使用的工业协议。
        /// 读取的频率。
        /// 等待的超时时间,如果超时时间为-1的话,则是无期限等待。
        /// 等待检测的值
        /// 是否等待成功的结果对象,一旦通信失败,或是等待超时就返回失败。否则返回成功,并告知调用方等待了多久。
        public abstract OperateResult Wait(string address, int readInterval, int waitTimeout, T value) where T : struct;
        /// 
        /// 读取自定义的数据类型,需要继承自IDataTransfer接口,返回一个新的类型的实例对象。
        /// 
        /// 自定义的数据类型泛型。
        /// 源地址,具体格式取决于使用的工业协议。
        /// 成功返回自定义类型数据,失败抛出异常。
        public abstract T ReadCustomer(string address) where T : IDataTransfer, new();
        /// 
        /// 写入自定义类型的数据,该类型必须继承自IDataTransfer接口。
        /// 
        /// 自定义的数据类型泛型。
        /// 源地址,具体格式取决于使用的工业协议。
        /// 要写入数据。
        /// 如果写入成功则返回true,失败则抛出异常。
        public abstract bool WriteCustomer(string address, [NotNull] T value) where T : IDataTransfer, new();
        /// 
        /// 释放对象资源的接口。
        /// 
        public abstract void Dispose();
    }
}