/*************************************************************************** * Copyright (C) 2011-2016 by Maxim Kochetkov * * fido_max@inbox.ru * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; version 2 of the License. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ #ifndef DA_GKR_H #define DA_GKR_H #include "da.h" #define c_wp 11 //chanell size with params #define c_p 7 //chanell size without params namespace FT3 { class B_GKR: public DA { public: //Methods B_GKR(TMdPrm& prm, uint16_t id, uint16_t n, bool has_params); ~B_GKR(); uint8_t state; uint16_t ID; uint16_t count_n; bool with_params; void AddChannel(uint8_t iid); uint16_t Task(uint16_t); uint16_t HandleEvent(int64_t, uint8_t *); uint8_t cmdGet(uint16_t prmID, uint8_t * out); uint8_t cmdSet(uint8_t * req, uint8_t addr); uint16_t setVal(TVal &val); void setTU(uint8_t, uint8_t, uint8_t, uint16_t); void runTU(uint8_t, uint8_t, uint8_t, uint16_t); string getStatus(void); void saveIO(void); void loadIO(bool force = false); void tmHandler(void); class SKRchannel { public: SKRchannel(uint8_t iid, DA* owner) : da(owner), id(iid), State(TSYS::strMess("state_%d", id + 1), TSYS::strMess(_("State %d"), id + 1)), On(TSYS::strMess("on_%d", id + 1), TSYS::strMess(_("On %d"), id + 1)), Off(TSYS::strMess("off_%d", id + 1), TSYS::strMess(_("Off %d"), id + 1)), Run(TSYS::strMess("run_%d", id + 1), TSYS::strMess(_("Run %d"), id + 1)), Reset(TSYS::strMess("reset_%d", id + 1), TSYS::strMess(_("Reset %d"), id + 1)), Lock(TSYS::strMess("lock_%d", id + 1), TSYS::strMess(_("Lock %d"), id + 1)), Lubrication(TSYS::strMess("lub_%d", id + 1), TSYS::strMess(_("Lubrication %d"), id + 1)), Time(TSYS::strMess("time_%d", id + 1), TSYS::strMess(_("Time %d"), id + 1)), ExTime(TSYS::strMess("extime_%d", id + 1), TSYS::strMess(_("ExTime %d"), id + 1)), Time_Lub(TSYS::strMess("timelub_%d", id + 1), TSYS::strMess(_("Time_Lub %d"), id + 1)), Timeout_PO(TSYS::strMess("timeout_po_%d", id + 1), TSYS::strMess(_("Timeout_PO %d"), id + 1)) { } DA* da; uint8_t id; ui8Data State, On, Off, Run, Reset, Lock, Lubrication; ui16Data Time, Time_Lub, ExTime, Timeout_PO; void UpdateState(uint16_t ID, uint8_t cl); }; vector data; int lnkSize() { if(with_params) { return data.size() * c_wp; //params SKRchannel } else { return data.size() * c_p; //params SKRchannel } } int lnkId(const string &id) { if(with_params) { for(int i_l = 0; i_l < data.size(); i_l++) { if(data[i_l].State.lnk.prmName == id) return i_l * c_wp; if(data[i_l].On.lnk.prmName == id) return i_l * c_wp + 1; if(data[i_l].Off.lnk.prmName == id) return i_l * c_wp + 2; if(data[i_l].Run.lnk.prmName == id) return i_l * c_wp + 3; if(data[i_l].Reset.lnk.prmName == id) return i_l * c_wp + 4; if(data[i_l].Lock.lnk.prmName == id) return i_l * c_wp + 5; if(data[i_l].Lubrication.lnk.prmName == id) return i_l * c_wp + 6; if(data[i_l].Time.lnk.prmName == id) return i_l * c_wp + 7; if(data[i_l].ExTime.lnk.prmName == id) return i_l * c_wp + 8; if(data[i_l].Time_Lub.lnk.prmName == id) return i_l * c_wp + 9; if(data[i_l].Timeout_PO.lnk.prmName == id) return i_l * c_wp + 10; } } else { for(int i_l = 0; i_l < data.size(); i_l++) { if(data[i_l].State.lnk.prmName == id) return i_l * c_p; if(data[i_l].On.lnk.prmName == id) return i_l * c_p + 1; if(data[i_l].Off.lnk.prmName == id) return i_l * c_p + 2; if(data[i_l].Run.lnk.prmName == id) return i_l * c_p + 3; if(data[i_l].Reset.lnk.prmName == id) return i_l * c_p + 4; if(data[i_l].Lock.lnk.prmName == id) return i_l * c_p + 5; if(data[i_l].Lubrication.lnk.prmName == id) return i_l * c_p + 6; } } return -1; } SLnk &lnk(int num) { if(with_params) { if((data.size() > 0) && ((data.size() * c_wp) > num)) { switch(num % c_wp) { case 0: return data[num / c_wp].State.lnk; break; case 1: return data[num / c_wp].On.lnk; break; case 2: return data[num / c_wp].Off.lnk; break; case 3: return data[num / c_wp].Run.lnk; break; case 4: return data[num / c_wp].Reset.lnk; break; case 5: return data[num / c_wp].Lock.lnk; break; case 6: return data[num / c_wp].Lubrication.lnk; break; case 7: return data[num / c_wp].Time.lnk; break; case 8: return data[num / c_wp].ExTime.lnk; break; case 9: return data[num / c_wp].Time_Lub.lnk; break; case 10: return data[num / c_wp].Timeout_PO.lnk; break; } } } else { if((data.size() > 0) && ((data.size() * c_p) > num)) { switch(num % c_p) { case 0: return data[num / c_p].State.lnk; break; case 1: return data[num / c_p].On.lnk; break; case 2: return data[num / c_p].Off.lnk; break; case 3: return data[num / c_p].Run.lnk; break; case 4: return data[num / c_p].Reset.lnk; break; case 5: return data[num / c_p].Lock.lnk; break; case 6: return data[num / c_p].Lubrication.lnk; break; } } } } }; } //End namespace #endif //DA_GKR_H