123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Text.RegularExpressions;
- using System.Threading.Tasks;
- using Aitex.Core.RT.Device;
- using Aitex.Core.RT.Log;
- namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.Robot.MAG7
- {
- public class Mag7RobotHandlerBase<T> : IHandler where T : ITransferMsg, new()
- {
- public int ID { get; set; }
- public int Unit { get; set; }
- public bool IsBackground
- {
- get
- {
- return !_seqMode && _imp.background;
- }
- }
- private static int retry_time = 3;
- private int retry_count = retry_time;
- private object[] _objs = null;
- private TokenGenerator _generator;
- private T _imp = new T();
- private Robot _device;
- private bool _seqMode = true;
- public Mag7RobotHandlerBase(IDevice device)
- {
- _device = (Robot)device;
- _imp.Robot = device;
- }
- public Mag7RobotHandlerBase(IDevice device, ref TokenGenerator gen, params object[] objs)
- {
- _device = (Robot)device;
- _imp.Robot = device;
- this._generator = gen;
- this._objs = objs;
- }
- public bool Execute<TPort>(ref TPort port) where TPort : ICommunication
- {
- retry_count = retry_time;
- ID = _generator.create();
- return port.Write(string.Format("{0}{1}", package(), ProtocolTag.tag_end));
- }
- /// <summary>
- /// return value: bhandle
- /// </summary>
- /// <typeparam name="TPort"></typeparam>
- /// <param name="port"></param>
- /// <param name="msg"></param>
- /// <param name="completed"></param>
- /// <returns></returns>
- ///
- public bool OnMessage<TPort>(ref TPort port, string message, out bool completed) where TPort : ICommunication
- {
- try
- {
- completed = false;
- string package = message;
- string[] words = Regex.Split(package, ProtocolTag.cmd_token);
- string type = words[0];
- if (type == ProtocolTag.resp_tag_error)
- {
- int error = int.Parse(words[1]);
- _device.LastErrorCode = error;
- if (error != 0) //can't retry
- {
- string warning = string.Format("Error code {0:D4}", error);
- LOG.Warning(warning);
- completed = _imp.unpackage(type, words);
- throw (new ExcuteFailedException(warning));
- }
- if (retry_count-- <= 0)
- {
- string warning = string.Format("retry over {0} times", retry_time);
- LOG.Warning(warning);
- throw (new ExcuteFailedException(warning));
- }
- return true;
- }
- else if (type == ProtocolTag.resp_tag_event)
- {
- string evtType = words[3];
- string evtInfo = words[5];
- if (_imp.evt)
- completed = _imp.unpackage(type, words);
- return _imp.evt;
- }
- else if (type == ProtocolTag.resp_tag_excute)
- {
- completed = _imp.unpackage(type, words);
- if (completed)
- {
- _generator.release(ID);
- return true;
- }
- return true;
- }
- else
- {
- completed = _imp.unpackage(type, words);
- if (completed)
- {
- _generator.release(ID);
- return true;
- }
- return true;
- }
- }
- catch (ExcuteFailedException e)
- {
- throw (e);
- }
- catch (InvalidPackageException e)
- {
- throw e;
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- throw (new InvalidPackageException(message));
- }
- }
- private string package()
- {
- //Commands<CR>
- string data = string.Empty;
- data = _imp.package(this._objs);
- return data;
- }
- }
- }
|