forked from GerhardHoffmann/DCLibraries
		
	Compare commits
	
		
			27 Commits
		
	
	
		
			1.99.5
			...
			gerhard-en
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4cc964e8c2 | |||
| f910b7d057 | |||
| 5dd90e9597 | |||
| 47f09067ea | |||
| 65163354bd | |||
| 5f88c8f856 | |||
| 4efbbcbb5a | |||
| 1155b83ca9 | |||
| 631550b55e | |||
| 9e5c379e8a | |||
| 6b9e795206 | |||
| b7ff6dcdbe | |||
| 2025a75d56 | |||
| 6176285b89 | |||
| 0344150950 | |||
| 68813a49c5 | |||
| 8e287e3163 | |||
| fd58f41c87 | |||
| ece75887e2 | |||
| cee4caf77d | |||
| 6b2830ee83 | |||
| cd4bddd169 | |||
| 8a380c9845 | |||
| 23619543b2 | |||
| be16fe4981 | |||
| cf621c02bd | |||
| ee26eef50f | 
| @@ -21,15 +21,14 @@ INCLUDEPATH += ../include | |||||||
| win32 { | win32 { | ||||||
|     BUILD_DATE=$$system("date /t") |     BUILD_DATE=$$system("date /t") | ||||||
|     BUILD_TIME=$$system("time /t") |     BUILD_TIME=$$system("time /t") | ||||||
|     GIT_COMMIT="" |  | ||||||
|     EXTENDED_VERSION="" |  | ||||||
| } else { | } else { | ||||||
|     BUILD_DATE=$$system("date +%d-%m-%y") |     BUILD_DATE=$$system("date +%d-%m-%y") | ||||||
|     BUILD_TIME=$$system("date +%H:%M:%S") |     BUILD_TIME=$$system("date +%H:%M:%S") | ||||||
|     GIT_COMMIT=$$system("git log -1 --format=oneline | cut -d' ' -f1") |  | ||||||
|     EXTENDED_VERSION="$${VERSION}-$${GIT_COMMIT}" |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | GIT_COMMIT=$$system("git log -1 --format=oneline | cut -d' ' -f1") | ||||||
|  |  | ||||||
|  | EXTENDED_VERSION="$${VERSION}-$${GIT_COMMIT}" | ||||||
|  |  | ||||||
| DEFINES+=APP_VERSION=\\\"$$VERSION\\\" | DEFINES+=APP_VERSION=\\\"$$VERSION\\\" | ||||||
| DEFINES+=APP_BUILD_DATE=\\\"$$BUILD_DATE\\\" | DEFINES+=APP_BUILD_DATE=\\\"$$BUILD_DATE\\\" | ||||||
|   | |||||||
| @@ -375,9 +375,6 @@ bool T_winComPort::working(uint16_t *nextScreen, uint8_t *useNavi) | |||||||
|     // bit0,1: enable/disable button "next" |     // bit0,1: enable/disable button "next" | ||||||
|     // bit2,3: enable/disable button "home" |     // bit2,3: enable/disable button "home" | ||||||
|     // bit4,5: enable/disable button "back" |     // bit4,5: enable/disable button "back" | ||||||
|     QString  bs, cn; |  | ||||||
|     int br, ci; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     this->updateGui(); |     this->updateGui(); | ||||||
|     *nextScreen=0;   // 0=no change |     *nextScreen=0;   // 0=no change | ||||||
| @@ -388,29 +385,22 @@ bool T_winComPort::working(uint16_t *nextScreen, uint8_t *useNavi) | |||||||
|         // load and use last settings:  -------------------- |         // load and use last settings:  -------------------- | ||||||
|         QByteArray myBA; |         QByteArray myBA; | ||||||
|         myBA=datei_readFromFile(FILENAME_COMPORT); |         myBA=datei_readFromFile(FILENAME_COMPORT); | ||||||
|         if (myBA.length()>0) |  | ||||||
|         { |         //uint32_t len= datei_nrOfEntriesInFile(myBA); | ||||||
|             bs=csv_getEntryAsString(myBA,0);      // read the 's'     war 2!?? |         //uint64_t ulltmp=csv_getEntryAs2Ulong(myBA,0); | ||||||
|             br=csv_getEntryAsInt(myBA,1);               // z.B. 5 (5.Eintrag in der Baud-Liste) |         //qDebug()<<"win_startup load long numer: "<<ulltmp; | ||||||
|  |  | ||||||
|  |         QString  bs=csv_getEntryAsString(myBA,0);      // read the 's'     war 2!?? | ||||||
|  |         int br=csv_getEntryAsInt(myBA,1);               // z.B. 5 (5.Eintrag in der Baud-Liste) | ||||||
|         bs=csv_getEntryAsString(myBA,2);                // z.B 115200 |         bs=csv_getEntryAsString(myBA,2);                // z.B 115200 | ||||||
|             cn=csv_getEntryAsString(myBA,3);       // z.B. COM9 |         QString  cn=csv_getEntryAsString(myBA,3);       // z.B. COM9 | ||||||
|             ci=csv_getEntryAsInt(myBA,4);               // Eintragsnummer in COM-Fenster |         int ci=csv_getEntryAsInt(myBA,4);               // Eintragsnummer in COM-Fenster | ||||||
|  |         //qDebug()<<"win_startup loaded com settings: "<<br<<" "<<bs<<" "<<cn; | ||||||
|         HWaccess->dc_openSerial(br,bs,cn,1); |         HWaccess->dc_openSerial(br,bs,cn,1); | ||||||
|  |         //CB_baudSel->setCurrentIndex(br);    // im BR auswahlfenster diese Baud vorgeben | ||||||
|         CB_portSel->setCurrentIndex(ci);    // den Port aus der Datei hier vorgeben |         CB_portSel->setCurrentIndex(ci);    // den Port aus der Datei hier vorgeben | ||||||
|         connectButton->setChecked(true);    // connect Taste "druecken" |         connectButton->setChecked(true);    // connect Taste "druecken" | ||||||
|         } else |  | ||||||
|         { |  | ||||||
|             // open with default settings |  | ||||||
|             qDebug()<<"CArunGui: open serial with default values"; |  | ||||||
|  |  | ||||||
|             bs="115200"; |  | ||||||
|             br=5; |  | ||||||
|             //cn="COM14";     // Windows |  | ||||||
|             cn="ttymxc2";   // PTU5 |  | ||||||
|             ci=2; |  | ||||||
|             HWaccess->dc_openSerial(br,bs,cn,1); |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         myTO->start(100);     // restart |         myTO->start(100);     // restart | ||||||
|         myStep++; |         myStep++; | ||||||
|     } else |     } else | ||||||
| @@ -420,13 +410,9 @@ bool T_winComPort::working(uint16_t *nextScreen, uint8_t *useNavi) | |||||||
|         if (!myTO->isActive()) |         if (!myTO->isActive()) | ||||||
|         { |         { | ||||||
|             if (HWaccess->dc_isPortOpen()) |             if (HWaccess->dc_isPortOpen()) | ||||||
|             { |  | ||||||
|                 myStep++; |                 myStep++; | ||||||
|             } else |             else | ||||||
|             { |                 myStep=99;  // stop automatic connection and wait for manual start | ||||||
|                 myStep=6;   // 13.12.23: start Autoconnect cycle |  | ||||||
|                 qDebug()<<"CArunGui: port is still closed, restarting.."; |  | ||||||
|             } |  | ||||||
|             myTO->start(100); |             myTO->start(100); | ||||||
|         } |         } | ||||||
|     } else |     } else | ||||||
| @@ -448,10 +434,7 @@ bool T_winComPort::working(uint16_t *nextScreen, uint8_t *useNavi) | |||||||
|             if (HWaccess->dc_readAnswTestResponse()) |             if (HWaccess->dc_readAnswTestResponse()) | ||||||
|                 myStep++;   // response was correct |                 myStep++;   // response was correct | ||||||
|             else |             else | ||||||
|             { |                 myStep=99;  // stop automatic connection and wait for manual start | ||||||
|                 myStep=6;   // 13.12.23: start Autoconnect cycle |  | ||||||
|                 qDebug()<<"CArunGui: got no answer from DC, retry.."; |  | ||||||
|             } |  | ||||||
|             myTO->start(100); |             myTO->start(100); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -462,38 +445,23 @@ bool T_winComPort::working(uint16_t *nextScreen, uint8_t *useNavi) | |||||||
|         HWaccess->dc_autoRequest(1); |         HWaccess->dc_autoRequest(1); | ||||||
|         AutSendButton->setChecked(true);        // taste "druecken" |         AutSendButton->setChecked(true);        // taste "druecken" | ||||||
|         myStep++; |         myStep++; | ||||||
|         myTO->start(2000); |  | ||||||
|     } else |     } else | ||||||
|  |  | ||||||
|     if (myStep==5) |     if (myStep==5) | ||||||
|     { |     { | ||||||
|         if (!myTO->isActive()) |         // got next screen: | ||||||
|         { |         //myNextStep=2; // nicht bei CArun | ||||||
|             if (HWaccess->sys_areDCdataValid()) |  | ||||||
|             { |  | ||||||
|                 qDebug()<<"CArunGui: DC is connected"; |  | ||||||
|                 myStep=7;  // OK, connection is up and running |  | ||||||
|             }  else |  | ||||||
|             { |  | ||||||
|                 qDebug()<<"CArunGui: auto request is not running, retry..."; |  | ||||||
|         myStep++; |         myStep++; | ||||||
|                 myTO->start(100); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|     } else |     } else | ||||||
|  |  | ||||||
|     if (myStep==6) |     if (myStep==6) | ||||||
|     { |     { | ||||||
|         // restart autoconnect cycle |         // stop here, everything done | ||||||
|         myTO->start(100);     // restart |  | ||||||
|         myStep=0; |  | ||||||
|     } else |     } else | ||||||
|  |  | ||||||
|     if (myStep==7) |     if (myStep==7) | ||||||
|     { |     { | ||||||
|         // stay here, DC connection is up and running |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     } else |     } else | ||||||
|     { |     { | ||||||
| @@ -502,6 +470,7 @@ bool T_winComPort::working(uint16_t *nextScreen, uint8_t *useNavi) | |||||||
|  |  | ||||||
|     if (myNextStep) |     if (myNextStep) | ||||||
|     { |     { | ||||||
|  |         //qDebug()<<"fenster1 working: "<< myNextStep; | ||||||
|         *nextScreen=myNextStep; |         *nextScreen=myNextStep; | ||||||
|         myNextStep=0; |         myNextStep=0; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| CONFIG += plugin | CONFIG += plugin | ||||||
| QT -= gui | QT -= gui | ||||||
| QT += serialport | QT += widgets serialport | ||||||
|  |  | ||||||
|  |  | ||||||
| win32 { | win32 { | ||||||
| @@ -81,31 +81,37 @@ contains( CONFIG, PTU5_YOCTO ) { | |||||||
| } | } | ||||||
|  |  | ||||||
| HEADERS += \ | HEADERS += \ | ||||||
|  |     $${PWD}/include/com.h \ | ||||||
|     $${PWD}/include/datei.h \ |     $${PWD}/include/datei.h \ | ||||||
|     $${PWD}/include/runProc.h \ |     $${PWD}/include/runProc.h \ | ||||||
|     $${PWD}/include/controlBus.h \ |     $${PWD}/include/controlBus.h \ | ||||||
|  |     $${PWD}/include/datIf.h \ | ||||||
|     $${PWD}/include/dcBL.h \ |     $${PWD}/include/dcBL.h \ | ||||||
|     $${PWD}/include/hwapi.h \ |     $${PWD}/include/hwapi.h \ | ||||||
|     $${PWD}/include/interfaces.h \ |     $${PWD}/include/interfaces.h \ | ||||||
|  |     $${PWD}/include/prot.h \ | ||||||
|     $${PWD}/include/sendWRcmd.h \ |     $${PWD}/include/sendWRcmd.h \ | ||||||
|     $${PWD}/include/storeINdata.h \ |     $${PWD}/include/storeINdata.h \ | ||||||
|     $${PWD}/include/tslib.h \ |     $${PWD}/include/tslib.h \ | ||||||
|     $${PWD}/include/shared_mem_buffer.h \ |     $${PWD}/include/shared_mem_buffer.h \ | ||||||
|     $${PWD}/include/reporting_thread.h \ |     $${PWD}/include/download_thread.h \ | ||||||
|     $${PWD}/include/download_thread.h |     $${PWD}/include/reporting_thread.h | ||||||
|  |  | ||||||
| SOURCES += \ | SOURCES += \ | ||||||
|  |     $${PWD}/src/com.cpp \ | ||||||
|     $${PWD}/src/datei.cpp \ |     $${PWD}/src/datei.cpp \ | ||||||
|     $${PWD}/src/runProc.cpp \ |     $${PWD}/src/runProc.cpp \ | ||||||
|     $${PWD}/src/controlBus.cpp \ |     $${PWD}/src/controlBus.cpp \ | ||||||
|  |     $${PWD}/src/datIf.cpp \ | ||||||
|     $${PWD}/src/dcBL.cpp \ |     $${PWD}/src/dcBL.cpp \ | ||||||
|     $${PWD}/src/hwapi.cpp \ |     $${PWD}/src/hwapi.cpp \ | ||||||
|  |     $${PWD}/src/prot.cpp \ | ||||||
|     $${PWD}/src/sendWRcmd.cpp \ |     $${PWD}/src/sendWRcmd.cpp \ | ||||||
|     $${PWD}/src/storeINdata.cpp \ |     $${PWD}/src/storeINdata.cpp \ | ||||||
|     $${PWD}/src/tslib.cpp \ |     $${PWD}/src/tslib.cpp \ | ||||||
|     $${PWD}/src/shared_mem_buffer.cpp \ |     $${PWD}/src/shared_mem_buffer.cpp \ | ||||||
|     $${PWD}/src/reporting_thread.cpp \ |     $${PWD}/src/download_thread.cpp \ | ||||||
|     $${PWD}/src/download_thread.cpp |     $${PWD}/src/reporting_thread.cpp | ||||||
|  |  | ||||||
|  |  | ||||||
| # INTERFACE = DeviceController | # INTERFACE = DeviceController | ||||||
|   | |||||||
| @@ -1,5 +1,4 @@ | |||||||
| TEMPLATE = subdirs | TEMPLATE = subdirs | ||||||
|  |  | ||||||
| CONFIG += ordered | CONFIG += ordered | ||||||
| SUBDIRS = lib_ca_master lib_ca_slave CArunGUI dCArun | SUBDIRS = lib_ca_master lib_ca_slave CArunGUI dCArun | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										174
									
								
								dCArun/CArun.cpp
									
									
									
									
									
								
							
							
						
						
									
										174
									
								
								dCArun/CArun.cpp
									
									
									
									
									
								
							| @@ -1,174 +0,0 @@ | |||||||
| #include "CArun.h" |  | ||||||
| #include "datei.h" |  | ||||||
|  |  | ||||||
| #include "CCWakelineAbstraction.h" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| CArun::CArun(QObject *parent) |  | ||||||
|     : QObject(parent) |  | ||||||
|     , setupStep(SETUP_STEP::INIT) |  | ||||||
| { |  | ||||||
|     this->timerChainCtrl = new QTimer(this); |  | ||||||
|     this->connect(timerChainCtrl, SIGNAL(timeout()), this, SLOT(chainControl())); |  | ||||||
|     this->timerChainCtrl->setSingleShot(true); |  | ||||||
|     this->timerChainCtrl->setInterval(100); |  | ||||||
|  |  | ||||||
|     loadPlugIn(1); |  | ||||||
|  |  | ||||||
|     // Start setup-steps: |  | ||||||
|     qCritical() << "CArun: start setup..."; |  | ||||||
|  |  | ||||||
|     this->timerChainCtrl->start(); |  | ||||||
|  |  | ||||||
|     this->ccWakelineAbstraction = new CCWakelineAbstraction(this->HWaccess, this); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| char CArun::loadPlugIn(char lade1_entlade2) |  | ||||||
| { |  | ||||||
|     plugInDir.cd("plugins"); |  | ||||||
|     QPluginLoader *pluginLoader = new QPluginLoader(); |  | ||||||
|  |  | ||||||
|     pluginLoader->setFileName("/usr/lib/libCAmaster.so"); // for ptu5 |  | ||||||
|  |  | ||||||
|     if (lade1_entlade2==2) |  | ||||||
|     { |  | ||||||
|         pluginLoader->unload(); |  | ||||||
|         return 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (!pluginLoader->load()) |  | ||||||
|     { |  | ||||||
|         qCritical() << "CArun: cannot load plugin"; |  | ||||||
|     } else |  | ||||||
|         qCritical() << "CArun: plugin loaded: " << pluginLoader->fileName(); |  | ||||||
|  |  | ||||||
|     if (!pluginLoader->isLoaded()) |  | ||||||
|     { |  | ||||||
|         qCritical() << "CArun: ERROR loading plugin: " << pluginLoader->errorString();; |  | ||||||
|         return 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     QObject *plugin = pluginLoader->instance(); |  | ||||||
|     if ( plugin == nullptr) |  | ||||||
|     { |  | ||||||
|         // make instance of the root component (which can hold more then one clases) |  | ||||||
|         // also loads the lib if not yet done |  | ||||||
|         qCritical() << "CArun: ERROR cannot start instance"; |  | ||||||
|         return 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     this->HWaccess = qobject_cast<hwinf *>(plugin); |  | ||||||
|     // make instance to class "hwinf" in dll_HWapi.h over "interfaces.h" |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void CArun::openSerialPort() |  | ||||||
| { |  | ||||||
|     #define FILENAME_COMPORT            "../comport.csv"  // TODO: use absolute path |  | ||||||
|                                                           // use settings (ini-file) |  | ||||||
|             // comport.csv wird mit installiert in: /opt/app/ |  | ||||||
|             // k.A., ob "../comport.csv" gefunden wird. |  | ||||||
|  |  | ||||||
|     qCritical() << "CArun: open serial port..."; |  | ||||||
|  |  | ||||||
|     QString  bs, cn; |  | ||||||
|     int br, ci; |  | ||||||
|  |  | ||||||
|     // load and use last settings:  -------------------- |  | ||||||
|     QByteArray myBA; |  | ||||||
|     myBA=datei_readFromFile(FILENAME_COMPORT); |  | ||||||
|     if (myBA.length()>0) |  | ||||||
|     { |  | ||||||
|         bs=csv_getEntryAsString(myBA,0);      // read the 's'     war 2!?? |  | ||||||
|         br=csv_getEntryAsInt(myBA,1);               // z.B. 5 (5.Eintrag in der Baud-Liste) |  | ||||||
|         bs=csv_getEntryAsString(myBA,2);                // z.B 115200 |  | ||||||
|         cn=csv_getEntryAsString(myBA,3);       // z.B. COM9 |  | ||||||
|         ci=csv_getEntryAsInt(myBA,4);               // Eintragsnummer in COM-Fenster |  | ||||||
|         this->HWaccess->dc_openSerial(br,bs,cn,1); |  | ||||||
|     } else |  | ||||||
|     { |  | ||||||
|         // vermutlich wird dies hier ausgeführt? |  | ||||||
|  |  | ||||||
|         // open with default settings |  | ||||||
|         qCritical() << "CArun: open serial with default values"; |  | ||||||
|  |  | ||||||
|         bs="115200"; |  | ||||||
|         br=5; |  | ||||||
|         //cn="COM14";     // Windows |  | ||||||
|         cn="ttymxc2";   // PTU5 |  | ||||||
|         ci=2; |  | ||||||
|         HWaccess->dc_openSerial(br,bs,cn,1); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void CArun::chainControl(void) |  | ||||||
| { |  | ||||||
|     switch (this->setupStep) { |  | ||||||
|     case SETUP_STEP::INIT: |  | ||||||
|         qCritical() << "CArun: SETUP_STEP::INIT"; |  | ||||||
|         this->setupStep = SETUP_STEP::OPEN_SERIAL_PORT; |  | ||||||
|         this->timerChainCtrl->start(); |  | ||||||
|         break; |  | ||||||
|     case SETUP_STEP::OPEN_SERIAL_PORT: |  | ||||||
|         qCritical() << "CArun: SETUP_STEP::OPEN_SERIAL_PORT"; |  | ||||||
|         this->openSerialPort(); |  | ||||||
|         this->setupStep = SETUP_STEP::CHECK_VALID_DATA; |  | ||||||
|         this->timerChainCtrl->start(); |  | ||||||
|         break; |  | ||||||
|     case SETUP_STEP::TEST_OPEN_PORT: |  | ||||||
|         qCritical() << "CArun: SETUP_STEP::TEST_OPEN_PORT"; |  | ||||||
|         if (this->HWaccess->dc_isPortOpen()) { |  | ||||||
|             this->setupStep = SETUP_STEP::TEST_RESPONSE_REQUEST; |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             qCritical() << "CArun: port is still closed, restarting.."; |  | ||||||
|             this->setupStep = SETUP_STEP::INIT; |  | ||||||
|         } |  | ||||||
|         this->timerChainCtrl->start(); |  | ||||||
|         break; |  | ||||||
|     case SETUP_STEP::TEST_RESPONSE_REQUEST: |  | ||||||
|         qCritical() << "CArun: SETUP_STEP::TEST_RESPONSE_REQUEST"; |  | ||||||
|         this->HWaccess->dc_requTestResponse(); |  | ||||||
|         this->setupStep = SETUP_STEP::TEST_RESPONSE_CHECK; |  | ||||||
|         this->timerChainCtrl->start(); |  | ||||||
|         break; |  | ||||||
|     case SETUP_STEP::TEST_RESPONSE_CHECK: |  | ||||||
|         qCritical() << "CArun: SETUP_STEP::TEST_RESPONSE_CHECK"; |  | ||||||
|         if (this->HWaccess->dc_readAnswTestResponse()) { |  | ||||||
|             // response was correct |  | ||||||
|             this->setupStep = SETUP_STEP::SETUP_AUTOREQEUST; |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             qCritical() << "CArun: got no answer from DC, retry.."; |  | ||||||
|             this->setupStep = SETUP_STEP::INIT; |  | ||||||
|         } |  | ||||||
|         this->timerChainCtrl->start(); |  | ||||||
|         break; |  | ||||||
|     case SETUP_STEP::SETUP_AUTOREQEUST: |  | ||||||
|         qCritical() << "CArun: SETUP_STEP::SETUP_AUTOREQEUST"; |  | ||||||
|  |  | ||||||
|         this->HWaccess->dc_autoRequest(1); |  | ||||||
|         this->setupStep = SETUP_STEP::CHECK_VALID_DATA; |  | ||||||
|         this->timerChainCtrl->start(); |  | ||||||
|         break; |  | ||||||
|     case SETUP_STEP::CHECK_VALID_DATA: |  | ||||||
|         qCritical() << "CArun: SETUP_STEP::CHECK_VALID_DATA"; |  | ||||||
|         if (this->HWaccess->sys_areDCdataValid()) { |  | ||||||
|             qCritical() << "CArun: DC is connected"; |  | ||||||
|             // do not start timer again |  | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             qCritical() << "CArun: auto request is not running, retry..."; |  | ||||||
|             this->setupStep = SETUP_STEP::INIT; |  | ||||||
|             this->timerChainCtrl->start(); |  | ||||||
|         } |  | ||||||
|         break; |  | ||||||
|     default: |  | ||||||
|         qCritical() << "CArun: invalid setup step"; |  | ||||||
|         break; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1,58 +0,0 @@ | |||||||
| #ifndef CARUN_H |  | ||||||
| #define CARUN_H |  | ||||||
|  |  | ||||||
| #include <QObject> |  | ||||||
| #include <QTimer> |  | ||||||
| #include <QDebug> |  | ||||||
| #include <QDateTime> |  | ||||||
|  |  | ||||||
| #include <QPluginLoader> |  | ||||||
| #include <QDir> |  | ||||||
| #include "plugin.h" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| enum class SETUP_STEP { |  | ||||||
|     INIT, |  | ||||||
|     OPEN_SERIAL_PORT, |  | ||||||
|     TEST_OPEN_PORT, |  | ||||||
|     TEST_RESPONSE_REQUEST, |  | ||||||
|     TEST_RESPONSE_CHECK, |  | ||||||
|     SETUP_AUTOREQEUST, |  | ||||||
|     CHECK_VALID_DATA |  | ||||||
| }; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class CCWakelineAbstraction; |  | ||||||
|  |  | ||||||
| class CArun : public QObject |  | ||||||
| { |  | ||||||
|     Q_OBJECT |  | ||||||
|  |  | ||||||
| public: |  | ||||||
|     explicit CArun(QObject *parent = nullptr); |  | ||||||
|  |  | ||||||
|     QTimer  *timerChainCtrl; |  | ||||||
|  |  | ||||||
|     char loadPlugIn(char lade1_entlade2); |  | ||||||
|  |  | ||||||
|     QDir plugInDir; |  | ||||||
|  |  | ||||||
| private: |  | ||||||
|  |  | ||||||
|     hwinf *HWaccess=nullptr;        // global pointer to plugin-class |  | ||||||
|  |  | ||||||
|     SETUP_STEP setupStep; |  | ||||||
|  |  | ||||||
|     void openSerialPort(); |  | ||||||
|  |  | ||||||
|     CCWakelineAbstraction* ccWakelineAbstraction; |  | ||||||
|  |  | ||||||
| signals: |  | ||||||
|  |  | ||||||
|  |  | ||||||
| private slots: |  | ||||||
|     void chainControl(); |  | ||||||
|  |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| #endif // CARUN_H |  | ||||||
| @@ -1,51 +0,0 @@ | |||||||
| #include <QFileSystemWatcher> |  | ||||||
| #include <QFile> |  | ||||||
|  |  | ||||||
| #include <QDebug> |  | ||||||
|  |  | ||||||
| #include "CCWakelineAbstraction.h" |  | ||||||
| #include "plugin.h" |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * this is based on a solution from: |  | ||||||
|  * https://embeddeduse.com/2018/09/18/monitoring-sys-files-qfilesystemwatcher/ |  | ||||||
|  * |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| CCWakelineAbstraction::CCWakelineAbstraction(hwinf *dc, QObject *parent) |  | ||||||
|     : QObject(parent) |  | ||||||
|     , dc(dc) |  | ||||||
| { |  | ||||||
|     auto ccWakeMonitor = new QFileSystemWatcher(this); |  | ||||||
|  |  | ||||||
|     ccWakeMonitor->addPath("/sys/class/leds/wakeupctrl_cc/brightness"); |  | ||||||
|     connect(ccWakeMonitor, &QFileSystemWatcher::fileChanged, |  | ||||||
|                 this, &CCWakelineAbstraction::ccWakeChanged); |  | ||||||
|  |  | ||||||
|     qCritical() << "... init CCWakelineAbstraction"; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void CCWakelineAbstraction::ccWakeChanged(const QString &path) |  | ||||||
| { |  | ||||||
|     QFile ccWakeFile(path); |  | ||||||
|      if (!ccWakeFile.open(QIODevice::ReadOnly)) { |  | ||||||
|          qWarning() << "ERROR: Could not open ccWakeFile file."; |  | ||||||
|          return; |  | ||||||
|      } |  | ||||||
|      auto ccWake = ccWakeFile.readAll(); |  | ||||||
|      if (!ccWake.isEmpty()) { |  | ||||||
|          int state = ccWake.at(0); |  | ||||||
|          //qCritical() << "INFO: ccWake = " << state; |  | ||||||
|          switch (state) { |  | ||||||
|          case 0x30:  // '1' |  | ||||||
|              qCritical() << "INFO: ccWake -> sleep"; |  | ||||||
|              this->dc->credit_switchWake(true); // switch 'sleep' |  | ||||||
|              break; |  | ||||||
|          case 0x31:  // '0' |  | ||||||
|              qCritical() << "INFO: ccWake -> wake"; |  | ||||||
|              this->dc->credit_switchWake(false); // switch 'wake' |  | ||||||
|              break; |  | ||||||
|          } |  | ||||||
|      } |  | ||||||
| } |  | ||||||
| @@ -1,25 +0,0 @@ | |||||||
| #ifndef CCWAKELINEABSTRACTION_H |  | ||||||
| #define CCWAKELINEABSTRACTION_H |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <QObject> |  | ||||||
|  |  | ||||||
| class hwinf; |  | ||||||
| class QFileSystemWatcher; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class CCWakelineAbstraction : public QObject |  | ||||||
| { |  | ||||||
|     Q_OBJECT |  | ||||||
|  |  | ||||||
| public: |  | ||||||
|     CCWakelineAbstraction(hwinf *dc, QObject *parent = nullptr); |  | ||||||
|  |  | ||||||
| private: |  | ||||||
|     hwinf *dc; |  | ||||||
|     QFileSystemWatcher *ccWakeMonitor; |  | ||||||
|  |  | ||||||
|     void ccWakeChanged(const QString &path); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| #endif // CCWAKELINEABSTRACTION_H |  | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| QT       += core | QT       += core gui | ||||||
| QT      += serialport | QT      +=widgets serialport | ||||||
| QT      +=network | QT      +=network | ||||||
|     # for TCP-IP |     # for TCP-IP | ||||||
|  |  | ||||||
| @@ -11,6 +11,8 @@ VERSION = "1.0.0" | |||||||
| DESTDIR=$${_PRO_FILE_PWD_}/../build | DESTDIR=$${_PRO_FILE_PWD_}/../build | ||||||
|  |  | ||||||
|  |  | ||||||
|  | greaterThan(QT_MAJOR_VERSION, 4): QT += widgets | ||||||
|  |  | ||||||
| CONFIG += c++11 | CONFIG += c++11 | ||||||
| CONFIG += PTU5 | CONFIG += PTU5 | ||||||
|  |  | ||||||
| @@ -23,33 +25,33 @@ INCLUDEPATH += ../include | |||||||
| win32 { | win32 { | ||||||
|     BUILD_DATE=$$system("date /t") |     BUILD_DATE=$$system("date /t") | ||||||
|     BUILD_TIME=$$system("time /t") |     BUILD_TIME=$$system("time /t") | ||||||
|     GIT_COMMIT="" |  | ||||||
|     EXTENDED_VERSION="" |  | ||||||
| } else { | } else { | ||||||
|     BUILD_DATE=$$system("date +%d-%m-%y") |     BUILD_DATE=$$system("date +%d-%m-%y") | ||||||
|     BUILD_TIME=$$system("date +%H:%M:%S") |     BUILD_TIME=$$system("date +%H:%M:%S") | ||||||
|  |  | ||||||
|     GIT_COMMIT=$$system("git log -1 --format=oneline | cut -d' ' -f1") |  | ||||||
|     EXTENDED_VERSION="$${VERSION}-$${GIT_COMMIT}" |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | GIT_COMMIT=$$system("git log -1 --format=oneline | cut -d' ' -f1") | ||||||
|  |  | ||||||
|  | EXTENDED_VERSION="$${VERSION}-$${GIT_COMMIT}" | ||||||
|  |  | ||||||
| DEFINES+=APP_VERSION=\\\"$$VERSION\\\" | DEFINES+=APP_VERSION=\\\"$$VERSION\\\" | ||||||
| DEFINES+=APP_BUILD_DATE=\\\"$$BUILD_DATE\\\" | DEFINES+=APP_BUILD_DATE=\\\"$$BUILD_DATE\\\" | ||||||
| DEFINES+=APP_BUILD_TIME=\\\"$$BUILD_TIME\\\" | DEFINES+=APP_BUILD_TIME=\\\"$$BUILD_TIME\\\" | ||||||
| DEFINES+=APP_EXTENDED_VERSION=\\\"$$EXTENDED_VERSION\\\" | DEFINES+=APP_EXTENDED_VERSION=\\\"$$EXTENDED_VERSION\\\" | ||||||
|  |  | ||||||
| SOURCES += \ | SOURCES += \ | ||||||
|     CArun.cpp \ |  | ||||||
|     CCWakelineAbstraction.cpp \ |  | ||||||
|     main.cpp \ |     main.cpp \ | ||||||
|  |     mainwindow.cpp \ | ||||||
|     tslib.cpp \ |     tslib.cpp \ | ||||||
|  |     win01_com.cpp \ | ||||||
|     datei.cpp |     datei.cpp | ||||||
|  |  | ||||||
| HEADERS += \ | HEADERS += \ | ||||||
|     CArun.h \ |  | ||||||
|     CCWakelineAbstraction.h \ |  | ||||||
|     guidefs.h \ |     guidefs.h \ | ||||||
|  |     mainwindow.h \ | ||||||
|  |     stepList.h \ | ||||||
|     tslib.h \ |     tslib.h \ | ||||||
|     versionHistory.txt \ |     versionHistory.txt \ | ||||||
|  |     win01_com.h \ | ||||||
|     datei.h \ |     datei.h \ | ||||||
|     plugin.h |     plugin.h | ||||||
|   | |||||||
| @@ -1,14 +1,15 @@ | |||||||
| #include "CArun.h" | #include "mainwindow.h" | ||||||
| //#include "message_handler.h" | //#include "message_handler.h" | ||||||
| #include <QCoreApplication> | #include <QApplication> | ||||||
|  |  | ||||||
|  | int thisisglobal; | ||||||
|  |  | ||||||
| int main(int argc, char *argv[]) | int main(int argc, char *argv[]) | ||||||
| { | { | ||||||
|     QCoreApplication myapp(argc, argv); |     int ret; | ||||||
|  |     QApplication myapp(argc, argv); | ||||||
|     QCoreApplication::setOrganizationName("ATB"); |     QApplication::setApplicationName("CArunGui"); | ||||||
|     QCoreApplication::setApplicationName("CArun"); |     QApplication::setApplicationVersion(APP_VERSION); | ||||||
|     QCoreApplication::setApplicationVersion(APP_VERSION); |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|     if (!messageHandlerInstalled()) { // change internal qt-QDebug-handling |     if (!messageHandlerInstalled()) { // change internal qt-QDebug-handling | ||||||
| @@ -17,9 +18,16 @@ int main(int argc, char *argv[]) | |||||||
|         //setDebugLevel(QtMsgType::QtDebugMsg); |         //setDebugLevel(QtMsgType::QtDebugMsg); | ||||||
|     } |     } | ||||||
| */ | */ | ||||||
|     CArun carun; |     MainWindow myMainWin; | ||||||
|  |     QSize myMainSize={800, 480};    // breite, höhe, PTU: 800x440 | ||||||
|  |     myMainWin.setMinimumSize(myMainSize); | ||||||
|  |     myMainWin.setMaximumSize(myMainSize); | ||||||
|  |     myMainWin.setWindowTitle("CArun_V4.2 run cash agent master lib"); | ||||||
|  |     //myMainWin.show(); | ||||||
|  |  | ||||||
|     return myapp.exec(); |     ret=myapp.exec(); | ||||||
|  |  | ||||||
|  |     return ret; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										439
									
								
								dCArun/mainwindow.cpp
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										439
									
								
								dCArun/mainwindow.cpp
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,439 @@ | |||||||
|  | #include "mainwindow.h" | ||||||
|  |  | ||||||
|  | char MainWindow::loadPlugIn(char lade1_entlade2) | ||||||
|  | { | ||||||
|  |     plugInDir.cd("plugins"); | ||||||
|  |     QPluginLoader *pluginLoader = new QPluginLoader(); | ||||||
|  |  | ||||||
|  | // select system: | ||||||
|  |     //pluginLoader->setFileName("../MasterPlug/libCAmaster.so");   // for suse | ||||||
|  |     //pluginLoader->setFileName("../SlavePlug/libCAslave.so");  // for ptu5 | ||||||
|  |     //pluginLoader->setFileName("../../MasterPlug/CAmaster.dll"); // for windows | ||||||
|  |     //pluginLoader->setFileName("CAmaster.dll"); // for windows | ||||||
|  |     pluginLoader->setFileName("/usr/lib/libCAmaster.so"); // for ptu5 | ||||||
|  |  | ||||||
|  |     if (lade1_entlade2==2) | ||||||
|  |     { | ||||||
|  |         pluginLoader->unload(); | ||||||
|  |         return 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (!pluginLoader->load()) | ||||||
|  |     { | ||||||
|  |         qDebug()<<"cannot load plugin"; | ||||||
|  |     } else | ||||||
|  |         qDebug() <<"loaded plugin: " << pluginLoader->fileName(); | ||||||
|  |  | ||||||
|  |     if (!pluginLoader->isLoaded()) | ||||||
|  |     { | ||||||
|  |         qDebug()<<pluginLoader->errorString(); | ||||||
|  |         return 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     QObject *plugin = pluginLoader->instance(); | ||||||
|  |     if ( plugin == nullptr) | ||||||
|  |     { | ||||||
|  |         // make instance of the root component (which can hold more then one clases) | ||||||
|  |         // also loads the lib if not yet done | ||||||
|  |         qDebug()<<"cannot start instance"; | ||||||
|  |         return 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     //int rr=hwapi->giveVal(2);                 funktioniert :)) | ||||||
|  |     //qDebug()<<"got value from plugin"<<rr;    funktioniert :)) | ||||||
|  |     // aber besser globaler pointer: | ||||||
|  |     // im h-file | ||||||
|  |     // hwinf *hwapi=nullptr;     // pointer to plugin-class | ||||||
|  |  | ||||||
|  |     HWaccess= qobject_cast<hwinf *>(plugin); | ||||||
|  |     // make instance to class "hwinf" in dll_HWapi.h over "interfaces.h" | ||||||
|  |  | ||||||
|  |     qDebug()<<"loadPlugIn, HWAccess: " << HWaccess; | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #define         WINCTRMIN      0 | ||||||
|  |     // 0 is always the home screen | ||||||
|  |  | ||||||
|  | #define         WINCTRMAX      30 | ||||||
|  |     // number of needed application screens, up to 255 | ||||||
|  |     // All screens must be defined below in mainwindow-class first before increasing the nr | ||||||
|  |     // numbers must be consecutively from 0 always, 0 is the home screen always | ||||||
|  |  | ||||||
|  | #define        FORMWIDTH        725 | ||||||
|  | //#define        FORMWIDTH        690 | ||||||
|  |     // this width is the same for ALL windows | ||||||
|  |  | ||||||
|  | #define        FORMHEIGHT       440 | ||||||
|  | // this height is the same for ALL windows | ||||||
|  |  | ||||||
|  | #define         NAVIBUTTONHEIGHT        70 | ||||||
|  | #define         NAVIBUTTONWIDHT        50 | ||||||
|  |  | ||||||
|  | #define         HOMEPAGE_BACKGROUND_COLOR   "background-color: lightgrey" | ||||||
|  |  | ||||||
|  | #define         BUTTON_COLOR                "background-color: rgb(160,250,190)" | ||||||
|  |  | ||||||
|  | #define         ACTIVE_NAVI_COLOR                "background-color: rgb(160,250,190)" | ||||||
|  | #define         DISABL_NAVI_COLOR                "background-color: grey" | ||||||
|  |  | ||||||
|  | #define         APPPAGE_BACKGROUND_COLOR   "background-color: lightgrey" | ||||||
|  |  | ||||||
|  | #define         UPDATE_PERIOD_MS        100 | ||||||
|  |     // period to call chain steps | ||||||
|  |  | ||||||
|  | #define         VENDINGTIMEOUT_MS       30000 | ||||||
|  |     // after this time without any operation the program returns to idle state | ||||||
|  |     // time in ms, that means 30.000 gives 30seconds | ||||||
|  |  | ||||||
|  | MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) | ||||||
|  | { | ||||||
|  |     loadPlugIn(1); | ||||||
|  |  | ||||||
|  |     // define all working moduls (besides gui) here, call ini and working in chainControl() (~Line 1000) | ||||||
|  |     //mifCard = new T_Mifare(HWaccess);   // ganz wichtig: HWaccess an sub-Konstruktor übergeben | ||||||
|  |                                         // sonst crash bei HW-Zugriff!!!! | ||||||
|  |     //diary = new T_lib_diary(); absturz!!!!!! | ||||||
|  |     //conf = new T_lib_config(HWaccess); | ||||||
|  |  | ||||||
|  |     timerChainCtrl = new QTimer(this); | ||||||
|  |     connect(timerChainCtrl, SIGNAL(timeout()), this, SLOT(chainControl())); | ||||||
|  |     timerChainCtrl->setSingleShot(0); | ||||||
|  |     timerChainCtrl->start(UPDATE_PERIOD_MS);     // 1000: call every 1000ms | ||||||
|  |  | ||||||
|  |     timerVendingTimeout = new QTimer(this); | ||||||
|  |     connect(timerVendingTimeout, SIGNAL(timeout()), this, SLOT(vendingTimeout())); | ||||||
|  |     timerVendingTimeout->setSingleShot(true); | ||||||
|  |     timerVendingTimeout->start(VENDINGTIMEOUT_MS);     // in ms | ||||||
|  |  | ||||||
|  |     // ########################################################################################## | ||||||
|  |     // für jedes anzuzeigende Fenster eine eigene Groupbox mit eigenem Grid anlegen: | ||||||
|  |  | ||||||
|  |     frame01 = new QGroupBox; | ||||||
|  |     frame01->setStyleSheet(APPPAGE_BACKGROUND_COLOR); | ||||||
|  |     frame01->setMinimumSize(FORMWIDTH,FORMHEIGHT); | ||||||
|  |     QVBoxLayout *smallLay01 = new QVBoxLayout; | ||||||
|  |     frame01->setLayout(smallLay01); | ||||||
|  |     // Fensterinhalt aus externer Klasse einfügen: | ||||||
|  |     myFenster01 = new T_winComPort(HWaccess);        // HWaccess damit auf das HW-Plugin zugegriffen werden kann, sonst crash | ||||||
|  |     smallLay01->addWidget(myFenster01); | ||||||
|  |  | ||||||
|  |     // ########################################################################################## | ||||||
|  |     // draw Mainwindow: | ||||||
|  |     bigGroupbox = new QGroupBox; | ||||||
|  |     bigGroupbox->setStyleSheet("background-color: grey"); | ||||||
|  |     bigGroupbox->setMinimumSize(800,480); | ||||||
|  | //    bigLayout = new QVBoxLayout;      // navi buttons on bottom side | ||||||
|  |     bigLayout = new QHBoxLayout;        // navi buttons right hand | ||||||
|  |  | ||||||
|  |     // ########################################################################################## | ||||||
|  |     // add all windows (but display only one) | ||||||
|  |     // display only one: then all windows are shown at the same place | ||||||
|  |     // display more then one: the windows are listed in vertical order | ||||||
|  |  | ||||||
|  |     bigLayout->addWidget(frame01); | ||||||
|  |  | ||||||
|  |     bigGroupbox->setLayout(bigLayout); | ||||||
|  |     switchScreen(1); | ||||||
|  |     //HideAllWindows(); | ||||||
|  |  | ||||||
|  |     // ########################################################################################## | ||||||
|  |     // Steuer Leiste | ||||||
|  |  | ||||||
|  |     //QHBoxLayout *ButtonLayout = new QHBoxLayout(); | ||||||
|  |     QVBoxLayout *ButtonLayout = new QVBoxLayout(); | ||||||
|  |     QFont myTabFont; | ||||||
|  |     myTabFont.setPixelSize(26); | ||||||
|  |  | ||||||
|  |     pBback = new QPushButton("<");        //b\na\nc\nk"); | ||||||
|  |     pBback->setFont(myTabFont); | ||||||
|  |     pBback->setStyleSheet(ACTIVE_NAVI_COLOR);     | ||||||
|  |     pBback->setMinimumHeight(NAVIBUTTONHEIGHT); | ||||||
|  |     pBback->setMaximumWidth(NAVIBUTTONWIDHT); | ||||||
|  |     connect(pBback, SIGNAL( clicked() ), myFenster01, SLOT( Nav_back())); | ||||||
|  |  | ||||||
|  |     myTabFont.setPixelSize(22); | ||||||
|  |     pBhome = new QPushButton("<<");      //h\no\nm\ne"); | ||||||
|  |     pBhome->setFont(myTabFont); | ||||||
|  |     pBhome->setStyleSheet(ACTIVE_NAVI_COLOR); | ||||||
|  |     pBhome->setMinimumHeight(NAVIBUTTONHEIGHT); | ||||||
|  |     pBhome->setMaximumWidth(NAVIBUTTONWIDHT); | ||||||
|  |     connect(pBhome, SIGNAL( clicked() ), myFenster01, SLOT( Nav_home())); | ||||||
|  |  | ||||||
|  |     myTabFont.setPixelSize(26); | ||||||
|  |     pBforward = new QPushButton(">"); //n\ne\nx\nt"); | ||||||
|  |     pBforward->setFont(myTabFont); | ||||||
|  |     pBforward->setStyleSheet(ACTIVE_NAVI_COLOR); | ||||||
|  |     pBforward->setMinimumHeight(NAVIBUTTONHEIGHT); | ||||||
|  |     pBforward->setMaximumWidth(NAVIBUTTONWIDHT); | ||||||
|  |     connect(pBforward, SIGNAL( clicked() ), myFenster01, SLOT( Nav_next())); | ||||||
|  |  | ||||||
|  |     QLabel *buttonSpace = new QLabel(" "); | ||||||
|  |     ButtonLayout->addWidget(pBback); | ||||||
|  |     ButtonLayout->addWidget(buttonSpace); | ||||||
|  |     //ButtonLayout->addWidget(buttonSpace); | ||||||
|  |     ButtonLayout->addWidget(pBhome); | ||||||
|  |     ButtonLayout->addWidget(buttonSpace); | ||||||
|  |     //ButtonLayout->addWidget(buttonSpace); | ||||||
|  |     ButtonLayout->addWidget(pBforward); | ||||||
|  |     QLabel *bottomSpace = new QLabel(" "); | ||||||
|  |     ButtonLayout->addWidget(bottomSpace); | ||||||
|  |  | ||||||
|  |     bigLayout->addLayout(ButtonLayout); | ||||||
|  |  | ||||||
|  |     setCentralWidget(bigGroupbox); | ||||||
|  |  | ||||||
|  |     // AUTOSTART serial transmission | ||||||
|  |     //HWaccess->dc_openSerial(5,"115200","ttyS0",1);    // my suse computer | ||||||
|  |     //HWaccess->dc_openSerial(1,"9600","COM5",1);    // my suse computer | ||||||
|  |     //HWaccess->dc_openSerial(5,"115200","ttymxc2",1);      // ptu5 | ||||||
|  |     //HWaccess->dc_autoRequest(true); | ||||||
|  |     //myFenster01->setButtons4autoStart(); | ||||||
|  |     //HWaccess->alarm_switchSiren(0);  // test | ||||||
|  |  | ||||||
|  |     enableNaviButtons(BACKBUTTON,true); | ||||||
|  |     enableNaviButtons(HOMEBUTTON,true); | ||||||
|  |     enableNaviButtons(FORWBUTTON,true);  | ||||||
|  |     this->chainIni(); | ||||||
|  |  | ||||||
|  |     //connect(myFenster02, SIGNAL(quitMyApp()), this, SLOT(close())); | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | MainWindow::~MainWindow() | ||||||
|  | { | ||||||
|  |     loadPlugIn(2); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void MainWindow::HideAllWindows() | ||||||
|  | { | ||||||
|  |     // vorsicht: Fenster muss oben definiert sein sonst Programmabsturz ohne Kommentar | ||||||
|  |  | ||||||
|  |     frame01->setEnabled(false); | ||||||
|  |     frame01->setVisible(false); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% | ||||||
|  | //  Call Windows | ||||||
|  | // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% | ||||||
|  |  | ||||||
|  | void MainWindow::switchScreen(uint16_t winNr)    // 0...30 | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     HideAllWindows(); | ||||||
|  |     //qDebug()<<"switch screen to " << winNr; | ||||||
|  |  | ||||||
|  |     switch (winNr) | ||||||
|  |     { | ||||||
|  |     case 1: | ||||||
|  |         frame01->setEnabled(true); | ||||||
|  |         frame01->setVisible(true); | ||||||
|  |         break; | ||||||
|  |     default: | ||||||
|  |         break; | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% | ||||||
|  | // Navigation buttons | ||||||
|  | // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% | ||||||
|  |  | ||||||
|  | void MainWindow::enableNaviButtons(uint8_t switchBitwise) | ||||||
|  | { | ||||||
|  |     // switchBitwise=0: no change | ||||||
|  |     // bit0,1: enable/disable button "next" | ||||||
|  |     // bit2,3: enable/disable button "home" | ||||||
|  |     // bit4,5: enable/disable button "back" | ||||||
|  |  | ||||||
|  |     if (switchBitwise &1) | ||||||
|  |     { | ||||||
|  |         pBforward->setStyleSheet(ACTIVE_NAVI_COLOR); | ||||||
|  |         //pBforward->setText("next"); | ||||||
|  |         pBforward->setEnabled(true); | ||||||
|  |     } else | ||||||
|  |     if (switchBitwise &2) | ||||||
|  |     { | ||||||
|  |         pBforward->setStyleSheet(DISABL_NAVI_COLOR); | ||||||
|  |         //pBforward->setText("    "); | ||||||
|  |         pBforward->setEnabled(false); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (switchBitwise &4) | ||||||
|  |     { | ||||||
|  |         pBhome->setStyleSheet(ACTIVE_NAVI_COLOR); | ||||||
|  |         //pBhome->setText("home"); | ||||||
|  |         pBhome->setEnabled(true); | ||||||
|  |     } else | ||||||
|  |     if (switchBitwise &8) | ||||||
|  |     { | ||||||
|  |         pBhome->setStyleSheet(DISABL_NAVI_COLOR); | ||||||
|  |         //pBhome->setText("    "); | ||||||
|  |         pBhome->setEnabled(false); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (switchBitwise &16) | ||||||
|  |     { | ||||||
|  |         pBback->setStyleSheet(ACTIVE_NAVI_COLOR); | ||||||
|  |         //pBback->setText("back"); | ||||||
|  |         pBback->setEnabled(true); | ||||||
|  |     } else | ||||||
|  |     if (switchBitwise &32) | ||||||
|  |     { | ||||||
|  |         pBback->setStyleSheet(DISABL_NAVI_COLOR); | ||||||
|  |         //pBback->setText("    "); | ||||||
|  |         pBback->setEnabled(false); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void MainWindow::enableNaviButtons(uint8_t buttonNr, bool enabled) | ||||||
|  | { | ||||||
|  |     if (buttonNr==1) | ||||||
|  |     { | ||||||
|  |         if (enabled) | ||||||
|  |         { | ||||||
|  |             pBback->setStyleSheet(ACTIVE_NAVI_COLOR); | ||||||
|  |             //pBback->setText("back"); | ||||||
|  |             pBback->setEnabled(true); | ||||||
|  |         } else | ||||||
|  |         { | ||||||
|  |             pBback->setStyleSheet(DISABL_NAVI_COLOR); | ||||||
|  |             //pBback->setText("    "); | ||||||
|  |             pBback->setEnabled(false); | ||||||
|  |         } | ||||||
|  |     } else | ||||||
|  |     if (buttonNr==2) | ||||||
|  |     { | ||||||
|  |         if (enabled) | ||||||
|  |         { | ||||||
|  |             pBhome->setStyleSheet(ACTIVE_NAVI_COLOR); | ||||||
|  |             //pBhome->setText("home"); | ||||||
|  |             pBhome->setEnabled(true); | ||||||
|  |         } else | ||||||
|  |         { | ||||||
|  |             pBhome->setStyleSheet(DISABL_NAVI_COLOR); | ||||||
|  |             //pBhome->setText("    "); | ||||||
|  |             pBhome->setEnabled(false); | ||||||
|  |         } | ||||||
|  |     } else | ||||||
|  |     if (buttonNr==3) | ||||||
|  |     { | ||||||
|  |         if (enabled) | ||||||
|  |         { | ||||||
|  |             pBforward->setStyleSheet(ACTIVE_NAVI_COLOR); | ||||||
|  |             //pBforward->setText("next"); | ||||||
|  |             pBforward->setEnabled(true); | ||||||
|  |         } else | ||||||
|  |         { | ||||||
|  |             pBforward->setStyleSheet(DISABL_NAVI_COLOR); | ||||||
|  |             //pBforward->setText("    "); | ||||||
|  |             pBforward->setEnabled(false); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% | ||||||
|  | // control work flow by Finite state machine | ||||||
|  | // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% | ||||||
|  |  | ||||||
|  | static uint16_t chainCurrentStep, chainNextStep; | ||||||
|  | static bool chain_stepIni; | ||||||
|  |  | ||||||
|  | void MainWindow::chainIni(void) | ||||||
|  | { | ||||||
|  |     // called once after power-up by constructor | ||||||
|  |     chainCurrentStep=WCS_STARTSCREEN;     // start screen | ||||||
|  |     chainNextStep=chainCurrentStep; | ||||||
|  |     switchScreen(chainCurrentStep); | ||||||
|  |     chain_stepIni=true; | ||||||
|  | //qDebug()<<"chain ini, call step "<<WCS_STARTUP << " " << chainCurrentStep; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void MainWindow::chainControl(void) | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     uint16_t nextScreen=0; | ||||||
|  |     uint8_t  useNavi=0; | ||||||
|  |     bool busy=false; | ||||||
|  |     // working step chain: | ||||||
|  |     if (chainCurrentStep != chainNextStep) | ||||||
|  |     { | ||||||
|  |         if (chainNextStep!=WCS_STARTSCREEN) | ||||||
|  |         { | ||||||
|  |             timerVendingTimeout->stop(); | ||||||
|  |             timerVendingTimeout->start(VENDINGTIMEOUT_MS); | ||||||
|  |         } | ||||||
|  |         //qDebug()<<"found new sreen"; | ||||||
|  |         chainCurrentStep=chainNextStep; | ||||||
|  |         switchScreen(chainCurrentStep); | ||||||
|  |         chain_stepIni=true; | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (chainCurrentStep==1) | ||||||
|  |     { | ||||||
|  |         if (chain_stepIni) | ||||||
|  |             busy=myFenster01->work_ini(&nextScreen, &useNavi); | ||||||
|  |         else | ||||||
|  |             busy=myFenster01->working(&nextScreen, &useNavi); | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     { | ||||||
|  |         // error undefined step | ||||||
|  |         qDebug()<<"error main chain control, wrong step ("<<chainCurrentStep<<") selected"; | ||||||
|  |          | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (chain_stepIni) | ||||||
|  |     { | ||||||
|  |         chain_stepIni=false; | ||||||
|  |         switchScreen(chainCurrentStep);       // the mainWindow frame has always the same number as the working step | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (nextScreen>0) | ||||||
|  |     { | ||||||
|  |         // call next chain step | ||||||
|  |         //qDebug()<<"chain control: new step selected: "<< nextScreen; | ||||||
|  |  | ||||||
|  |         chainNextStep=nextScreen; | ||||||
|  |     } | ||||||
|  |     if (useNavi>0) | ||||||
|  |     { | ||||||
|  |         //qDebug()<<"chain control: navi buttons "<< useNavi; | ||||||
|  |         enableNaviButtons(useNavi); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (busy>0) | ||||||
|  |     { | ||||||
|  |         // reset time-out | ||||||
|  |         timerVendingTimeout->start(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void MainWindow::vendingTimeout(void) | ||||||
|  | { | ||||||
|  |     // there was no user operation for 30s so return to start screen | ||||||
|  | //    uint16_t nextScreen=WCS_STARTSCREEN; | ||||||
|  | //    chainNextStep=nextScreen;             erstmal stilllegen, stört bei IBN | ||||||
|  |     //qDebug()<<"chain control: vending TO"; | ||||||
|  |     timerVendingTimeout->stop(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										72
									
								
								dCArun/mainwindow.h
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										72
									
								
								dCArun/mainwindow.h
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,72 @@ | |||||||
|  | #ifndef MAINWINDOW_H | ||||||
|  | #define MAINWINDOW_H | ||||||
|  |  | ||||||
|  | #include <QMainWindow> | ||||||
|  | #include <QTimer> | ||||||
|  | #include <QGroupBox> | ||||||
|  | #include <QStyle> | ||||||
|  | #include <QVBoxLayout> | ||||||
|  | #include <QHBoxLayout> | ||||||
|  | #include <QGridLayout> | ||||||
|  | #include <QLabel> | ||||||
|  | #include <QDebug> | ||||||
|  | #include <QPushButton> | ||||||
|  | #include <QDialog> | ||||||
|  | #include <QWidget> | ||||||
|  | #include <QApplication> | ||||||
|  | #include <QObject> | ||||||
|  | #include <QDateTime> | ||||||
|  | #include <QDate> | ||||||
|  | #include <QTime> | ||||||
|  |  | ||||||
|  | #include <QPluginLoader> | ||||||
|  | #include <QDir> | ||||||
|  | #include "plugin.h" | ||||||
|  | #include "stepList.h" | ||||||
|  | //#include "stepList.h" // define all working chain steps here | ||||||
|  | #include "win01_com.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class MainWindow : public QMainWindow | ||||||
|  | { | ||||||
|  |     Q_OBJECT | ||||||
|  |  | ||||||
|  |     QPushButton *pBback; | ||||||
|  |     QPushButton *pBhome; | ||||||
|  |     QPushButton *pBforward; | ||||||
|  |     QGroupBox   *bigGroupbox; | ||||||
|  |     QHBoxLayout *bigLayout; | ||||||
|  |     QTimer      *timerChainCtrl; | ||||||
|  |     QTimer      *timerVendingTimeout; | ||||||
|  |  | ||||||
|  |     QGroupBox   *frame01; | ||||||
|  |     T_winComPort    *myFenster01; | ||||||
|  |  | ||||||
|  |     void HideAllWindows(); | ||||||
|  |     void switchScreen(uint16_t winNr); | ||||||
|  |     char loadPlugIn(char lade1_entlade2); | ||||||
|  |     QDir plugInDir; | ||||||
|  |     void chainIni(void); | ||||||
|  |  | ||||||
|  | public: | ||||||
|  |     hwinf *HWaccess=nullptr;        // global pointer to plugin-class | ||||||
|  |  | ||||||
|  |     MainWindow(QWidget *parent = nullptr); | ||||||
|  |     ~MainWindow(); | ||||||
|  |  | ||||||
|  | #define BACKBUTTON  1 | ||||||
|  | #define HOMEBUTTON  2 | ||||||
|  | #define FORWBUTTON  3 | ||||||
|  |     void enableNaviButtons(uint8_t buttonNr, bool enabled); | ||||||
|  |     void enableNaviButtons(uint8_t switchBitwise); | ||||||
|  |  | ||||||
|  | private slots: | ||||||
|  |     void chainControl(); | ||||||
|  |     void vendingTimeout(); | ||||||
|  |  | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #endif // MAINWINDOW_H | ||||||
							
								
								
									
										210
									
								
								dCArun/stepList.h
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										210
									
								
								dCArun/stepList.h
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,210 @@ | |||||||
|  | #ifndef STEPLIST_H | ||||||
|  | #define STEPLIST_H | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // define all working chain steps | ||||||
|  | // every FSM-Step get's a frame in MainWindow with the same number and a self-designed GUI | ||||||
|  | // labels are used for switchScreen( label=nr ); | ||||||
|  | // numbers are important: e.g. number 3 calls frame3 and frame3 includes subClass "T_fenster03" | ||||||
|  | // so best solution: label = same name like class (in example: Fenster03). Label is fixed bound to number, never change! | ||||||
|  |  | ||||||
|  | // numbers are fixed assosiated with the function (e.g. ComPort), can't be changed. | ||||||
|  | // but screen order can be called in step chain randomly | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Windownumbers for certain function, never change | ||||||
|  | #define     PAGE_COMPORT            1 | ||||||
|  | #define     PAGE_SERVICEMAIN        2 | ||||||
|  | #define     PAGE_TIMEDATEVERSION    3 | ||||||
|  | #define     PAGE_MACHINESTATUS      4 | ||||||
|  | #define     PAGE_CHECKDOORS         5 | ||||||
|  | #define     PAGE_PRINTER            6 | ||||||
|  | #define     PAGE_COINMECHANIC       7 | ||||||
|  | #define     PAGE_MIFARE             8 | ||||||
|  | #define     PAGE_MODEM              9 | ||||||
|  | #define     PAGE_COINPAYMENT        10 | ||||||
|  | #define     PAGE_VAULTRECORD        11 | ||||||
|  | #define     PAGE_BOOTLOADER         12 | ||||||
|  | #define     PAGE_PROG_JSON          13 | ||||||
|  | #define     PAGE_COINCHANGER        14 | ||||||
|  | #define     PAGE_BILLREADER         15 | ||||||
|  | #define     PAGE_NEXT16             16 | ||||||
|  | #define     PAGE_NEXT17             17 | ||||||
|  | #define     PAGE_NEXT18             18 | ||||||
|  | #define     PAGE_NEXT19             19 | ||||||
|  | #define     PAGE_NEXT20             20 | ||||||
|  |  | ||||||
|  | //          fix:                customize: | ||||||
|  | #define     WCS_STARTSCREEN     PAGE_COMPORT | ||||||
|  |  | ||||||
|  | // PAGE_COMPORT: | ||||||
|  | #define     WCS_WIN01BAK    PAGE_COMPORT | ||||||
|  | #define     WCS_WIN01MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN01FWD    PAGE_SERVICEMAIN | ||||||
|  |  | ||||||
|  | // PAGE_SERVICEMAIN: | ||||||
|  | #define     WCS_WIN02BAK    PAGE_COMPORT | ||||||
|  | #define     WCS_WIN02MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN02FWD    PAGE_TIMEDATEVERSION | ||||||
|  |  | ||||||
|  | // PAGE_TIMEDATEVERSION: | ||||||
|  | #define     WCS_WIN03BAK    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN03MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN03FWD    PAGE_MACHINESTATUS | ||||||
|  |  | ||||||
|  | // PAGE_MACHINESTATUS: | ||||||
|  | #define     WCS_WIN04BAK    PAGE_TIMEDATEVERSION | ||||||
|  | #define     WCS_WIN04MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN04FWD    PAGE_CHECKDOORS | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // PAGE_CHECKDOORS: | ||||||
|  | #define     WCS_WIN05BAK    PAGE_MACHINESTATUS | ||||||
|  | #define     WCS_WIN05MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN05FWD    PAGE_COINMECHANIC | ||||||
|  |  | ||||||
|  | // PAGE_COINMECHANIC: | ||||||
|  | #define     WCS_WIN07BAK    PAGE_CHECKDOORS | ||||||
|  | #define     WCS_WIN07MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN07FWD    PAGE_COINPAYMENT | ||||||
|  |  | ||||||
|  | // PAGE_COINPAYMENT: | ||||||
|  | #define     WCS_WIN10BAK    PAGE_COINMECHANIC | ||||||
|  | #define     WCS_WIN10MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN10FWD    PAGE_COINCHANGER | ||||||
|  |  | ||||||
|  | // PAGE_COINCHANGER: | ||||||
|  | #define     WCS_WIN14BAK    PAGE_COINPAYMENT | ||||||
|  | #define     WCS_WIN14MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN14FWD    PAGE_BILLREADER | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // PAGE_BILLREADER: | ||||||
|  | #define     WCS_WIN15BAK    PAGE_COINCHANGER | ||||||
|  | #define     WCS_WIN15MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN15FWD    PAGE_PRINTER | ||||||
|  |  | ||||||
|  | // PAGE_PRINTER: | ||||||
|  | #define     WCS_WIN06BAK    PAGE_BILLREADER | ||||||
|  | #define     WCS_WIN06MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN06FWD    PAGE_MIFARE | ||||||
|  |  | ||||||
|  | // PAGE_MIFARE: | ||||||
|  | #define     WCS_WIN08BAK    PAGE_PRINTER | ||||||
|  | #define     WCS_WIN08MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN08FWD    PAGE_MODEM | ||||||
|  |  | ||||||
|  | // PAGE_MODEM: | ||||||
|  | #define     WCS_WIN09BAK    PAGE_MIFARE | ||||||
|  | #define     WCS_WIN09MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN09FWD    PAGE_VAULTRECORD | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // PAGE_VAULTRECORD: | ||||||
|  | #define     WCS_WIN11BAK    PAGE_MODEM | ||||||
|  | #define     WCS_WIN11MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN11FWD    PAGE_PROG_JSON | ||||||
|  |  | ||||||
|  | // PAGE_PROG_JSON: | ||||||
|  | #define     WCS_WIN13BAK    PAGE_VAULTRECORD | ||||||
|  | #define     WCS_WIN13MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN13FWD    PAGE_BOOTLOADER | ||||||
|  |  | ||||||
|  | // PAGE_BOOTLOADER: | ||||||
|  | #define     WCS_WIN12BAK    PAGE_PROG_JSON | ||||||
|  | #define     WCS_WIN12MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN12FWD    PAGE_NEXT16 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // PAGE_NEXT16 | ||||||
|  | #define     WCS_WIN16BAK    PAGE_BOOTLOADER | ||||||
|  | #define     WCS_WIN16MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN16FWD    PAGE_NEXT17 | ||||||
|  |  | ||||||
|  | // PAGE_NEXT17 | ||||||
|  | #define     WCS_WIN17BAK    PAGE_NEXT16 | ||||||
|  | #define     WCS_WIN17MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN17FWD    PAGE_NEXT18 | ||||||
|  |  | ||||||
|  | // PAGE_NEXT18 | ||||||
|  | #define     WCS_WIN18BAK    PAGE_NEXT17 | ||||||
|  | #define     WCS_WIN18MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN18FWD    PAGE_NEXT19 | ||||||
|  |  | ||||||
|  | // PAGE_NEXT19 | ||||||
|  | #define     WCS_WIN19BAK    PAGE_NEXT18 | ||||||
|  | #define     WCS_WIN19MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN19FWD    PAGE_NEXT20 | ||||||
|  |  | ||||||
|  | // PAGE_NEXT20 | ||||||
|  | #define     WCS_WIN20BAK    PAGE_NEXT19 | ||||||
|  | #define     WCS_WIN20MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN20FWD    PAGE_SERVICEMAIN | ||||||
|  |  | ||||||
|  | // just for Template | ||||||
|  | #define     WCS_WIN99BAK    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN99MID    PAGE_SERVICEMAIN | ||||||
|  | #define     WCS_WIN99FWD    PAGE_SERVICEMAIN | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #define     WIN02_LABEL_SHORT01     " Status" | ||||||
|  | #define     WCS_WIN02SHORT01    PAGE_MACHINESTATUS | ||||||
|  | #define     WIN02_LABEL_SHORT02     " Doors " | ||||||
|  | #define     WCS_WIN02SHORT02    PAGE_CHECKDOORS | ||||||
|  | #define     WIN02_LABEL_SHORT03     "Coin mech" | ||||||
|  | #define     WCS_WIN02SHORT03    PAGE_COINMECHANIC | ||||||
|  | #define     WIN02_LABEL_SHORT04     "Payment" | ||||||
|  | #define     WCS_WIN02SHORT04    PAGE_COINPAYMENT | ||||||
|  |  | ||||||
|  | #define     WIN02_LABEL_SHORT05     "Changer" | ||||||
|  | #define     WCS_WIN02SHORT05    PAGE_COINCHANGER | ||||||
|  | #define     WIN02_LABEL_SHORT06     " Bill  " | ||||||
|  | #define     WCS_WIN02SHORT06    PAGE_BILLREADER | ||||||
|  | #define     WIN02_LABEL_SHORT07     "Printer" | ||||||
|  | #define     WCS_WIN02SHORT07    PAGE_PRINTER | ||||||
|  |  | ||||||
|  | #define     WIN02_LABEL_SHORT08     "Program" | ||||||
|  | #define     WCS_WIN02SHORT08    PAGE_VAULTRECORD | ||||||
|  | #define     WIN02_LABEL_SHORT09     "      " | ||||||
|  | #define     WCS_WIN02SHORT09    PAGE_SERVICEMAIN | ||||||
|  | #define     WIN02_LABEL_SHORT10     "      " | ||||||
|  | #define     WCS_WIN02SHORT10    PAGE_SERVICEMAIN | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // set needed navigation buttons, use | to combine more then one: | ||||||
|  | #define     SWITCH_NEXT_ON      1 | ||||||
|  | #define     SWITCH_NEXT_OFF     2 | ||||||
|  | #define     SWITCH_HOME_ON      4 | ||||||
|  | #define     SWITCH_HOME_OFF     8 | ||||||
|  | #define     SWITCH_BACK_ON      16 | ||||||
|  | #define     SWITCH_BACK_OFF     32 | ||||||
|  | // example: *useNavi=SWITCH_BACK_ON;   // change only this one, or set all: | ||||||
|  | //          *useNavi=SWITCH_BACK_OFF | SWITCH_HOME_OFF | SWITCH_NEXT_ON; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // some defines for Widget design: | ||||||
|  |  | ||||||
|  | #define     TS_VALUEBOX_FRAMESTYLE      0x0032 | ||||||
|  | #define     TS_VALUEBOX_LINEWIDTH       3 | ||||||
|  |  | ||||||
|  | //genDatPort->setFrameStyle(QFrame::Panel |  QFrame::Sunken ); funktioniert aber gibt unverständliche Warnung | ||||||
|  | // QFrame::Panel = 0x0002    QFrame::Sunken=0x0030 | ||||||
|  | //genDatPort->setFrameStyle(0x0032);      //  funktioniert und gibt keine Warnung | ||||||
|  | //genDatPort->setFrameStyle(TS_VALUEBOX_FRAMESTYLE);      //  funktioniert und gibt keine Warnung | ||||||
|  |  | ||||||
|  | #define     TS_LED_FRAMESTYLE      0x0031 | ||||||
|  | // QFrame::Box | QFrame::Sunken | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #endif // STEPLIST_H | ||||||
							
								
								
									
										578
									
								
								dCArun/win01_com.cpp
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										578
									
								
								dCArun/win01_com.cpp
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,578 @@ | |||||||
|  | #include "win01_com.h" | ||||||
|  | #include "stepList.h"       // define all working chain steps here | ||||||
|  | #include "datei.h" | ||||||
|  | //#include "globVars.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // %%%%%%%%%%%%%%%%%%%%   TabComPort | ||||||
|  |  | ||||||
|  | Console::Console(QWidget *parent) : QPlainTextEdit(parent) | ||||||
|  | { | ||||||
|  |     document()->setMaximumBlockCount(100); | ||||||
|  |     QPalette p = palette(); | ||||||
|  |     p.setColor(QPalette::Base, Qt::black);  //geht nicht weil untergrund schon farbig | ||||||
|  |     p.setColor(QPalette::Text, Qt::blue); | ||||||
|  |     setPalette(p); | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void Console::putData(const QByteArray &data) | ||||||
|  | { | ||||||
|  |     insertPlainText(data); | ||||||
|  |     insertPlainText("\n"); | ||||||
|  |     QScrollBar *bar = verticalScrollBar(); | ||||||
|  |     bar->setValue(bar->maximum()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void Console::putText(QString text) | ||||||
|  | { | ||||||
|  |     insertPlainText(text); | ||||||
|  |     insertPlainText("\n"); | ||||||
|  |     QScrollBar *bar = verticalScrollBar(); | ||||||
|  |     bar->setValue(bar->maximum()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::subPortInfo() | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     // Port Info Anzeige Feld, 2. Zeile links | ||||||
|  |     QStringList myStringList; | ||||||
|  |     QStringList comboPortList; | ||||||
|  |  | ||||||
|  |     const auto infos = QSerialPortInfo::availablePorts(); | ||||||
|  |     for (const QSerialPortInfo &info : infos) | ||||||
|  |     { | ||||||
|  |         myStringList.append(QObject::tr(" \n Port: ") + info.portName() ); | ||||||
|  |         myStringList.append(QObject::tr("Location: ") + info.systemLocation()); // + "\n"); | ||||||
|  |         myStringList.append(QObject::tr("Description: ") + info.description() ); | ||||||
|  |         myStringList.append(QObject::tr("Manufacturer: ") + info.manufacturer()); | ||||||
|  |         myStringList.append(QObject::tr("Serial number: ") + info.serialNumber()); | ||||||
|  |         myStringList.append (QObject::tr("Vendor Id: ") + QString::number(info.vendorIdentifier(), 16)); | ||||||
|  |         myStringList.append(QObject::tr("Product Id: ") +QString::number(info.productIdentifier(), 16)); | ||||||
|  |         //myStringList.append(QObject::tr("Busy: ") + (info.isBusy() ? QObject::tr("Yes") : QObject::tr("No"))); | ||||||
|  |         comboPortList.append(info.portName());  // wenn Comport im System vorhanden dann in die Liste eintragen | ||||||
|  |     } | ||||||
|  |     QListWidget *myListWidget = new QListWidget; | ||||||
|  |     myListWidget->insertItems(0, myStringList); | ||||||
|  |     myListWidget->setMaximumWidth(250); | ||||||
|  |     myTabComLayout->addWidget(myListWidget,1,0); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     // ComboBox Comport Nr: | ||||||
|  |     CB_portSel = new QComboBox(); | ||||||
|  |     CB_portSel->addItems(comboPortList);       //  string Liste mit addItems (s am Schluss) ! | ||||||
|  |     CB_portSel->setMinimumHeight(30); | ||||||
|  |     CB_portSel->setMaximumWidth(150); | ||||||
|  |     QFont myCBfont; | ||||||
|  |     //myCBfont.setBold(true); | ||||||
|  |     myCBfont.setPixelSize(15); | ||||||
|  |     CB_portSel->setFont(myCBfont); | ||||||
|  |     CB_portSel->setCurrentIndex(2);     // default 3. Comport in der Liste = ttymxc2 in PTU5 | ||||||
|  |     myTabComLayout->addWidget(CB_portSel, 4,0); | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::callOpenSerial() | ||||||
|  | { | ||||||
|  |     // Taste Connect wurde gedrückt, eine Klasse/einen Slot aus einer übergeordneten Klasse: | ||||||
|  |     // openSerialPort(); | ||||||
|  |     // kann man nicht aufrufen. deshalb: speichere ComPort, Baudrate und Startbefehl global. | ||||||
|  |     // Von dort wird mit einem zyklischen Timer ausgelesen | ||||||
|  |  | ||||||
|  |     int br, ci; | ||||||
|  |     QString bs, cn; | ||||||
|  |     //br=CB_baudSel->currentIndex(); | ||||||
|  |     //bs=CB_baudSel->currentText(); | ||||||
|  |     br=5; | ||||||
|  |     bs="115200"; | ||||||
|  |     cn=CB_portSel->currentText(); | ||||||
|  |     ci=CB_portSel->currentIndex(); | ||||||
|  |  | ||||||
|  |     // aktuell: br=5  bs=115200 cn=0 (=Com5) | ||||||
|  |     //epi_setSerial(5,"115200","COM5",1); | ||||||
|  |     //  epi_setSerial(br, bs, cn, 1); | ||||||
|  |  | ||||||
|  |     // new: save values for next time | ||||||
|  |     QByteArray myBA, tmpBA; | ||||||
|  |     myBA.clear(); tmpBA.clear(); | ||||||
|  |     myBA.append('s');   // start sign, not used | ||||||
|  |     myBA.append(FILESEPERATOR); | ||||||
|  |     tmpBA.setNum(br,10); | ||||||
|  |     myBA.append(tmpBA); | ||||||
|  |     myBA.append(FILESEPERATOR);  | ||||||
|  |     myBA.append(bs.toLatin1()); | ||||||
|  |     myBA.append(FILESEPERATOR); | ||||||
|  |     myBA.append(cn.toLatin1()); | ||||||
|  |     myBA.append(FILESEPERATOR); | ||||||
|  |     tmpBA.clear(); | ||||||
|  |     tmpBA.setNum(ci,10); | ||||||
|  |     myBA.append(tmpBA); | ||||||
|  |     myBA.append(FILESEPERATOR); | ||||||
|  |  | ||||||
|  |     datei_clearFile(FILENAME_COMPORT); | ||||||
|  |     datei_writeToFile(FILENAME_COMPORT, myBA); | ||||||
|  |     qDebug() << "winComPort opening serial with: " << br << " " << bs << " " << cn; | ||||||
|  |     HWaccess->dc_openSerial(br, bs, cn, 1);// same function with hwapi | ||||||
|  |     // void dc_openSerial(int BaudNr, QString BaudStr, QString ComName, uint8_t connect) | ||||||
|  |             // BaudNr:  0:1200   1:9600   2:19200   3:38400   4:57600   5:115200 | ||||||
|  |             // BaudStr: for exapmle "19200" | ||||||
|  |             // ComName: for example "COM48" | ||||||
|  |             // connect: 0, 1 | ||||||
|  |  | ||||||
|  |     emit connectButtonPressed(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::callCloseSerial() | ||||||
|  | { | ||||||
|  |     HWaccess->dc_closeSerial(); | ||||||
|  |     // epi_closeSerial();   // same function without hwapi | ||||||
|  |     emit closeButtonPressed(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::callAutoSend() | ||||||
|  | { | ||||||
|  |     if (AutSendButton->isChecked()) | ||||||
|  |     { | ||||||
|  |         HWaccess->dc_autoRequest(1); | ||||||
|  |         emit autoSendButtonIsOn(); | ||||||
|  |     } else | ||||||
|  |     { | ||||||
|  |         HWaccess->dc_autoRequest(0); | ||||||
|  |  | ||||||
|  |         emit autoSendButtonIsOff(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::callRefresh(void) | ||||||
|  | { | ||||||
|  |     subPortInfo(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::callConnectToggle() | ||||||
|  | { | ||||||
|  |    if (connectButton->isChecked()) | ||||||
|  |     { | ||||||
|  |         //qDebug() << "down"; | ||||||
|  |  | ||||||
|  |         callOpenSerial(); | ||||||
|  |     } else | ||||||
|  |     { | ||||||
|  |         //qDebug() << "released"; | ||||||
|  |         callCloseSerial(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::getDcTestRS232() | ||||||
|  | { | ||||||
|  |     //qDebug() << "request test response..."; | ||||||
|  |    HWaccess->dc_requTestResponse(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void T_winComPort::newBaud(void) | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     qDebug() << "new baud selected..."; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::setButtons4autoStart() | ||||||
|  | { | ||||||
|  |     connectButton->setEnabled(true); | ||||||
|  |     connectButton->setDown(true); | ||||||
|  |     connectButton->setChecked(true); | ||||||
|  |  | ||||||
|  |     AutSendButton->setEnabled(true); | ||||||
|  |     AutSendButton->setDown(true); | ||||||
|  |     AutSendButton->setChecked(true); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | T_winComPort::T_winComPort(hwinf *HWaccess, QWidget *parent) : QWidget(parent) | ||||||
|  | { | ||||||
|  |     this->HWaccess = HWaccess; | ||||||
|  |  | ||||||
|  |     myTabComLayout = new QGridLayout; | ||||||
|  |     //QGridLayout *myGridLayout = new QGridLayout(); | ||||||
|  |  | ||||||
|  |     // Überschrift linke Spalte | ||||||
|  |     QLabel *portListLabel2 = new QLabel(tr("in System available Ports:")); | ||||||
|  |     myTabComLayout->addWidget(portListLabel2, 0,0); | ||||||
|  |  | ||||||
|  |     // Überschrift rechte Spalte | ||||||
|  |     QLabel *lab_headlineR = new QLabel(tr("Serial traffic:")); | ||||||
|  |     myTabComLayout->addWidget(lab_headlineR, 0, 1); | ||||||
|  |  | ||||||
|  |     subPortInfo(); | ||||||
|  |     // sende-empfangs-Rohdaten-Fenster, 2. Zeile rechts | ||||||
|  |     myDiagWindow = new Console(); | ||||||
|  |     myDiagWindow->setReadOnly(true); | ||||||
|  |     myDiagWindow->setEnabled(true); | ||||||
|  |     //myDiagWindow->setLocalEchoEnabled(p.localEchoEnabled); | ||||||
|  |     //myDiagWindow->setMinimumWidth(300); | ||||||
|  |     //myDiagWindow->putData("ongoing serial traffic: "); | ||||||
|  |     myTabComLayout->addWidget(myDiagWindow, 1,1); | ||||||
|  |  | ||||||
|  | // links: | ||||||
|  |     // refresh button: | ||||||
|  |     refreshButton = new QPushButton(tr("&refresh")); | ||||||
|  |     refreshButton->setCheckable(false);      // true = toggle button | ||||||
|  |     refreshButton->setAutoDefault(false);   // beim start aus | ||||||
|  |     //refreshButton->setMaximumWidth(90); | ||||||
|  |     myTabComLayout->addWidget(refreshButton, 2,0); | ||||||
|  |     //connect(refreshButton, &QAbstractButton::clicked, this, &T_fenster01::callRefresh); | ||||||
|  |     connect(refreshButton, SIGNAL(clicked()), this, SLOT(callRefresh())); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     QLabel *Label3 = new QLabel(tr("Port:")); | ||||||
|  |     myTabComLayout->addWidget(Label3, 3,0); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     QLabel *Label4 = new QLabel(tr("Baud:")); | ||||||
|  |     myTabComLayout->addWidget(Label4, 5,0); | ||||||
|  |  | ||||||
|  |     // ComboBox Baudrate: | ||||||
|  |     QFont my2CBfont; | ||||||
|  |     //my2CBfont.setBold(true); | ||||||
|  |     my2CBfont.setPixelSize(15); | ||||||
|  | /* | ||||||
|  |     CB_baudSel = new QComboBox(); | ||||||
|  |     CB_baudSel->addItem(tr("1200")); | ||||||
|  |     CB_baudSel->addItem(tr("9600")); | ||||||
|  |     CB_baudSel->addItem(tr("19200")); | ||||||
|  |     CB_baudSel->addItem(tr("38400")); | ||||||
|  |     CB_baudSel->addItem(tr("57600")); | ||||||
|  |     CB_baudSel->addItem(tr("115200")); | ||||||
|  |     CB_baudSel->setMinimumHeight(30); | ||||||
|  |     CB_baudSel->setMaximumWidth(150); | ||||||
|  |     CB_baudSel->setFont(my2CBfont); | ||||||
|  |     CB_baudSel->setCurrentIndex(5);     // default 115k baud | ||||||
|  |     //CB_baudSel->setCurrentIndex(1);     // default 9600 baud | ||||||
|  |     myTabComLayout->addWidget(CB_baudSel, 6,0); | ||||||
|  |     //connect(CB_baudSel, SIGNAL(currentIndexChanged(int)), this, SLOT(newBaud())); | ||||||
|  |     connect(CB_baudSel, SIGNAL(currentIndexChanged(int)), this, SLOT(newBaud())); | ||||||
|  | */ | ||||||
|  |     // Statuszeile COM Port  (serial Port) | ||||||
|  |     LabelComState = new QLabel(tr("not connected")); | ||||||
|  |     myTabComLayout->addWidget(LabelComState, 7,0); | ||||||
|  |  | ||||||
|  |     // Connect button: | ||||||
|  |     connectButton = new QPushButton(tr("&Connect")); | ||||||
|  |     connectButton->setCheckable(true);      // true = toggle button | ||||||
|  |     connectButton->setAutoDefault(true);   // beim start ein | ||||||
|  |     connectButton->setMaximumWidth(90); | ||||||
|  |     connectButton->setMinimumHeight(50); | ||||||
|  |     myTabComLayout->addWidget(connectButton, 8,0); | ||||||
|  |     //connect(connectButton, &QAbstractButton::clicked, this, &T_fenster01::callConnectToggle); | ||||||
|  |     connect(connectButton, SIGNAL(clicked()), this, SLOT(callConnectToggle())); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // rechts: | ||||||
|  |  | ||||||
|  |     // test serial line: | ||||||
|  |     TestButton = new QPushButton(tr("test Connection")); | ||||||
|  |     TestButton->setMaximumWidth(150); | ||||||
|  |     myTabComLayout->addWidget(TestButton,2,1); | ||||||
|  |     TestButton->setCheckable(false);      // true = toggle button | ||||||
|  |     TestButton->setAutoDefault(false);   // beim start aus | ||||||
|  | //    connect(TestButton, &QAbstractButton::clicked, this, &T_fenster01::getDcTestRS232); | ||||||
|  |     connect(TestButton, SIGNAL(clicked()), this, SLOT(getDcTestRS232())); | ||||||
|  |  | ||||||
|  |     // I Statuszeile Handshakes (serial Control)   flow.cpp | ||||||
|  |     // geht überhaupt was raus? kommt überhaupt was zurück? | ||||||
|  |     //LabelHandshakes = new QLabel(tr("control line")); | ||||||
|  |     LabelHandshakes = new QLabel("HS");       // not used | ||||||
|  |     myTabComLayout->addWidget(LabelHandshakes, 3,1); | ||||||
|  |  | ||||||
|  |     // II Statuszeile Auswertung der SlaveResponse (serial Frame, CRC usw)  (prot.cpp) | ||||||
|  |     LabelRecieveFrame = new QLabel(tr("slave receive")); | ||||||
|  |     myTabComLayout->addWidget(LabelRecieveFrame, 4,1); | ||||||
|  |  | ||||||
|  |     // III Anzeige der Slave-Results (Datif) | ||||||
|  |     LabelResults = new QLabel(tr("results line")); | ||||||
|  |     myTabComLayout->addWidget(LabelResults, 5,1); | ||||||
|  |  | ||||||
|  |     // IV Statuszeile Sende- und Empfangsdaten brauchbar? (Datif) | ||||||
|  |     LabelDataState = new QLabel(tr("datif line")); | ||||||
|  |     myTabComLayout->addWidget(LabelDataState, 6,1); | ||||||
|  |  | ||||||
|  |     // V | ||||||
|  |     LabelDatif = new QLabel(tr("datif line")); | ||||||
|  |     myTabComLayout->addWidget(LabelDatif, 7,1); | ||||||
|  |  | ||||||
|  |     // Autosend: | ||||||
|  |     AutSendButton = new QPushButton(tr("&Automatic reading"));       // &A --> also keycode Alt-A possible | ||||||
|  |     //AutSendButton->setMaximumWidth(90); | ||||||
|  |     myTabComLayout->addWidget(AutSendButton,8,1); | ||||||
|  |     AutSendButton->setCheckable(true);      // true = toggle button | ||||||
|  |     AutSendButton->setAutoDefault(true);   // beim start aus | ||||||
|  |     AutSendButton->setMinimumHeight(50); | ||||||
|  | //    connect(AutSendButton, &QAbstractButton::clicked, this, &T_fenster01::callAutoSend); | ||||||
|  |     connect(AutSendButton, SIGNAL(clicked()), this, SLOT(callAutoSend())); | ||||||
|  |  | ||||||
|  |     setLayout(myTabComLayout); | ||||||
|  |     myNextStep=0; | ||||||
|  |     myStep=0; | ||||||
|  |     callConnectToggle(); | ||||||
|  |     callAutoSend(); | ||||||
|  |  | ||||||
|  |     myTO = new QTimer(); | ||||||
|  |     myTO->setSingleShot(true); | ||||||
|  |     myTO->start(2000); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // not needed: | ||||||
|  | T_winComPort::~T_winComPort() | ||||||
|  | { | ||||||
|  |     close(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void T_winComPort::Nav_back(void) | ||||||
|  | { | ||||||
|  |     myNextStep=WCS_WIN01BAK; | ||||||
|  | } | ||||||
|  | void T_winComPort::Nav_home(void) | ||||||
|  | { | ||||||
|  |     myNextStep=WCS_WIN01MID; | ||||||
|  | } | ||||||
|  | void T_winComPort::Nav_next(void) | ||||||
|  | { | ||||||
|  |     myNextStep=WCS_WIN01FWD; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool T_winComPort::work_ini(uint16_t *nextScreen, uint8_t *useNavi) | ||||||
|  | { | ||||||
|  |     // one state of the vending/operating FSM | ||||||
|  |     // called ONE time after selecting this state (initialization) | ||||||
|  |     // useNavi=0: no change | ||||||
|  |     // bit0,1: enable/disable button "next" | ||||||
|  |     // bit2,3: enable/disable button "home" | ||||||
|  |     // bit4,5: enable/disable button "back" | ||||||
|  |  | ||||||
|  |     *nextScreen=0;   // needed  0=no change | ||||||
|  | //    *useNavi=SWITCH_BACK_OFF | SWITCH_HOME_OFF | SWITCH_NEXT_ON; | ||||||
|  |     *useNavi=SWITCH_BACK_OFF | SWITCH_HOME_OFF | SWITCH_NEXT_OFF;   // bei CArun alle aus | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool T_winComPort::working(uint16_t *nextScreen, uint8_t *useNavi) | ||||||
|  | { | ||||||
|  |     // one state of the vending/operating FSM | ||||||
|  |     // called cyclic until this state changes intentionally to another state | ||||||
|  |     // display informations for human operator, react on operators inputs or wait for payment media | ||||||
|  |  | ||||||
|  |     // useNavi=0: no change | ||||||
|  |     // bit0,1: enable/disable button "next" | ||||||
|  |     // bit2,3: enable/disable button "home" | ||||||
|  |     // bit4,5: enable/disable button "back" | ||||||
|  |  | ||||||
|  |     this->updateGui(); | ||||||
|  |     *nextScreen=0;   // 0=no change | ||||||
|  |     *useNavi=0; | ||||||
|  |  | ||||||
|  |     if (myStep==0) | ||||||
|  |     { | ||||||
|  |         // load and use last settings:  -------------------- | ||||||
|  |         QByteArray myBA; | ||||||
|  |         myBA=datei_readFromFile(FILENAME_COMPORT); | ||||||
|  |  | ||||||
|  |         //uint32_t len= datei_nrOfEntriesInFile(myBA); | ||||||
|  |         //uint64_t ulltmp=csv_getEntryAs2Ulong(myBA,0); | ||||||
|  |         //qDebug()<<"win_startup load long numer: "<<ulltmp; | ||||||
|  |  | ||||||
|  |         QString  bs=csv_getEntryAsString(myBA,0);      // read the 's'     war 2!?? | ||||||
|  |         int br=csv_getEntryAsInt(myBA,1);               // z.B. 5 (5.Eintrag in der Baud-Liste) | ||||||
|  |         bs=csv_getEntryAsString(myBA,2);                // z.B 115200 | ||||||
|  |         QString  cn=csv_getEntryAsString(myBA,3);       // z.B. COM9 | ||||||
|  |         int ci=csv_getEntryAsInt(myBA,4);               // Eintragsnummer in COM-Fenster | ||||||
|  |         //qDebug()<<"win_startup loaded com settings: "<<br<<" "<<bs<<" "<<cn; | ||||||
|  |         HWaccess->dc_openSerial(br,bs,cn,1); | ||||||
|  |         //CB_baudSel->setCurrentIndex(br);    // im BR auswahlfenster diese Baud vorgeben | ||||||
|  |         CB_portSel->setCurrentIndex(ci);    // den Port aus der Datei hier vorgeben | ||||||
|  |         connectButton->setChecked(true);    // connect Taste "druecken" | ||||||
|  |  | ||||||
|  |         myTO->start(100);     // restart | ||||||
|  |         myStep++; | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==1) | ||||||
|  |     { | ||||||
|  |         if (!myTO->isActive()) | ||||||
|  |         { | ||||||
|  |             if (HWaccess->dc_isPortOpen()) | ||||||
|  |                 myStep++; | ||||||
|  |             else | ||||||
|  |                 myStep=99;  // stop automatic connection and wait for manual start | ||||||
|  |             myTO->start(100); | ||||||
|  |         } | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==2) | ||||||
|  |     { | ||||||
|  |         if (!myTO->isActive()) | ||||||
|  |         { | ||||||
|  |             HWaccess->dc_requTestResponse(); | ||||||
|  |             myStep++; | ||||||
|  |             myTO->start(100); | ||||||
|  |         } | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==3) | ||||||
|  |     { | ||||||
|  |         if (!myTO->isActive()) | ||||||
|  |         { | ||||||
|  |             if (HWaccess->dc_readAnswTestResponse()) | ||||||
|  |                 myStep++;   // response was correct | ||||||
|  |             else | ||||||
|  |                 myStep=99;  // stop automatic connection and wait for manual start | ||||||
|  |             myTO->start(100); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==4) | ||||||
|  |     { | ||||||
|  |         HWaccess->dc_autoRequest(1); | ||||||
|  |         AutSendButton->setChecked(true);        // taste "druecken" | ||||||
|  |         myStep++; | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==5) | ||||||
|  |     { | ||||||
|  |         // got next screen: | ||||||
|  |         //myNextStep=2; // nicht bei CArun | ||||||
|  |         myStep++; | ||||||
|  |  | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==6) | ||||||
|  |     { | ||||||
|  |         // stop here, everything done | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==7) | ||||||
|  |     { | ||||||
|  |  | ||||||
|  |     } else | ||||||
|  |     { | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (myNextStep) | ||||||
|  |     { | ||||||
|  |         //qDebug()<<"fenster1 working: "<< myNextStep; | ||||||
|  |         *nextScreen=myNextStep; | ||||||
|  |         myNextStep=0; | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void T_winComPort::updateGui(void) | ||||||
|  | { | ||||||
|  |     QByteArray myBA; | ||||||
|  |     QString ms; | ||||||
|  |  | ||||||
|  |      ms=HWaccess->dc_getTxt4RsDiagWin(); | ||||||
|  |     if (ms.length()>1)  // sonst ständig scrolling | ||||||
|  |     { | ||||||
|  |        myDiagWindow->putText(ms); | ||||||
|  |        HWaccess->dc_clrTxt4RsDiagWin(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |      ms=HWaccess->dc_get2ndTxt4RsDiagWin(); | ||||||
|  |     if (ms.length()>1)  // sonst ständig scrolling | ||||||
|  |     { | ||||||
|  |         myDiagWindow->putText(ms); | ||||||
|  |         HWaccess->dc_clr2ndTxt4RsDiagWin(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // state of the COM Port (open, closed) | ||||||
|  |     ms=HWaccess->dc_getSerialState(); | ||||||
|  |     if (ms.length()>1)  // sonst ständig scrolling | ||||||
|  |     { | ||||||
|  |         LabelComState->setText(ms); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // -------------------------------------------------------------------------- | ||||||
|  |     // I  Statuszeile Handshakes (serial Control) | ||||||
|  |  | ||||||
|  |     ms=HWaccess->dc_getTxt4HsStateLine(); | ||||||
|  |     if (!connectButton->isChecked()) | ||||||
|  |         ms=""; | ||||||
|  |     if (ms.length()>1)  // sonst ständig scrolling | ||||||
|  |     { | ||||||
|  |         LabelHandshakes->setText(ms); | ||||||
|  |         HWaccess->dc_clrTxt4HsStateLine(); | ||||||
|  |         // clear to avoid multiple displaying | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     // II  Master receive state (empfangenes Telgramm OK? crc? length?  ) | ||||||
|  |     // Statuszeile Auswertung der SlaveResponse (serial Frame, CRC usw)  (prot.cpp) | ||||||
|  |  | ||||||
|  |     ms=HWaccess->dc_getTxt4masterStateLine(); | ||||||
|  |     if (!connectButton->isChecked()) | ||||||
|  |         ms="---"; | ||||||
|  |     if (ms.length()>1)  // sonst ständig scrolling | ||||||
|  |     { | ||||||
|  |         LabelRecieveFrame->setText(ms); | ||||||
|  |         HWaccess->dc_clrTxt4masterStateLine(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     // III   Slave receive (from Master) OK? if then show results, if not then show errors | ||||||
|  |     // entweder Empfangsfehler anzeigen (crc? length?) oder result OUT-OK, OUT_ERR, IN_OK, IN_ERR | ||||||
|  |     // Hintergrund: wenn der Slave Fehler im Master-Telegramm gefunden hat, dann kann er es auch | ||||||
|  |     // nicht verwenden und nichts ausgeben oder einlesen | ||||||
|  |  | ||||||
|  |     ms=HWaccess->dc_getTxt4resultStateLine(); | ||||||
|  |     if (!connectButton->isChecked()) | ||||||
|  |         ms="---"; | ||||||
|  |     if (ms.length()>1)  // sonst ständig scrolling | ||||||
|  |     { | ||||||
|  |         LabelResults->setText(ms); | ||||||
|  |         HWaccess->dc_clrTxt4resultStateLine(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     // IV  Statuszeile Empfangsdaten | ||||||
|  |  | ||||||
|  |     ms=HWaccess->dc_getdataStateLine(); | ||||||
|  |     if (!connectButton->isChecked()) | ||||||
|  |         ms="---"; | ||||||
|  |     if (ms.length()>1)  // sonst ständig scrolling | ||||||
|  |     { | ||||||
|  |         LabelDataState->setText(ms); | ||||||
|  |         HWaccess->dc_clrTxt4dataStateLine(); | ||||||
|  |         // clear to avoid multiple displaying | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     // 5. Zeile: Datif Ergebnis, Daten brauchbar? | ||||||
|  |  | ||||||
|  |     ms=HWaccess->dc_getdatifLine(); | ||||||
|  |     if (!connectButton->isChecked()) | ||||||
|  |         ms="---"; | ||||||
|  |     if (ms.length()>1)  // sonst ständig scrolling | ||||||
|  |     { | ||||||
|  |         LabelDatif->setText(ms); | ||||||
|  |         HWaccess->dc_clrTxt4datifLine(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // ----------------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										107
									
								
								dCArun/win01_com.h
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										107
									
								
								dCArun/win01_com.h
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,107 @@ | |||||||
|  | #ifndef WINCOMPORT_H | ||||||
|  | #define WINCOMPORT_H | ||||||
|  |  | ||||||
|  | #include <QVBoxLayout> | ||||||
|  | #include <QHBoxLayout> | ||||||
|  | #include <QGridLayout> | ||||||
|  | #include <QObject> | ||||||
|  | #include <QTimer> | ||||||
|  | #include <QDebug> | ||||||
|  | #include <QTabWidget> | ||||||
|  | #include <QScrollBar> | ||||||
|  | #include <QPlainTextEdit> | ||||||
|  | #include <QComboBox> | ||||||
|  | #include <QLabel> | ||||||
|  | #include <QScrollArea> | ||||||
|  | #include <QSerialPortInfo> | ||||||
|  | #include <QWidget> | ||||||
|  | #include <QListWidget> | ||||||
|  | #include <QGroupBox> | ||||||
|  | #include <QPushButton> | ||||||
|  | #include <QRadioButton> | ||||||
|  | //#include "tslib.h" | ||||||
|  | //#include "stepList.h"       // define all working chain steps here | ||||||
|  | //#include "datei.h" | ||||||
|  | #include "plugin.h" | ||||||
|  | //#include "globVars.h" | ||||||
|  |  | ||||||
|  | class Console : public QPlainTextEdit | ||||||
|  | { | ||||||
|  |     Q_OBJECT | ||||||
|  |  | ||||||
|  | public: | ||||||
|  |     explicit Console(QWidget *parent = nullptr); | ||||||
|  |  | ||||||
|  |     void putData(const QByteArray &data); | ||||||
|  |     void putText(QString text); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | class T_winComPort : public QWidget      // former TabComport | ||||||
|  | { | ||||||
|  |     Q_OBJECT | ||||||
|  |     Console *myDiagWindow;      // Ausgabefenster | ||||||
|  |     QComboBox *CB_portSel; | ||||||
|  |     //QComboBox *CB_baudSel; | ||||||
|  |     QPushButton *connectButton; | ||||||
|  |     QPushButton *AutSendButton; | ||||||
|  |     QPushButton *TestButton; | ||||||
|  |     QPushButton *refreshButton; | ||||||
|  |  | ||||||
|  |     QLabel *LabelComState;      // Statusanzeige | ||||||
|  |     QLabel *LabelPort; | ||||||
|  |     QLabel *LabelHandshakes; | ||||||
|  |     QLabel *LabelRecieveFrame; | ||||||
|  |     QLabel *LabelResults; | ||||||
|  |     QLabel *LabelDataState; | ||||||
|  |     QLabel *LabelDatif; | ||||||
|  |  | ||||||
|  |     QGridLayout *myTabComLayout; | ||||||
|  |     void subPortInfo(); | ||||||
|  |     hwinf *HWaccess; | ||||||
|  |     void updateGui(void); | ||||||
|  |     uint16_t myNextStep; | ||||||
|  |     uint8_t myStep; | ||||||
|  |     QTimer *myTO; | ||||||
|  |  | ||||||
|  | private slots: | ||||||
|  |     void callOpenSerial(); | ||||||
|  |     void callCloseSerial(); | ||||||
|  |     void callAutoSend(); | ||||||
|  |     //void tabComTime100ms(); | ||||||
|  |     void callConnectToggle(); | ||||||
|  |     void getDcTestRS232(); | ||||||
|  |     void callRefresh(void); | ||||||
|  |  | ||||||
|  | public: | ||||||
|  |     explicit T_winComPort(hwinf *HWaccess = nullptr, QWidget *parent = nullptr); | ||||||
|  |     bool work_ini(uint16_t *nextScreen, uint8_t *useNavi); | ||||||
|  |         // useNavi=0: no change | ||||||
|  |         // bit0,1: enable/disable button "next" | ||||||
|  |         // bit2,3: enable/disable button "home" | ||||||
|  |         // bit4,5: enable/disable button "back" | ||||||
|  |     bool working (uint16_t *nextScreen, uint8_t *useNavi); | ||||||
|  |     ~T_winComPort(); | ||||||
|  |  | ||||||
|  |     void writeRSdiagBytes(const QByteArray &bytarray); | ||||||
|  |     void writeRSdiagText(QString text); | ||||||
|  |     void writeComState(const QString text); | ||||||
|  |     void writeDataState(const QString text); | ||||||
|  |     void setButtons4autoStart(); | ||||||
|  |  | ||||||
|  | signals: | ||||||
|  |     void connectButtonPressed(); | ||||||
|  |     void closeButtonPressed(); | ||||||
|  |     void autoSendButtonIsOn(); | ||||||
|  |     void autoSendButtonIsOff(); | ||||||
|  |  | ||||||
|  | private slots: | ||||||
|  |     void newBaud(void); // just for test | ||||||
|  |  | ||||||
|  | public slots: | ||||||
|  |     void Nav_back(void); | ||||||
|  |     void Nav_home(void); | ||||||
|  |     void Nav_next(void); | ||||||
|  |  | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif | ||||||
| @@ -3,7 +3,7 @@ | |||||||
| #ifndef SER_H | #ifndef SER_H | ||||||
| #define SER_H | #define SER_H | ||||||
| #include <stdint.h> | #include <stdint.h> | ||||||
| #include <QObject> | #include <QMainWindow> | ||||||
| //#include <QString> | //#include <QString> | ||||||
| #include <QTimer> | #include <QTimer> | ||||||
| #include <QSerialPort> | #include <QSerialPort> | ||||||
|   | |||||||
| @@ -133,8 +133,8 @@ | |||||||
| #define SENDCOMBINED            0 | #define SENDCOMBINED            0 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class hwinf; | ||||||
|  | class DownloadThread; | ||||||
| class T_datif : public QObject | class T_datif : public QObject | ||||||
| { | { | ||||||
|     Q_OBJECT     |     Q_OBJECT     | ||||||
| @@ -165,13 +165,15 @@ class T_datif : public QObject | |||||||
|     T_prot *myDCIF; |     T_prot *myDCIF; | ||||||
|     QTimer *datif_trigger; |     QTimer *datif_trigger; | ||||||
|     uint8_t selectedSlaveAddr; |     uint8_t selectedSlaveAddr; | ||||||
|  |     DownloadThread *m_downloadThread; | ||||||
|  |     hwinf *m_hw; | ||||||
|  |  | ||||||
| private slots: | private slots: | ||||||
|     char datif_cycleSend(); |     char datif_cycleSend(); | ||||||
|     void StoredRecData(); |     void StoredRecData(); | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     T_datif(QObject *parent = nullptr); |     T_datif(hwinf *hw, QObject *parent = nullptr); | ||||||
|  |  | ||||||
|     void resetChain(void); |     void resetChain(void); | ||||||
|     char isPortOpen(void); |     char isPortOpen(void); | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| #ifndef DATEI_H | #ifndef DATEI_H | ||||||
| #define DATEI_H | #define DATEI_H | ||||||
|  |  | ||||||
| #include <stdint.h> |  | ||||||
| #include <QFile> | #include <QFile> | ||||||
| #include <QFileInfo> | #include <QFileInfo> | ||||||
| #include <QDebug> | #include <QDebug> | ||||||
|   | |||||||
| @@ -1,92 +0,0 @@ | |||||||
| /* |  | ||||||
| void incTextBuffer(void) |  | ||||||
| { |  | ||||||
|     runProc_prnSeqNr++; |  | ||||||
|     runProc_pointPrnTxt=0; |  | ||||||
|     if (runProc_prnSeqNr>127) |  | ||||||
|         runProc_prnSeqNr=127; |  | ||||||
|     runProc_prnCmdSeq[runProc_pointPrnCmd]=1; |  | ||||||
|     runProc_prnCmdPara[runProc_pointPrnCmd++]=runProc_prnSeqNr; |  | ||||||
| }*/ |  | ||||||
| /* |  | ||||||
| void T_runProc::subAppendNxtTxt(char *textLine) |  | ||||||
| { |  | ||||||
|     // append given text to current sequence, respect max. sequ.length |  | ||||||
|  |  | ||||||
|     // also send a command "print text buffer nn" ==1  once for each buffer |  | ||||||
|     //static uint8_t runProc_prnCmdSeq[512]; |  | ||||||
|     //static uint8_t runProc_prnCmdPara[512]; |  | ||||||
|     //static uint16_t runProc_pointPrnCmd; |  | ||||||
|  |  | ||||||
|     int sl=strlen(textLine); |  | ||||||
|     if (sl>1024) sl=1024; |  | ||||||
|     textLine[sl]=0; |  | ||||||
|     if (runProc_prnSeqNr==0 && runProc_pointPrnTxt<3) |  | ||||||
|     { |  | ||||||
|         // then this is the very first text entry |  | ||||||
|         // store command to print this buffer |  | ||||||
|         runProc_prnCmdSeq[runProc_pointPrnCmd]=1; |  | ||||||
|         runProc_prnCmdPara[runProc_pointPrnCmd++]=runProc_prnSeqNr; |  | ||||||
|     } |  | ||||||
|     if ( (runProc_pointPrnTxt + sl) > 1023) |  | ||||||
|     { |  | ||||||
|         incTextBuffer(); |  | ||||||
|  |  | ||||||
|     } |  | ||||||
|     runProc_prnTextSeq[runProc_prnSeqNr].append(textLine); |  | ||||||
|  |  | ||||||
|     //for (nn=0; nn<sl; nn++) |  | ||||||
|     //{ |  | ||||||
|         //runProc_prnTextSeq[runProc_prnSeqNr][runProc_pointPrnTxt+nn]=textLine[nn]; |  | ||||||
|     //} |  | ||||||
| }*/ |  | ||||||
|  |  | ||||||
| //    qCritical() << "emitting signal payCancelled"; |  | ||||||
| //    emit runProc_payCancelled(); |  | ||||||
|     /* |  | ||||||
|      // gabs bei Szeged, jetzt nicht mehr: |  | ||||||
|     if (payInProg==8) |  | ||||||
|     { |  | ||||||
|         // coin checker faulty, cannot start |  | ||||||
|         if (hwapi_paymentStarted==1) |  | ||||||
|         { |  | ||||||
|             hwapi_paymentStarted=90;    // stop due to error |  | ||||||
|             qCritical() << "emitting signal coinCollectionAborted 1"; |  | ||||||
|             emit runProc_coinCollectionAborted(); |  | ||||||
|             //sendFDcmd_set(156, 0,0, 2,0,0,0);       // cancel payment |  | ||||||
|         } |  | ||||||
|         return 10;    // error cannot start |  | ||||||
|     }*/ |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* |  | ||||||
| static uint8_t Sdata_DeviceParameter[64]; |  | ||||||
| static uint8_t Sdata_DevParaLen; |  | ||||||
|  |  | ||||||
| uint8_t T_runProc::epi_store64BdevParameter(uint8_t length, uint8_t *buf) |  | ||||||
| { |  | ||||||
|     // HWapi writes data to be stored |  | ||||||
|     uint8_t nn; |  | ||||||
|     for (nn=0; nn<length; nn++) |  | ||||||
|         Sdata_DeviceParameter[nn]=buf[nn]; |  | ||||||
|     for (nn=length; nn<64; nn++) |  | ||||||
|         Sdata_DeviceParameter[nn]=0; |  | ||||||
|  |  | ||||||
|     Sdata_DevParaLen=length; |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| uint8_t T_runProc::epi_restore64BdevParameter(uint8_t *length, uint8_t *buf) |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     for (uint8_t nn=0; nn<Sdata_DevParaLen; nn++) |  | ||||||
|         buf[nn]=Sdata_DeviceParameter[nn]; |  | ||||||
|     *length=Sdata_DevParaLen; |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
| */ |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
							
								
								
									
										141
									
								
								include/hwapi.h
									
									
									
									
									
								
							
							
						
						
									
										141
									
								
								include/hwapi.h
									
									
									
									
									
								
							| @@ -2,7 +2,6 @@ | |||||||
| matching interfaces.h: | matching interfaces.h: | ||||||
|  |  | ||||||
| // History | // History | ||||||
|  |  | ||||||
| // 11.10.2021: V1.0  222 functions | // 11.10.2021: V1.0  222 functions | ||||||
| // 23.12.2021: V1.1  added block-parameter to function "read mifare data" | // 23.12.2021: V1.1  added block-parameter to function "read mifare data" | ||||||
| // 30.12.2021: V1.2  added function: mif_clearDataBuffer(), mif_isBlockAvailable(uint8_t blkNr) and mif_getAvailableDataBlocks() | // 30.12.2021: V1.2  added function: mif_clearDataBuffer(), mif_isBlockAvailable(uint8_t blkNr) and mif_getAvailableDataBlocks() | ||||||
| @@ -15,39 +14,18 @@ matching interfaces.h: | |||||||
| //             V3.2 Bootloader improvement | //             V3.2 Bootloader improvement | ||||||
| // 12.04.2023: V3.3 new features extended: loading and using Json-files, cash-collection, cash-data-logging | // 12.04.2023: V3.3 new features extended: loading and using Json-files, cash-collection, cash-data-logging | ||||||
|  |  | ||||||
|  |  | ||||||
| 14.7.23TS: patch for correct printer state in line 3364 in sys_getDeviceConditions(struct T_moduleCondition *devCond) const |  | ||||||
|  |  | ||||||
| 8.9.2023 two new functions (end of file) for mifare test. Interface version 4.4   DC4.40...4.43 |  | ||||||
|  |  | ||||||
| 14.09.2023: Verriegelung eingebaut, nur noch gültige Abr.Daten zurückgeben, Suchbegriff: <epi_restoreVaultRecord> |  | ||||||
|             alle Mifare-Funktionen ueberprueft und ggf verbessert |  | ||||||
|     18.09.2023: Signal "Kasse entnommen" und Signale "Tuer auf/zu" ueberprueft |  | ||||||
|  |  | ||||||
| 20.9.2023: in datif die Abfrage der DynMachineData massiv beschleunigt |  | ||||||
|             und hier in hwapi die entprellten Werte fuer Tueren und Kasse verwenden. |  | ||||||
|             Problem war: Signal "Kasse entnommen" war zu langsam -> manchmal abr nicht gesendet |  | ||||||
|  |  | ||||||
| 14.3.24     new function bool hwapi::cash_isCollectionStarted(void) const |  | ||||||
|             padding three struct to 64 byte to avoid stack overflow when using |  | ||||||
|  |  | ||||||
| //#define HWINF_iid "Atb.Psa2020.software.HWapi/3.1" | //#define HWINF_iid "Atb.Psa2020.software.HWapi/3.1" | ||||||
| //#define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/3.1" | //#define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/3.1" | ||||||
| #define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/3.3" | #define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/3.3" | ||||||
|  |  | ||||||
| V4.0  6.9.2023: activating DC-Bootloader in slve-lib (SM) | V4.0  6.9.2023: activating DC-Bootloader in slve-lib (SM) | ||||||
|  |  | ||||||
| 23.5.2024: prn_getHwState() fixed and moved down to runProc with a wrapper in hwapi, current version: 5.5 |  | ||||||
|         several new functions for "direct ticket print", without the dueway loading jsons to DC and cmd DC to print |  | ||||||
|         The same rules as before apply to the json, but it can have any arbitrary length |  | ||||||
|  |  | ||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifndef hwapi_H | #ifndef hwapi_H | ||||||
| #define hwapi_H | #define hwapi_H | ||||||
|  |  | ||||||
| #include <stdint.h> |  | ||||||
| #include <QtPlugin> | #include <QtPlugin> | ||||||
| #include <QTimer> | #include <QTimer> | ||||||
| #include <QObject> | #include <QObject> | ||||||
| @@ -59,11 +37,11 @@ V4.0  6.9.2023: activating DC-Bootloader in slve-lib (SM) | |||||||
| #include "controlBus.h" | #include "controlBus.h" | ||||||
| #include "storeINdata.h" | #include "storeINdata.h" | ||||||
| #include "dcBL.h" | #include "dcBL.h" | ||||||
| //#include <../plugins/interfaces.h> | #include "interfaces.h" | ||||||
| #include "shared_mem_buffer.h" | #include "shared_mem_buffer.h" | ||||||
| #include "runProc.h" | #include "runProc.h" | ||||||
| #include "interfaces.h" | #include "download_thread.h" | ||||||
|  | #include "reporting_thread.h" | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * select Plugin Type here |  * select Plugin Type here | ||||||
| @@ -95,13 +73,10 @@ V4.0  6.9.2023: activating DC-Bootloader in slve-lib (SM) | |||||||
| //#undef THIS_IS_CA_MASTER  	 | //#undef THIS_IS_CA_MASTER  	 | ||||||
|  |  | ||||||
| //for CAmaster:	 | //for CAmaster:	 | ||||||
| //#define THIS_IS_CA_MASTER |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class QSharedMemory; | class QSharedMemory; | ||||||
| class DownloadThread; |  | ||||||
| class ReportingThread; | class ReportingThread; | ||||||
|  | class DownloadThread; | ||||||
| class hwapi :   public QObject, | class hwapi :   public QObject, | ||||||
|                 public hwinf |                 public hwinf | ||||||
| { | { | ||||||
| @@ -115,10 +90,9 @@ private: | |||||||
|     QSharedMemory *m_sharedMem; |     QSharedMemory *m_sharedMem; | ||||||
|     ReportingThread *m_reportingThread; |     ReportingThread *m_reportingThread; | ||||||
|     DownloadThread *m_downloadThread; |     DownloadThread *m_downloadThread; | ||||||
|     //QTimer *hwapi_triggerBL; |  | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit hwapi(QObject *parent = nullptr); |     explicit hwapi(QWidget *parent = nullptr); | ||||||
|  |  | ||||||
|  |  | ||||||
|     #ifdef  THIS_IS_CA_MASTER |     #ifdef  THIS_IS_CA_MASTER | ||||||
| @@ -590,10 +564,12 @@ public: | |||||||
|     // read printer condition and settings |     // read printer condition and settings | ||||||
|  |  | ||||||
|     uint8_t prn_getHwState(struct Tprn_hw_state *prn_hw_state) const override; |     uint8_t prn_getHwState(struct Tprn_hw_state *prn_hw_state) const override; | ||||||
|         // return value:  =prn_hw_state[0] |         // retval: status byte | ||||||
|         //       0:unknown   1: printer OK     100: printer OK but paper near end |             // byte 0 = 0: prnter OK,  >0: error | ||||||
|         //       200: not connected      201: printer on error     202: no paper |             // bit0: paper low  1: no paper    2: temperature error | ||||||
|  |             // 3: head open     4: paper jam in cutter | ||||||
|  |             // 6: no response   7: bad response from printer | ||||||
|  |         // and return struct "Tprn_hw_state" | ||||||
|  |  | ||||||
|     bool prn_isUpAndReady(void) const override; |     bool prn_isUpAndReady(void) const override; | ||||||
|         // true: printer is powered, serial is ok, no error, printer is connected and resonding |         // true: printer is powered, serial is ok, no error, printer is connected and resonding | ||||||
| @@ -622,7 +598,7 @@ public: | |||||||
|  |  | ||||||
|     void prn_movePaper(uint8_t wayInMm, uint8_t direction) const override; |     void prn_movePaper(uint8_t wayInMm, uint8_t direction) const override; | ||||||
|         //direction: 1=forward 2=backward |         //direction: 1=forward 2=backward | ||||||
|  |         // | ||||||
|     void prn_setFonts(uint8_t font, uint8_t size, uint8_t width, uint8_t height) const override; |     void prn_setFonts(uint8_t font, uint8_t size, uint8_t width, uint8_t height) const override; | ||||||
|         // font = kind of font 5...11 (0..22) |         // font = kind of font 5...11 (0..22) | ||||||
|         // size = 6...20, 9..9: too tiny 10: small ...12 = normal size ...20=huge |         // size = 6...20, 9..9: too tiny 10: small ...12 = normal size ...20=huge | ||||||
| @@ -1056,6 +1032,7 @@ public: | |||||||
|  |  | ||||||
|     void sys_getDynMachineConditions(struct T_dynamicCondition *dynMachCond) const override; |     void sys_getDynMachineConditions(struct T_dynamicCondition *dynMachCond) const override; | ||||||
|  |  | ||||||
|  |  | ||||||
|     uint32_t cash_getAmountInVault(void) const override; |     uint32_t cash_getAmountInVault(void) const override; | ||||||
|  |  | ||||||
|     uint16_t cash_getNrCoinsInVault(void) const override; |     uint16_t cash_getNrCoinsInVault(void) const override; | ||||||
| @@ -1319,15 +1296,8 @@ public: | |||||||
|  |  | ||||||
|     uint8_t bna_getCurrentNotes(uint16_t latestBill, uint16_t *currentNotes) const override; |     uint8_t bna_getCurrentNotes(uint16_t latestBill, uint16_t *currentNotes) const override; | ||||||
|         // returns number of collected bank notes since start-command (current transaction) |         // returns number of collected bank notes since start-command (current transaction) | ||||||
|         // return value: numbers of bills or 99 in case of error |         //  latestBill: last accepted bank note, value in cent | ||||||
|         //  latestBill: not used |         //  currentNotes an array with up to 16 (further) notes collected | ||||||
|         // in case of error: currentNotes[0,1,2,3] = 1..4 error number(s) |  | ||||||
|         // in normal case: |  | ||||||
|         //  currentNotes[0]: last bill in cent (e.g. 1000 = 10€) |  | ||||||
|         //  currentNotes[1]: bin 1 = bill is still in escrow   else bill is stacked |  | ||||||
|         //       note: by now (dec2023) escrow is not used, bills always go to stacker (box) |  | ||||||
|         //  currentNotes[2]: total sum of bills in cent, low word (16bit) |  | ||||||
|         //  currentNotes[3]: total sum of bills in cent, high word (16bit) |  | ||||||
|  |  | ||||||
|     void bna_requestStackerLevel(void) const override; |     void bna_requestStackerLevel(void) const override; | ||||||
|  |  | ||||||
| @@ -1336,9 +1306,6 @@ public: | |||||||
|         // countOfBills: array of up to 16 sums,    countOfBills[0]=nr of 5€-bills in stacker |         // countOfBills: array of up to 16 sums,    countOfBills[0]=nr of 5€-bills in stacker | ||||||
|         //                                          countOfBills[1] for 10€   and so on |         //                                          countOfBills[1] for 10€   and so on | ||||||
|  |  | ||||||
|     bool cash_isCollectionStarted(void) const override; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     // download device controller |     // download device controller | ||||||
|     bool dcDownloadRequest(QString const &fileToDownload) const override; |     bool dcDownloadRequest(QString const &fileToDownload) const override; | ||||||
| @@ -1352,6 +1319,7 @@ public: | |||||||
|     bool dcDownloadReportRunning() const override; |     bool dcDownloadReportRunning() const override; | ||||||
|     bool dcDownloadReportFinished() override; |     bool dcDownloadReportFinished() override; | ||||||
|  |  | ||||||
|  |  | ||||||
|     bool dcDownloadThreadStart() override; |     bool dcDownloadThreadStart() override; | ||||||
|     bool dcDownloadThreadRunning() const override; |     bool dcDownloadThreadRunning() const override; | ||||||
|     void dcDownloadThreadFinalize(DownloadThread *) override; |     void dcDownloadThreadFinalize(DownloadThread *) override; | ||||||
| @@ -1376,62 +1344,34 @@ public: | |||||||
|  |  | ||||||
|     virtual QObject const *getAPI() override; |     virtual QObject const *getAPI() override; | ||||||
|  |  | ||||||
|     void mod_switchResetline(void) override; | signals:    // for download | ||||||
|  |     void hwapi_reportDCDownloadStatus(QString const&) const; | ||||||
|  |     void hwapi_reportDCDownloadSuccess(QString const&) const; | ||||||
|  |     void hwapi_reportDCDownloadFailure(QString const&) const; | ||||||
|  |     // already declared in interfaces.h | ||||||
|  |     void hwapi_templatePrintFinished_OK(void) const; | ||||||
|  |     void hwapi_templatePrintFinished_Err(void) const; | ||||||
|  |  | ||||||
|  |     void hwapi_coinCollectionJustStarted(void) const; | ||||||
|  |     void hwapi_coinCollectionAborted(void) const; | ||||||
|  |  | ||||||
|  |     void hwapi_gotNewCoin(void) const; | ||||||
|  |     void hwapi_payStopByMax(void) const; | ||||||
|  |     void hwapi_payStopByPushbutton(void) const; | ||||||
|  |  | ||||||
|  |     void hwapi_payStopByEscrow(void) const; | ||||||
|     // 22.5.2024 direct ticket printing |     void hwapi_payStopByError(void) const; | ||||||
|  |     void hwapi_payStopByTimeout(void) const; | ||||||
|     void prn_translateLocalPrinterJson(QByteArray jsonFile2print) const override; |     void hwapi_payCancelled(void) const; | ||||||
|     // load, parse, translate and save the file |     void hwapi_coinProcessJustStopped(void) const; | ||||||
|  |  | ||||||
|     void prnStoreDynamics(char *bufferDynPrintVars[], uint8_t nrOfDyns) const override; |  | ||||||
|         // store nrOfDyns (up to 16) dynamics before printing |  | ||||||
|         // max length = 16 byte per dynamic |  | ||||||
|         // 16 strings with up to 16bytes each |  | ||||||
|  |  | ||||||
|     void prn_printTranslatedTicket(void) const override; |  | ||||||
|  |  | ||||||
|     uint8_t prn_waitForDirectTicket(void) const override; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| signals: |  | ||||||
|     void hwapi_reportDCDownloadStatus(QString const&) const override; |  | ||||||
|     void hwapi_reportDCDownloadSuccess(QString const&) const override; |  | ||||||
|     void hwapi_reportDCDownloadFailure(QString const&) const override; |  | ||||||
|  |  | ||||||
|     void hwapi_templatePrintFinished_OK(void) const override; |  | ||||||
|     void hwapi_templatePrintFinished_Err(void) const override; |  | ||||||
|  |  | ||||||
|     void hwapi_coinCollectionJustStarted(void) const override; |  | ||||||
|     void hwapi_coinCollectionAborted(void) const override; |  | ||||||
|  |  | ||||||
|     void hwapi_gotNewCoin(void) const override; |  | ||||||
|     void hwapi_payStopByMax(void) const override; |  | ||||||
|     void hwapi_payStopByPushbutton(void) const override; |  | ||||||
|  |  | ||||||
|     void hwapi_payStopByEscrow(void) const override; |  | ||||||
|     void hwapi_payStopByError(void) const override; |  | ||||||
|     void hwapi_payStopByTimeout(void) const override; |  | ||||||
|     void hwapi_payCancelled(void) const override; |  | ||||||
|     void hwapi_coinProcessJustStopped(void) const override; |  | ||||||
|  |  | ||||||
|     // new from 2023.06.12 |     // new from 2023.06.12 | ||||||
|     void hwapi_doorServiceDoorOpened(void) const override; |     void hwapi_doorServiceDoorOpened(void) const; | ||||||
|     void hwapi_doorVaultDoorOpened(void) const override; |     void hwapi_doorVaultDoorOpened(void) const; | ||||||
|     void hwapi_doorCoinBoxRemoved(void) const override; |     void hwapi_doorCoinBoxRemoved(void) const; | ||||||
|     void hwapi_doorCoinBoxInserted(void) const override; |     void hwapi_doorCoinBoxInserted(void) const; | ||||||
|     void hwapi_doorCBinAndAllDoorsClosed(void) const override; |     void hwapi_doorCBinAndAllDoorsClosed(void) const; | ||||||
|     void hwapi_doorAllDoorsClosed(void) const override; |     void hwapi_doorAllDoorsClosed(void) const; | ||||||
|  |  | ||||||
|     void hwapi_coinAttached() const override; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  private slots: |  private slots: | ||||||
|     //void hwapi_slotPrintFinished_OK(void); |     //void hwapi_slotPrintFinished_OK(void); | ||||||
| @@ -1459,7 +1399,8 @@ signals: | |||||||
|     void sub_slotCoin15(void); |     void sub_slotCoin15(void); | ||||||
|     void sub_slotCoin16(void); |     void sub_slotCoin16(void); | ||||||
|  |  | ||||||
|     void coinAttached(); |  | ||||||
|  |  | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ | |||||||
| #define INTERFACE_H | #define INTERFACE_H | ||||||
|  |  | ||||||
| #include <QtPlugin> | #include <QtPlugin> | ||||||
|  | #include <QString> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -24,7 +25,6 @@ struct T_emp | |||||||
|  |  | ||||||
|    // dynamic: |    // dynamic: | ||||||
|    uint8_t state;      // step counter of EMP (electronic coin checker) FSM (finite state machine): |    uint8_t state;      // step counter of EMP (electronic coin checker) FSM (finite state machine): | ||||||
|    /* |  | ||||||
|        // 0=start command |        // 0=start command | ||||||
|        // 1=powered, do emp ini, send reset |        // 1=powered, do emp ini, send reset | ||||||
|        // 2=delay |        // 2=delay | ||||||
| @@ -40,7 +40,7 @@ struct T_emp | |||||||
|        // 90: stop all, 1s delay |        // 90: stop all, 1s delay | ||||||
|        // 99: off, all stopped |        // 99: off, all stopped | ||||||
|  |  | ||||||
| */ |  | ||||||
|    uint8_t pollingRunning; |    uint8_t pollingRunning; | ||||||
|    uint8_t paymentRunning; |    uint8_t paymentRunning; | ||||||
|  |  | ||||||
| @@ -170,7 +170,6 @@ struct T_vaultRecord | |||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // ATTENTION: struct length must be 64 exactly!!! |  | ||||||
| struct T_moduleCondition | struct T_moduleCondition | ||||||
| { | { | ||||||
|         // store conditon of all system components, hold in RAM |         // store conditon of all system components, hold in RAM | ||||||
| @@ -179,64 +178,48 @@ struct T_moduleCondition | |||||||
|         // 50..99	= HINT / Notification |         // 50..99	= HINT / Notification | ||||||
|         // 100..150	= WARNING |         // 100..150	= WARNING | ||||||
|         // 200..250	= ERROR |         // 200..250	= ERROR | ||||||
|  |  | ||||||
|         uint8_t	ram; |         uint8_t	ram; | ||||||
|         uint8_t	intEe; |         uint8_t	intEe; | ||||||
|         uint8_t	extEe; |         uint8_t	extEe; | ||||||
|         uint8_t	rtc;				// 1: time/date OK   100: time not plausible  200: hardware error |  | ||||||
|  |  | ||||||
|  |         uint8_t	rtc;				// 1: time/date OK   100: time not plausible  200: hardware error | ||||||
|         uint8_t	boardHw; |         uint8_t	boardHw; | ||||||
|         uint8_t	printer; |         uint8_t	printer; | ||||||
|         uint8_t	modem; |         uint8_t	modem; | ||||||
|         uint8_t	signal;				//		1...99 |  | ||||||
|  |  | ||||||
|  |         uint8_t	signal;				//		1...99 | ||||||
|         uint8_t	regist;				// 100:not  1:reg  2:ping OK   3:gotTime |         uint8_t	regist;				// 100:not  1:reg  2:ping OK   3:gotTime | ||||||
|         uint8_t	mdbBus; |         uint8_t	mdbBus; | ||||||
|         uint8_t	coinChecker;		// EMP, OMP or mei-cashflow |         uint8_t	coinChecker;		// EMP, OMP or mei-cashflow | ||||||
|         uint8_t	coinEscrow; |  | ||||||
|  |  | ||||||
|  |         uint8_t	coinEscrow; | ||||||
|         uint8_t	mifareReader;       // 0: unknown  1=OK  200=no response  201=wrong response   202: Reader reports HW-error |         uint8_t	mifareReader;       // 0: unknown  1=OK  200=no response  201=wrong response   202: Reader reports HW-error | ||||||
|         uint8_t	creditTerm; |         uint8_t	creditTerm; | ||||||
|         uint8_t	coinReject; |         uint8_t	coinReject; | ||||||
|         uint8_t	coinSafe; |  | ||||||
|  |  | ||||||
|  |         uint8_t	coinSafe; | ||||||
|         uint8_t   billSafe; |         uint8_t   billSafe; | ||||||
|         uint8_t	voltage;			// 1:11..14V |         uint8_t	voltage;			// 1:11..14V | ||||||
|         uint8_t   temper; |         uint8_t   temper; | ||||||
|         uint8_t	poweronTest; |  | ||||||
|  |  | ||||||
|  |         uint8_t	poweronTest; | ||||||
|         uint8_t   doorState;			// 1: alles zu  200: tuer offen + bit1(S) +bit2(CB) + bit3(CB) |         uint8_t   doorState;			// 1: alles zu  200: tuer offen + bit1(S) +bit2(CB) + bit3(CB) | ||||||
|         uint8_t	doorWasOpened;		// 1: all doors are closed   200: any door was just opened |         uint8_t	doorWasOpened;		// 1: all doors are closed   200: any door was just opened | ||||||
|         uint8_t	changer; |         uint8_t	changer;			// can only be tested by usage | ||||||
|         uint8_t   coinBlocker; |  | ||||||
|  |  | ||||||
|         uint8_t   billReader; |         uint8_t   coinBlocker;		// can only be tested by usage | ||||||
|  |         uint8_t   billReader;			// can only be tested by usage | ||||||
|         uint8_t   ResetReason; |         uint8_t   ResetReason; | ||||||
|         uint8_t	allModulesChecked; |         uint8_t	allModulesChecked; | ||||||
|         uint8_t   alarmState; |  | ||||||
|  |  | ||||||
|         uint8_t   fuses; |         uint8_t   alarmState; | ||||||
|         uint8_t   res11; |         uint8_t   res11; | ||||||
|         uint8_t   res12; |         uint8_t   res12; | ||||||
|         uint8_t   res13; |         uint8_t   res13; | ||||||
|         // 32 | // 31 | ||||||
|  |  | ||||||
|         uint8_t     padd00; |  | ||||||
|         uint8_t     padd01; |  | ||||||
|         uint8_t     padd02; |  | ||||||
|         uint8_t     padd03; |  | ||||||
|         //36 |  | ||||||
|         uint32_t   padd04; |  | ||||||
|         uint32_t   padd05; |  | ||||||
|         uint32_t   padd06; |  | ||||||
|         uint32_t   padd07; |  | ||||||
|         // 52 |  | ||||||
|         uint32_t   padd08; |  | ||||||
|         uint32_t   padd09; |  | ||||||
|         uint32_t   padd10; |  | ||||||
|         // 64 |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| struct T_dynamicCondition | struct T_dynamicCondition | ||||||
| { | { | ||||||
|         char allDoorsDebounced; |         char allDoorsDebounced; | ||||||
| @@ -245,19 +228,17 @@ struct T_dynamicCondition | |||||||
|         char upperDoor;         // 99: undefined  0:closed  1:open |         char upperDoor;         // 99: undefined  0:closed  1:open | ||||||
|         char middleDoor;		// 99: undefined  0:closed  1:open |         char middleDoor;		// 99: undefined  0:closed  1:open | ||||||
|         char lowerDoor;         // 99: undefined  0:closed  1:open |         char lowerDoor;         // 99: undefined  0:closed  1:open | ||||||
|         char coinAttached; |         char reserve; | ||||||
|         char billBox; |         char billBox; | ||||||
|         char modeAbrech; |         char modeAbrech; | ||||||
|         char onAlarm;           // 0:alarm aus  1:alarm  2:alarm mit Sirene   3: Sirenentest |         char onAlarm;           // 0:alarm aus  1:alarm  2:alarm mit Sirene   3: Sirenentest | ||||||
|         // 10 |  | ||||||
|         char nowCardTest; |         char nowCardTest; | ||||||
|         char nowPayment;        // not used, always 0 |         char nowPayment;        // not used, always 0 | ||||||
|         char lastMifCardType; |         char lastMifCardType; | ||||||
|         uint8_t lastSDoorState; |         uint8_t lastSDoorState; | ||||||
|         uint8_t lastVDoorState; |         uint8_t lastVDoorState; | ||||||
|         uint8_t lastCBstate;        // =0, not used |         uint8_t lastCBstate; | ||||||
|         char        paymentInProgress; |         char        paymentInProgress; | ||||||
|         // Version Szeged:  aug2023 |  | ||||||
|         //	0: stopped by timeout |         //	0: stopped by timeout | ||||||
|         //  1: running  2: wait4lastCoin |         //  1: running  2: wait4lastCoin | ||||||
|         //				3: payment stopped manually, coins in Escrow |         //				3: payment stopped manually, coins in Escrow | ||||||
| @@ -266,25 +247,9 @@ struct T_dynamicCondition | |||||||
|         //			    6: coins encashed   7:coins returned |         //			    6: coins encashed   7:coins returned | ||||||
|         //				8: CoinChecker or MDB on Error |         //				8: CoinChecker or MDB on Error | ||||||
|  |  | ||||||
|         // since Schoenau with bill and changer, nov2023 |  | ||||||
|         //0 = no payment |  | ||||||
|         //will be set to 1 by cash_startCollection() |  | ||||||
|         //neu 1: wait for devices getting ready for payment |  | ||||||
|         //2 = payment, |  | ||||||
|         //3 = wait for last coin/bill |  | ||||||
|         //4 = Bezahlvorgang manuell beendet |  | ||||||
|         //5 = payment stopped autom, amount collected, coins in Escrow |  | ||||||
|         //6 = Bezahlvorgang beendet weil ZK voll |  | ||||||
|         //4,5,6: payment done, keep on polling, wait for cash or return command |  | ||||||
|         //7 = encash collected money from coin escrow into cash box |  | ||||||
|         //8 = return "amountToReturn", can be complete inserted amount or only overpayment |  | ||||||
|         //9 = wait for changer result |  | ||||||
|         //10= print refund receipt with "amountToReturn" |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         char        res1; |         char        res1; | ||||||
|         uint16_t    U_Batt; |         uint16_t    U_Batt; | ||||||
|         // 20 |  | ||||||
|         uint16_t	Temperatur; |         uint16_t	Temperatur; | ||||||
|         uint16_t	nrCoinsInBox; |         uint16_t	nrCoinsInBox; | ||||||
|         uint32_t	amountInBox; |         uint32_t	amountInBox; | ||||||
| @@ -294,14 +259,11 @@ struct T_dynamicCondition | |||||||
|         char        jsonValid_device; |         char        jsonValid_device; | ||||||
|         char        jsonValid_cash; |         char        jsonValid_cash; | ||||||
|         char        jsonValid_print; |         char        jsonValid_print; | ||||||
|         // 40 |  | ||||||
|         char        jsonValid_serial; |         char        jsonValid_serial; | ||||||
|         char        jsonValid_time; |         char        jsonValid_time; | ||||||
|         char        lastFileType; |         char        lastFileType; | ||||||
|  | // 44 | ||||||
|         uint8_t     MifCardHolder[8]; |         uint8_t     MifCardHolder[8]; | ||||||
|         // 51 |  | ||||||
|  |  | ||||||
|         uint8_t     resultOfLastTemplPrint; |         uint8_t     resultOfLastTemplPrint; | ||||||
|                     // 0: unknown or printing in progress |                     // 0: unknown or printing in progress | ||||||
|                     // 1: OK, doc was printed   2: error, doc was not printed |                     // 1: OK, doc was printed   2: error, doc was not printed | ||||||
| @@ -312,36 +274,9 @@ struct T_dynamicCondition | |||||||
|                     //          bit4: paper jam in cutter |                     //          bit4: paper jam in cutter | ||||||
|                     //          bit6: no response             bit7: serial rec. error |                     //          bit6: no response             bit7: serial rec. error | ||||||
|                     //			bit5: printer not ready |                     //			bit5: printer not ready | ||||||
|         uint8_t     startupTestIsRunning;   // =0, not used |         uint8_t     startupTestIsRunning; | ||||||
|         uint16_t    empty;                   // neu 3.7.24, dieser Platz wird vom Compiler im Ram |  | ||||||
|                                             // freigehalten weil naechster Wert ein Long ist |  | ||||||
|         // 56 |  | ||||||
|         // new since 7.5.24 |  | ||||||
|         uint32_t   totalNrOfCuts; |  | ||||||
|         uint16_t   nextAccountNumber; |  | ||||||
|         uint16_t   nrOfBillsInBox; |  | ||||||
|   //uint16_t   padd07;            // raus am 3.7.24 |  | ||||||
|          // 64 |  | ||||||
|  |  | ||||||
|         // rest comes with new cmd: |  | ||||||
|         uint32_t    amountInBillbox; |  | ||||||
|         uint16_t    UbatAtLastPrint; |  | ||||||
|         uint16_t    pad01; |  | ||||||
|         uint32_t    reserve01; |  | ||||||
|         uint32_t    reserve02; |  | ||||||
|         uint32_t    reserve03; |  | ||||||
|         uint32_t    reserve04; |  | ||||||
|         uint32_t    reserve05; |  | ||||||
|         uint32_t    reserve06; |  | ||||||
|         uint32_t    reserve07; |  | ||||||
|         uint32_t    reserve08; |  | ||||||
|         uint32_t    reserve09; |  | ||||||
|         uint32_t    reserve10; |  | ||||||
|         uint32_t    reserve11; |  | ||||||
|         uint32_t    reserve12; |  | ||||||
|         uint32_t    reserve13; |  | ||||||
|         uint32_t    reserve14; |  | ||||||
|  |  | ||||||
|  |         //54 | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct T_extTime | struct T_extTime | ||||||
| @@ -378,7 +313,6 @@ struct T_extTime | |||||||
| typedef uint8_t UCHAR; | typedef uint8_t UCHAR; | ||||||
| typedef uint16_t UINT; | typedef uint16_t UINT; | ||||||
|  |  | ||||||
| // ATTENTION: struct length must be 64 exactly!!! |  | ||||||
| struct T_devices | struct T_devices | ||||||
| { | { | ||||||
|     // set by master, used(1) or notused (0) or type 2....20 |     // set by master, used(1) or notused (0) or type 2....20 | ||||||
| @@ -387,6 +321,7 @@ struct T_devices | |||||||
|     UCHAR	kindOfCoinChecker;		// 0: without  1=EMP820   2=EMP900    3=currenza Csquare  (MW) |     UCHAR	kindOfCoinChecker;		// 0: without  1=EMP820   2=EMP900    3=currenza Csquare  (MW) | ||||||
|     UCHAR	kindOfMifareReader;		// by now only stronglink SL025 =1 |     UCHAR	kindOfMifareReader;		// by now only stronglink SL025 =1 | ||||||
|     UCHAR   solarPower;             // 1:sleep allowed   0: no sleep |     UCHAR   solarPower;             // 1:sleep allowed   0: no sleep | ||||||
|  |     //UCHAR   suppressSleepMode;	// 0:sleep allowed   1: no sleep | ||||||
|  |  | ||||||
|     UCHAR	kindOfModem;			// 0:off    1:Sunlink |     UCHAR	kindOfModem;			// 0:off    1:Sunlink | ||||||
|     UCHAR	kindOfCreditcard;		// 0:off    1:Feig NFC |     UCHAR	kindOfCreditcard;		// 0:off    1:Feig NFC | ||||||
| @@ -395,7 +330,6 @@ struct T_devices | |||||||
|  |  | ||||||
|     UCHAR	CoinShutter; |     UCHAR	CoinShutter; | ||||||
|     UCHAR	BillAcceptor; |     UCHAR	BillAcceptor; | ||||||
|     // 10 |  | ||||||
|     UCHAR	usevaultLock; |     UCHAR	usevaultLock; | ||||||
|     UCHAR	autoAlarm;				// 1: switch on siren for 1min in doors opened unauthorized |     UCHAR	autoAlarm;				// 1: switch on siren for 1min in doors opened unauthorized | ||||||
|  |  | ||||||
| @@ -406,28 +340,9 @@ struct T_devices | |||||||
|  |  | ||||||
|     UINT	VaultFullWarnLevel; |     UINT	VaultFullWarnLevel; | ||||||
|     UINT	VaultFullErrorLevel; |     UINT	VaultFullErrorLevel; | ||||||
|     // 20 |  | ||||||
|     UINT    BattEmptyWarnLevel; |     UINT    BattEmptyWarnLevel; | ||||||
|     UINT    BattEmptyErrorLevel; |     UINT    BattEmptyErrorLevel; | ||||||
|  |  | ||||||
|     UCHAR   useForeignCharacters; |  | ||||||
|     UCHAR   printRefundReceipt; |  | ||||||
|     UINT	BillFullWarnLevel; |  | ||||||
|     UINT	BillFullErrorLevel; |  | ||||||
|  |  | ||||||
|     UCHAR   housing; |  | ||||||
|     UCHAR   resUc1; |  | ||||||
|     // 32 |  | ||||||
|     uint32_t     padd01; |  | ||||||
|     uint32_t     padd02; |  | ||||||
|     uint32_t     padd03; |  | ||||||
|     uint32_t     padd04; |  | ||||||
|     uint32_t     padd05; |  | ||||||
|     uint32_t     padd06; |  | ||||||
|     uint32_t     padd07; |  | ||||||
|     uint32_t     padd08; |  | ||||||
|     // 64 |  | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct T_chg_Tub | struct T_chg_Tub | ||||||
| @@ -459,8 +374,6 @@ struct T_changer | |||||||
|     uint8_t paymentRunning;	// 1: coins are accepted |     uint8_t paymentRunning;	// 1: coins are accepted | ||||||
|     uint16_t denomination[16]; |     uint16_t denomination[16]; | ||||||
|     uint16_t availableTubes; //bitwise 0,1 1=av. bit0 = lowest coin value |     uint16_t availableTubes; //bitwise 0,1 1=av. bit0 = lowest coin value | ||||||
|     uint16_t pad; |  | ||||||
|     // 64byte |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct T_bna | struct T_bna | ||||||
| @@ -469,32 +382,23 @@ struct T_bna | |||||||
|     uint8_t setup;			// 0: not  1: got valid parameters from device |     uint8_t setup;			// 0: not  1: got valid parameters from device | ||||||
|     uint8_t	FeatureLevel; |     uint8_t	FeatureLevel; | ||||||
|     uint16_t countryCode;		// programmed in EMP |     uint16_t countryCode;		// programmed in EMP | ||||||
|  |  | ||||||
|     uint16_t scalingFactor;				// z.B. 5 |     uint16_t scalingFactor;				// z.B. 5 | ||||||
|     uint8_t	decimalPlace; |     uint8_t	decimalPlace; | ||||||
|     uint8_t pad1; |     uint8_t pad1; | ||||||
|  |  | ||||||
|     uint16_t stackerCap; |     uint16_t stackerCap; | ||||||
|     uint16_t billSecureLevel; |     uint16_t billSecureLevel; | ||||||
| // 12 |  | ||||||
|     uint8_t	hasEscrow; |     uint8_t	hasEscrow; | ||||||
|     uint8_t accBillTypes[16];             // programmed in EMP  z.B. (bit 0..7): 1 2 4 10 20 40 0 0 |     uint8_t accBillTypes[16];             // programmed in EMP  z.B. (bit 0..7): 1 2 4 10 20 40 0 0 | ||||||
|     uint16_t currentStackerLevel;        // requested number of notes in billbox |     uint16_t currentStackerLevel;        // requested number of notes in billbox | ||||||
| // 31 |  | ||||||
|     // settings from Master |     // settings from Master | ||||||
|     uint16_t intendedAccept;    // bit 0 =5€ |     uint16_t intendedAccept;    // bit 0 =5€ | ||||||
|     uint16_t pad2; |     uint16_t pad2; | ||||||
|  // 35 |     uint16_t billDenomination[16]; | ||||||
|     uint16_t billDenomination[8]; |  | ||||||
| // 51 |  | ||||||
|     uint8_t  pad3; |  | ||||||
|     uint32_t pad4; |  | ||||||
|     uint32_t pad5; |  | ||||||
|     uint32_t pad6; |  | ||||||
|     // 8.5.24 reduced, 3 bytes too much. |  | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | class hwapi; | ||||||
| class DownloadThread; | class DownloadThread; | ||||||
| class hwinf | class hwinf | ||||||
| { | { | ||||||
| @@ -1333,17 +1237,16 @@ public: | |||||||
|  |  | ||||||
|     // read printer condition and settings |     // read printer condition and settings | ||||||
|  |  | ||||||
|     virtual uint8_t prn_getHwState(struct Tprn_hw_state *prn_hw_state) const |     virtual uint8_t prn_getHwState(struct Tprn_hw_state *prn_hw_state) const { | ||||||
|     { |  | ||||||
|         Q_UNUSED(prn_hw_state); |         Q_UNUSED(prn_hw_state); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|     // return value:  =prn_hw_state[0] |         // retval: status byte | ||||||
|     //       0:unknown   1: printer OK     100: printer OK but paper near end |             // byte 0 = 0: prnter OK,  >0: error | ||||||
|     //       200: not connected      201: printer on error     202: no paper |             // bit0: paper low  1: no paper    2: temperature error | ||||||
|  |             // 3: head open     4: paper jam in cutter | ||||||
|  |             // 6: no response   7: bad response from printer | ||||||
|  |         // and return struct "Tprn_hw_state" | ||||||
|  |  | ||||||
|     virtual bool prn_isUpAndReady(void) const { |     virtual bool prn_isUpAndReady(void) const { | ||||||
|         return false; |         return false; | ||||||
| @@ -2352,23 +2255,14 @@ public: | |||||||
|     virtual void bna_requestCurrentNotes() const {} |     virtual void bna_requestCurrentNotes() const {} | ||||||
|     // send command to DC in order to get transaction data |     // send command to DC in order to get transaction data | ||||||
|  |  | ||||||
|     virtual uint8_t bna_getCurrentNotes(uint16_t latestBill, uint16_t *currentNotes) const |     virtual uint8_t bna_getCurrentNotes(uint16_t latestBill, uint16_t *currentNotes) const { | ||||||
|     { |  | ||||||
|         Q_UNUSED(latestBill); |         Q_UNUSED(latestBill); | ||||||
|         Q_UNUSED(currentNotes); |         Q_UNUSED(currentNotes); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|     // returns number of collected bank notes since start-command (current transaction) |     // returns number of collected bank notes since start-command (current transaction) | ||||||
|     // return value: numbers of bills or 99 in case of error |     //  latestBill: last accepted bank note, value in cent | ||||||
|     //  latestBill: not used |     //  currentNotes an array with up to 16 (further) notes collected | ||||||
|     // in case of error: currentNotes[0,1,2,3] = 1..4 error number(s) |  | ||||||
|     // in normal case: |  | ||||||
|     //  currentNotes[0]: last bill in cent (e.g. 1000 = 10€) |  | ||||||
|     //  currentNotes[1]: bin 1 = bill is still in escrow   else bill is stacked |  | ||||||
|     //       note: by now (dec2023) escrow is not used, bills always go to stacker (box) |  | ||||||
|     //  currentNotes[2]: total sum of bills in cent, low word (16bit) |  | ||||||
|     //  currentNotes[3]: total sum of bills in cent, high word (16bit) |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     virtual void bna_requestStackerLevel() const {} |     virtual void bna_requestStackerLevel() const {} | ||||||
|  |  | ||||||
| @@ -2381,9 +2275,6 @@ public: | |||||||
|     // countOfBills: array of up to 16 sums,    countOfBills[0]=nr of 5€-bills in stacker |     // countOfBills: array of up to 16 sums,    countOfBills[0]=nr of 5€-bills in stacker | ||||||
|     //                                          countOfBills[1] for 10€   and so on |     //                                          countOfBills[1] for 10€   and so on | ||||||
|  |  | ||||||
|     virtual bool cash_isCollectionStarted(void) const {return false;} |  | ||||||
|         // return true is coin collection in DC is running |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     // download device controller |     // download device controller | ||||||
|     virtual bool dcDownloadRequest(QString const &fileToDownload) const { |     virtual bool dcDownloadRequest(QString const &fileToDownload) const { | ||||||
| @@ -2435,83 +2326,34 @@ public: | |||||||
|  |  | ||||||
|     virtual QObject const *getAPI() { return nullptr; } |     virtual QObject const *getAPI() { return nullptr; } | ||||||
|  |  | ||||||
|     virtual void mod_switchResetline()  { } | signals:    // for download | ||||||
|  |     void hwapi_reportDCDownloadStatus(QString const&) const; | ||||||
|  |     void hwapi_reportDCDownloadSuccess(QString const&) const; | ||||||
|  |     void hwapi_reportDCDownloadFailure(QString const&) const; | ||||||
|  |  | ||||||
|  |     // NOTE: declaring a "pure virtual" "signal" should be an error and thus not valid. | ||||||
|  |     void hwapi_templatePrintFinished_OK() const; | ||||||
|  |     void hwapi_templatePrintFinished_Err() const; | ||||||
|  |  | ||||||
|     // direct ticket printing |     void hwapi_coinCollectionJustStarted() const; | ||||||
|     // new from 22.5.2024, print Json-Printer-Template which |     void hwapi_coinCollectionAborted() const; | ||||||
|     // is stored locally here in PTU memory, |  | ||||||
|     // rather then loading several jsons to DC and tell it to print (until now) |  | ||||||
|     // the local printer-json can have any length using predefined commands |  | ||||||
|     // printing a local printer-json happens like this: |  | ||||||
|     // 1) select a file to be printed from memory |  | ||||||
|     // 2) load, parse, translate and save the file with following function |  | ||||||
|     // 3) set dynamics (values from current transaction) |  | ||||||
|     // 4) send saved file to printer one or several times |  | ||||||
|     // hint: dynamics can be changed at any time without reloading the ticket, just repeat 3) and 4) |  | ||||||
|  |  | ||||||
|     virtual void prn_translateLocalPrinterJson(QByteArray jsonFile2print) const |     void hwapi_gotNewCoin() const; | ||||||
|     { Q_UNUSED(jsonFile2print) } |     void hwapi_payStopByMax() const; | ||||||
|     // load, parse, translate and save the file |     void hwapi_payStopByPushbutton() const; | ||||||
|  |  | ||||||
|     virtual void prnStoreDynamics(char *bufferDynPrintVars[], uint8_t nrOfDyns) const |  | ||||||
|     { Q_UNUSED(bufferDynPrintVars);  Q_UNUSED(nrOfDyns) } |  | ||||||
|         // store nrOfDyns (up to 16) dynamics before printing |  | ||||||
|         // max length = 16 byte per dynamic |  | ||||||
|         // 16 strings with up to 16bytes each |  | ||||||
|  |  | ||||||
|     virtual void prn_printTranslatedTicket(void) const { } |  | ||||||
|  |  | ||||||
|     virtual uint8_t prn_waitForDirectTicket(void) const { return 0; } |  | ||||||
|     // return:  0: just printing, wait |  | ||||||
|     //          1: OK - last print was succesful |  | ||||||
|     //          2: error - not printed |  | ||||||
|     //              2: printer error  3: no connection to DC |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| signals: |  | ||||||
|     /* |  | ||||||
|         NOTE: the difference between a virtual Qt signal and a normal Qt signal: |  | ||||||
|         A Qt virtual signal is a connection that is established using a pointer |  | ||||||
|         or reference and is not connected to an object or data. It is therefore |  | ||||||
|         not bound to a particular object, but to a specific class (object type). |  | ||||||
|         Qt virtual signals are useful because they allow you to create |  | ||||||
|         connections without worrying about whether an object or a specific data |  | ||||||
|         element has been destroyed. |  | ||||||
|         https://www.youtube.com/watch?v=HTH3VFfqsXw |  | ||||||
|  |  | ||||||
|      */ |  | ||||||
|     virtual void hwapi_reportDCDownloadStatus(QString const&) const {} |  | ||||||
|     virtual void hwapi_reportDCDownloadSuccess(QString const&) const {} |  | ||||||
|     virtual void hwapi_reportDCDownloadFailure(QString const&) const {} |  | ||||||
|  |  | ||||||
|     virtual void hwapi_templatePrintFinished_OK(void) const=0; |  | ||||||
|     virtual void hwapi_templatePrintFinished_Err(void) const=0; |  | ||||||
|  |  | ||||||
|     virtual void hwapi_coinCollectionJustStarted(void) const=0; |  | ||||||
|     virtual void hwapi_coinCollectionAborted(void) const=0; |  | ||||||
|  |  | ||||||
|     virtual void hwapi_gotNewCoin(void) const=0; |  | ||||||
|     virtual void hwapi_payStopByMax(void) const=0; |  | ||||||
|     virtual void hwapi_payStopByPushbutton(void) const=0; |  | ||||||
|  |  | ||||||
|     virtual void hwapi_payStopByEscrow(void) const=0; |  | ||||||
|     virtual void hwapi_payStopByError(void) const=0; |  | ||||||
|     virtual void hwapi_payStopByTimeout(void) const=0; |  | ||||||
|     virtual void hwapi_payCancelled(void) const=0; |  | ||||||
|     virtual void hwapi_coinProcessJustStopped(void) const=0; |  | ||||||
|  |  | ||||||
|     virtual void hwapi_doorServiceDoorOpened(void) const=0; |  | ||||||
|     virtual void hwapi_doorVaultDoorOpened(void) const=0; |  | ||||||
|     virtual void hwapi_doorCoinBoxRemoved(void) const=0; |  | ||||||
|     virtual void hwapi_doorCoinBoxInserted(void) const=0; |  | ||||||
|     virtual void hwapi_doorCBinAndAllDoorsClosed(void) const=0; |  | ||||||
|     virtual void hwapi_doorAllDoorsClosed(void) const=0; |  | ||||||
|  |  | ||||||
|     virtual void hwapi_coinAttached() const = 0; |  | ||||||
|  |  | ||||||
|  |     void hwapi_payStopByEscrow() const; | ||||||
|  |     void hwapi_payStopByError() const; | ||||||
|  |     void hwapi_payStopByTimeout() const; | ||||||
|  |     void hwapi_payCancelled() const; | ||||||
|  |     void hwapi_coinProcessJustStopped() const; | ||||||
|  |  | ||||||
|  |     void hwapi_doorServiceDoorOpened() const; | ||||||
|  |     void hwapi_doorVaultDoorOpened() const; | ||||||
|  |     void hwapi_doorCoinBoxRemoved() const; | ||||||
|  |     void hwapi_doorCoinBoxInserted() const; | ||||||
|  |     void hwapi_doorCBinAndAllDoorsClosed() const; | ||||||
|  |     void hwapi_doorAllDoorsClosed() const; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -2574,21 +2416,9 @@ signals: | |||||||
|  |  | ||||||
| // hier dazwischen: Umstellung ALLER Prototypen | // hier dazwischen: Umstellung ALLER Prototypen | ||||||
| //  hier von =0 auf {} durch Gerhard | //  hier von =0 auf {} durch Gerhard | ||||||
| //#define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/5.2" |  | ||||||
|  | #define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/5.2" | ||||||
|     // 7.11.2023: bna functions activated |     // 7.11.2023: bna functions activated | ||||||
| //#define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/5.3" |  | ||||||
|     // 14.3.24:new function bool hwapi::cash_isCollectionStarted(void) const |  | ||||||
|     // padding three struct to 64 byte to avoid stack overflow when using |  | ||||||
|     // signal coin attached is much faster now |  | ||||||
|  |  | ||||||
| //#define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/5.4" |  | ||||||
|     // 7.may.2024, matches to DC V6, some structs extended |  | ||||||
|     // new function: modem reset, dyn. data come with two commands now |  | ||||||
|     // released 17.may.2024 |  | ||||||
|  |  | ||||||
| #define HWINF_iid "Atb.Psa1256ptu5.software.HWapi/5.5" |  | ||||||
|     // started at 21.5.24, integration of ticket interpreter |  | ||||||
|     // see change log in hwapi.h |  | ||||||
|  |  | ||||||
|  |  | ||||||
| Q_DECLARE_INTERFACE(hwinf, HWINF_iid) | Q_DECLARE_INTERFACE(hwinf, HWINF_iid) | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
|  |  | ||||||
| #ifndef SERIAL_FRAME_H | #ifndef SERIAL_FRAME_H | ||||||
| #define SERIAL_FRAME_H | #define SERIAL_FRAME_H | ||||||
| #include <QObject> | #include <QMainWindow> | ||||||
| #include <QString> | #include <QString> | ||||||
| #include <QTimer> | #include <QTimer> | ||||||
| #include "tslib.h" | #include "tslib.h" | ||||||
| @@ -43,7 +43,7 @@ | |||||||
| #define     STARTSIGN_RECEIVE_LONG          0x5D | #define     STARTSIGN_RECEIVE_LONG          0x5D | ||||||
|  |  | ||||||
|  |  | ||||||
| class T_prot : public QObject | class T_prot : public QMainWindow | ||||||
| { | { | ||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,8 +2,7 @@ | |||||||
| #ifndef RUN_PROCESS_H | #ifndef RUN_PROCESS_H | ||||||
| #define RUN_PROCESS_H | #define RUN_PROCESS_H | ||||||
|  |  | ||||||
| #include <stdint.h> | #include <QMainWindow> | ||||||
| #include <QObject> |  | ||||||
| #include <QString> | #include <QString> | ||||||
| #include <QTimer> | #include <QTimer> | ||||||
| #include "tslib.h" | #include "tslib.h" | ||||||
| @@ -15,7 +14,6 @@ | |||||||
| #include <QDebug> | #include <QDebug> | ||||||
| #include "datIf.h" | #include "datIf.h" | ||||||
| #include <QSharedMemory> | #include <QSharedMemory> | ||||||
| #include <atomic> |  | ||||||
| #include "sendWRcmd.h" | #include "sendWRcmd.h" | ||||||
| #include "controlBus.h" | #include "controlBus.h" | ||||||
| #include "storeINdata.h" | #include "storeINdata.h" | ||||||
| @@ -23,10 +21,11 @@ | |||||||
| #include "shared_mem_buffer.h" | #include "shared_mem_buffer.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class T_runProc : public QObject | class T_runProc : public QObject | ||||||
| { | { | ||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|     QTimer *hwapi_TimerPayment, *hwapi_triggerBL, *myTO; |     QTimer *hwapi_TimerPayment, *hwapi_triggerBL; | ||||||
|  |  | ||||||
|     void sub_emp_getAllParameters(struct T_emp *emp); |     void sub_emp_getAllParameters(struct T_emp *emp); | ||||||
|     void changer_getAllParameters(struct T_changer *mw); |     void changer_getAllParameters(struct T_changer *mw); | ||||||
| @@ -35,20 +34,6 @@ class T_runProc : public QObject | |||||||
|  |  | ||||||
|     void restoreDeviceParameter(struct T_devices *deviceSettings); |     void restoreDeviceParameter(struct T_devices *deviceSettings); | ||||||
|  |  | ||||||
|     void clearPrnFile(void); |  | ||||||
|     char subFeedPaper(char *valueStr); |  | ||||||
|     bool subGetVariStr(char *valueStr, char *returnStr); |  | ||||||
|     //void subAppendNxtTxt(char *textLine); |  | ||||||
|     void sub_changeStyle(char *valueStr); |  | ||||||
|     void subPrintGrafics(char *valueStr); |  | ||||||
|     char prn_directTicket_cycle(void); |  | ||||||
|     void runProc_subPerformPrintCmds(uint8_t nextCmd, uint8_t nextPara); |  | ||||||
|     uint16_t subStoreTicketText(char *textLine); |  | ||||||
|  |  | ||||||
| #ifndef THIS_IS_CA_MASTER |  | ||||||
|     std::atomic_bool m_coinAttached{false}; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| private slots: | private slots: | ||||||
|     void runProc_slotProcess(void); |     void runProc_slotProcess(void); | ||||||
|     bool bl_performComplStart(void); |     bool bl_performComplStart(void); | ||||||
| @@ -62,9 +47,6 @@ public: | |||||||
|     uint8_t epi_restore64BdevParameter(uint8_t *length, uint8_t *buf); |     uint8_t epi_restore64BdevParameter(uint8_t *length, uint8_t *buf); | ||||||
|     bool doors_supervise(void); |     bool doors_supervise(void); | ||||||
|     uint8_t prn_getHwState(struct Tprn_hw_state *prn_hw_state); |     uint8_t prn_getHwState(struct Tprn_hw_state *prn_hw_state); | ||||||
|         // byte 0: 0:unknown   1: printer OK     100: printer OK but paper near end |  | ||||||
|         //          200: not connected    201: printer on error   202: no paper |  | ||||||
|  |  | ||||||
|     void bl_completeStart(void); |     void bl_completeStart(void); | ||||||
|     void dc_autoRequest(bool on); |     void dc_autoRequest(bool on); | ||||||
|     void bl_rebootDC(void); |     void bl_rebootDC(void); | ||||||
| @@ -72,48 +54,6 @@ public: | |||||||
|     void bl_checkBL(void); |     void bl_checkBL(void); | ||||||
|     bool bl_isUp(void); |     bool bl_isUp(void); | ||||||
|  |  | ||||||
|     // new from 21.5.24 .................................................................. |  | ||||||
|  |  | ||||||
|     uint16_t sys_getCustomerNumber(void); |  | ||||||
|     uint16_t sys_getMachineNumber(void); |  | ||||||
|     uint16_t sys_getBoroughNumber(void); |  | ||||||
|     uint16_t sys_getZoneNumber(void); |  | ||||||
|     uint16_t sys_getMachineAlias(void); |  | ||||||
|     void sys_getLocation(char *locStr); |  | ||||||
|     void prn_sendText(QByteArray *buf); |  | ||||||
|     void prn_sendPrnSysCmd(uint8_t para1, uint8_t para2, uint32_t para3); |  | ||||||
|     void prn_printBarcode(uint8_t kindOf, uint8_t withText,  uint8_t offset, uint8_t rotation, uint8_t dataLeng, uint8_t *data); |  | ||||||
|     bool sys_parseFile(QByteArray jsonFile2print); |  | ||||||
|         // and copy all keys and values to arrays |  | ||||||
|  |  | ||||||
|     bool sys_translateKeys(void); |  | ||||||
|  |  | ||||||
|     bool sys_interpretPrnCmds(void); |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     void prn_sendPrnSetup(uint16_t paperSpeed, uint8_t density,  uint8_t alignment, uint8_t orientation); |  | ||||||
|         // send 5 byte: byte 0,1: speed  5...250 mm/s |  | ||||||
|         //              byte2: density   0....(25)....50 |  | ||||||
|         //              byte3: alignment    'l', 'c', 'r' = left, center, right |  | ||||||
|         //              byte4: orientation  0, 90, 180    = 0°, 90°, 180° rotation (by now not supported!) |  | ||||||
|  |  | ||||||
|     void prnStoreDynamics(char *bufferDynPrintVars[], uint8_t nrOfDyns); |  | ||||||
|         // store nrOfDyns (up to 16) dynamics before printing |  | ||||||
|         // max length = 16 byte per dynamic |  | ||||||
|  |  | ||||||
|     bool prnRestoreDynamic(uint8_t nrOfDyn, char *bufferOneDyn); |  | ||||||
|         // nrOfDyn = 0...15 |  | ||||||
|         // buffer bufferOneDyn[16] needs length of at least 16 byte |  | ||||||
|  |  | ||||||
|     bool prn_isUpAndReady(void); |  | ||||||
|  |  | ||||||
|     void prnStartDirectPrinting(void); |  | ||||||
|  |  | ||||||
|     uint8_t prn_getDirectPrintResult(void); |  | ||||||
|     // return:  0: just printing, wait |  | ||||||
|     //          1: OK - last print was succesful |  | ||||||
|     //          2: error - not printed |  | ||||||
|     //              2: printer error  3: no connection to DC |  | ||||||
|  |  | ||||||
| signals: | signals: | ||||||
|     //void runProc_templatePrintFinished_OK(void) const override; |     //void runProc_templatePrintFinished_OK(void) const override; | ||||||
| @@ -139,7 +79,6 @@ signals: | |||||||
|     void runProc_doorCBinAndAllDoorsClosed(void); |     void runProc_doorCBinAndAllDoorsClosed(void); | ||||||
|     void runProc_doorAllDoorsClosed(void); |     void runProc_doorAllDoorsClosed(void); | ||||||
|  |  | ||||||
|     void runProc_coinAttached(); |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								include/sendWRcmd.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										2
									
								
								include/sendWRcmd.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -14,8 +14,6 @@ uint8_t sendWRcmd_getSendBlock160(uint8_t *leng, uint8_t *buf); | |||||||
|  |  | ||||||
| void sendWRcmd_INI(void); | void sendWRcmd_INI(void); | ||||||
|  |  | ||||||
| uint8_t sendWRcmd_getStackSize(void); |  | ||||||
|  |  | ||||||
| // #define     FDCMD_STACKDEPTH    16 / 32 | // #define     FDCMD_STACKDEPTH    16 / 32 | ||||||
| // short and long commands are queued into the same stack to guaranty right order | // short and long commands are queued into the same stack to guaranty right order | ||||||
| void sendFDcmd_clrStack(void); | void sendFDcmd_clrStack(void); | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								include/shared_mem_buffer.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										7
									
								
								include/shared_mem_buffer.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -230,9 +230,6 @@ struct SharedMem | |||||||
|     uint8_t  store_bnaCollect[8]; |     uint8_t  store_bnaCollect[8]; | ||||||
|     uint8_t  store_bnaContent[64]; |     uint8_t  store_bnaContent[64]; | ||||||
|  |  | ||||||
|     // new, 8.5.24 |  | ||||||
|     uint8_t store_machCon2len; |  | ||||||
|     uint8_t store_machCon2[66]; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -245,7 +242,7 @@ struct SharedMem | |||||||
|     // ------------------ Data OUTPUT -------------------------------- |     // ------------------ Data OUTPUT -------------------------------- | ||||||
|  |  | ||||||
|     // sendWRcmd.cpp |     // sendWRcmd.cpp | ||||||
|     #define CMDSTACKDEPTH   32 |     #define CMDSTACKDEPTH   16 | ||||||
|     uint16_t nextAsynchsendCmd0[CMDSTACKDEPTH]; |     uint16_t nextAsynchsendCmd0[CMDSTACKDEPTH]; | ||||||
|     uint8_t  nrOfCmdsInQueue; |     uint8_t  nrOfCmdsInQueue; | ||||||
|  |  | ||||||
| @@ -303,6 +300,7 @@ struct SharedMem | |||||||
|  |  | ||||||
|     uint8_t  p_nextFDcmdsInQueue; |     uint8_t  p_nextFDcmdsInQueue; | ||||||
|  |  | ||||||
|  |  | ||||||
|     // download of device controller and json files |     // download of device controller and json files | ||||||
|     struct DCDownload { |     struct DCDownload { | ||||||
|         enum class FILE_INDEX { |         enum class FILE_INDEX { | ||||||
| @@ -324,7 +322,6 @@ struct SharedMem | |||||||
|         std::atomic_bool m_finished{false}; |         std::atomic_bool m_finished{false}; | ||||||
|     } m_downLoadDC; |     } m_downLoadDC; | ||||||
|  |  | ||||||
|  |  | ||||||
|     static QSharedMemory *getShm(std::size_t s = 0); |     static QSharedMemory *getShm(std::size_t s = 0); | ||||||
|  |  | ||||||
|     static SharedMem *getData() |     static SharedMem *getData() | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								include/storeINdata.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										9
									
								
								include/storeINdata.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -527,9 +527,6 @@ void gpi_storeDcDataValid(bool isVal); | |||||||
|  |  | ||||||
| bool epi_areDcDataValid(); | bool epi_areDcDataValid(); | ||||||
|  |  | ||||||
| void epi_setDcDataValid(void); |  | ||||||
|  |  | ||||||
| void epi_resetDcDataValid(char reason); |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void epi_clearDynData(void); | void epi_clearDynData(void); | ||||||
| @@ -626,12 +623,6 @@ void epi_restoreBnaContent(uint8_t  *data); | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void epi_clearDynMachCond2(void); |  | ||||||
|  |  | ||||||
| void gpi_storeDynMachCond2(uint8_t leng, uint8_t *data); |  | ||||||
|  |  | ||||||
| void epi_restoreDynMachCond2(uint8_t *leng, uint8_t *data); |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										33
									
								
								include/tslib.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										33
									
								
								include/tslib.h
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -1,7 +1,7 @@ | |||||||
| #ifndef TSLIB_H | #ifndef TSLIB_H | ||||||
| #define TSLIB_H | #define TSLIB_H | ||||||
| #include <QByteArray> | #include <QByteArray> | ||||||
| #include "stdint.h" |  | ||||||
|  |  | ||||||
| #define LOWBYTE     false | #define LOWBYTE     false | ||||||
| #define HIGHBYTE    true | #define HIGHBYTE    true | ||||||
| @@ -87,37 +87,6 @@ void biox_CopyBlock(uint8_t *src, uint16_t srcPos, uint8_t *dest, uint16_t destP | |||||||
|  |  | ||||||
| bool tslib_strComp(uint8_t *buf, char *compStr); | bool tslib_strComp(uint8_t *buf, char *compStr); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| uint16_t tslib_StrLen(char *str); |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void tslib_itoa(int n, char *str); |  | ||||||
|     // -23456 -> str[0]='-'   str[1]='2' ...[5]='6' str[6]=0 |  | ||||||
|     // 5      -> str[0]='5'   str[1..6]=0 |  | ||||||
|  |  | ||||||
| void tslib_uitoa(unsigned int n, char *str); |  | ||||||
|  |  | ||||||
| void tslib_ltoa(long n, char *str); |  | ||||||
|     // -2147483647 -> str[0]='-'   str[1]='2' ...[10]='6' str[11]=0 |  | ||||||
|  |  | ||||||
| void tslib_ultoa( long n, char *str); |  | ||||||
|     // 0... ->4294967296   str[0]='4'   str[1]='2' ...[9]='6' str[10]=0   str[11]=0 |  | ||||||
|  |  | ||||||
| void tslib_uitobin( int  decval, char *str); |  | ||||||
|  |  | ||||||
| long tslib_atol( char *AscString); |  | ||||||
|     // change ascii string ( of ascii numbers '0'..'9') to number |  | ||||||
|     // AscString must be 0-terminated! |  | ||||||
|     // a leading '-' is ignored, a'.' or a ',' stops calculation |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif // TSLIB_H | #endif // TSLIB_H | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,46 +1,14 @@ | |||||||
| TEMPLATE = lib | TEMPLATE = lib | ||||||
| TARGET = CAmaster | TARGET = CAmaster | ||||||
| VERSION="1.0.1" | VERSION="1.0.0" | ||||||
|  |  | ||||||
| HEADERS += \ |  | ||||||
|     ../include/com.h \ |  | ||||||
|     ../include/datIf.h \ |  | ||||||
|     ../include/prot.h |  | ||||||
|  |  | ||||||
| SOURCES += \ |  | ||||||
|     ../src/com.cpp \ |  | ||||||
|     ../src/datIf.cpp \ |  | ||||||
|     ../src/prot.cpp |  | ||||||
|  |  | ||||||
| include(../DCLibraries.pri) | include(../DCLibraries.pri) | ||||||
|  |  | ||||||
| win32 { |  | ||||||
|     BUILD_DATE=$$system("date /t") |  | ||||||
|     BUILD_TIME=$$system("time /t") |  | ||||||
|     GIT_COMMIT="" |  | ||||||
|     EXTENDED_VERSION="" |  | ||||||
|     EXTENDED_VERSION_LIB="" |  | ||||||
| } else { |  | ||||||
|     BUILD_DATE=$$system("date +%d-%m-%y") |  | ||||||
|     BUILD_TIME=$$system("date +%H:%M:%S") |  | ||||||
|  |  | ||||||
|     GIT_COMMIT=$$system("git log -1 --format=oneline . | cut -d' ' -f1") |  | ||||||
|     EXTENDED_VERSION_LIB="libCAmaster-$${VERSION}-$${GIT_COMMIT}" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| DEFINES+=APP_VERSION=\\\"$$VERSION\\\" |  | ||||||
| DEFINES+=APP_BUILD_DATE=\\\"$$BUILD_DATE\\\" |  | ||||||
| DEFINES+=APP_BUILD_TIME=\\\"$$BUILD_TIME\\\" |  | ||||||
| DEFINES+=APP_EXTENDED_VERSION=\\\"$$EXTENDED_VERSION\\\" |  | ||||||
| DEFINES+=APP_EXTENDED_VERSION_LIB=\\\"$$EXTENDED_VERSION_LIB\\\" |  | ||||||
|  |  | ||||||
| DEFINES+=THIS_IS_CA_MASTER | DEFINES+=THIS_IS_CA_MASTER | ||||||
|  | DEFINES-=THIS_IS_CA_SLAVE | ||||||
| DESTDIR=$${_PRO_FILE_PWD_}/../build | DESTDIR=$${_PRO_FILE_PWD_}/../build | ||||||
|  |  | ||||||
| unix { | unix { | ||||||
|     system("mkdir -p $${DESTDIR}") |     system("mkdir -p $${DESTDIR}") | ||||||
|     system("cp ../include/interfaces.h $${DESTDIR}") |     system("cp ../include/interfaces.h $${DESTDIR}") | ||||||
| } | } | ||||||
|  |  | ||||||
| DISTFILES += \ |  | ||||||
|     ../include/dump.txt |  | ||||||
|   | |||||||
| @@ -1,30 +1,12 @@ | |||||||
| TEMPLATE = lib | TEMPLATE = lib | ||||||
| TARGET = CAslave | TARGET = CAslave | ||||||
| VERSION="1.0.1" | VERSION="1.0.0" | ||||||
|  |  | ||||||
| include(../DCLibraries.pri) | include(../DCLibraries.pri) | ||||||
|  |  | ||||||
| win32 { |  | ||||||
|     BUILD_DATE=$$system("date /t") |  | ||||||
|     BUILD_TIME=$$system("time /t") |  | ||||||
|     GIT_COMMIT="" |  | ||||||
|     EXTENDED_VERSION="" |  | ||||||
|     EXTENDED_VERSION_LIB="" |  | ||||||
| } else { |  | ||||||
|     BUILD_DATE=$$system("date +%d-%m-%y") |  | ||||||
|     BUILD_TIME=$$system("date +%H:%M:%S") |  | ||||||
|  |  | ||||||
|     GIT_COMMIT=$$system("git log -1 --format=oneline . | cut -d' ' -f1") |  | ||||||
|     EXTENDED_VERSION_LIB_="libCAslave-$${VERSION}-$${GIT_COMMIT}" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| DEFINES+=APP_VERSION=\\\"$$VERSION\\\" |  | ||||||
| DEFINES+=APP_BUILD_DATE=\\\"$$BUILD_DATE\\\" |  | ||||||
| DEFINES+=APP_BUILD_TIME=\\\"$$BUILD_TIME\\\" |  | ||||||
| DEFINES+=APP_EXTENDED_VERSION=\\\"$$EXTENDED_VERSION\\\" |  | ||||||
| DEFINES+=APP_EXTENDED_VERSION_LIB=\\\"$$EXTENDED_VERSION_LIB\\\" |  | ||||||
|  |  | ||||||
| DEFINES+=THIS_IS_CA_SLAVE | DEFINES+=THIS_IS_CA_SLAVE | ||||||
|  | DEFINES-=THIS_IS_CA_MASTER | ||||||
|  |  | ||||||
| DESTDIR=$${_PRO_FILE_PWD_}/../build | DESTDIR=$${_PRO_FILE_PWD_}/../build | ||||||
|  |  | ||||||
| unix { | unix { | ||||||
|   | |||||||
							
								
								
									
										256
									
								
								src/datIf.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										256
									
								
								src/datIf.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -1,14 +1,10 @@ | |||||||
| /* |  | ||||||
| History: |  | ||||||
| 06.12.2023: weitere IN-requests in Autorequest übernommen |  | ||||||
|             Umschaltung mit/ohne Verkauf, während VK nur 12 wichtige, sonst alle 36 |  | ||||||
|  |  | ||||||
|  |  | ||||||
| */ |  | ||||||
| #include "datIf.h" | #include "datIf.h" | ||||||
| #include "sendWRcmd.h" | #include "sendWRcmd.h" | ||||||
| #include "controlBus.h" | #include "controlBus.h" | ||||||
| #include "storeINdata.h" | #include "storeINdata.h" | ||||||
|  | #include "download_thread.h" | ||||||
|  | #include "hwapi.h" | ||||||
|  |  | ||||||
| #include <QDebug> | #include <QDebug> | ||||||
| #include <datei.h> | #include <datei.h> | ||||||
| #include <QDir> | #include <QDir> | ||||||
| @@ -54,8 +50,10 @@ static uint8_t datif_pNextCmd, datif_sendSlowCmd; | |||||||
| //#define     DATIF_CTR_GOTRESPVAL        100 | //#define     DATIF_CTR_GOTRESPVAL        100 | ||||||
|  |  | ||||||
|  |  | ||||||
| T_datif::T_datif(QObject *parent) : QObject(parent) | T_datif::T_datif(hwinf *hw, QObject *parent) : QObject(parent) | ||||||
| { | { | ||||||
|  |     m_hw = hw; | ||||||
|  |  | ||||||
|     QByteArray myBA; |     QByteArray myBA; | ||||||
|     QDir myDir("../dmd"); |     QDir myDir("../dmd"); | ||||||
|  |  | ||||||
| @@ -88,8 +86,7 @@ T_datif::T_datif(QObject *parent) : QObject(parent) | |||||||
|     dif_scanStep=0; |     dif_scanStep=0; | ||||||
|     selectedSlaveAddr=FIX_SLAVE_ADDR; |     selectedSlaveAddr=FIX_SLAVE_ADDR; | ||||||
|     cycl_running=0; |     cycl_running=0; | ||||||
|     epi_resetDcDataValid(1);        // data are not yet valid, no response from DC by now |     gpi_storeDcDataValid(0);        // data are not yet valid, no response from DC by now | ||||||
|  |  | ||||||
|     datif_noResponseCtr=0; |     datif_noResponseCtr=0; | ||||||
|  |  | ||||||
|     datif_repeatCtr=0; |     datif_repeatCtr=0; | ||||||
| @@ -129,11 +126,6 @@ void T_datif::resetChain(void) | |||||||
|    dif_scanStep=0; |    dif_scanStep=0; | ||||||
| } | } | ||||||
|  |  | ||||||
| #define     RESPONSEWAITTIME    10 |  | ||||||
|     // ab 5 keine timeouts mehr |  | ||||||
| #define     GOTRESP_SENDGAP     20 |  | ||||||
|     // Wert egal, muss nur > RESPONSEWAITTIME und <255 sein |  | ||||||
|  |  | ||||||
| char T_datif::datif_cycleSend() | char T_datif::datif_cycleSend() | ||||||
| { | { | ||||||
|     // cyclic transmission of INPUT-Requests |     // cyclic transmission of INPUT-Requests | ||||||
| @@ -150,14 +142,14 @@ char T_datif::datif_cycleSend() | |||||||
|     if ( !myDCIF->isPortOpen()) |     if ( !myDCIF->isPortOpen()) | ||||||
|     { |     { | ||||||
|         //qDebug()  << "com port not available";    // wird ununterbrochen ausgegeben |         //qDebug()  << "com port not available";    // wird ununterbrochen ausgegeben | ||||||
|         epi_resetDcDataValid(2);    // DC data not valid |         gpi_storeDcDataValid(0);    // DC data not valid | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // supervise if DC data are valid |     // supervise if DC data are valid | ||||||
|     datif_noResponseCtr++;         // inc every 20ms |     datif_noResponseCtr++;         // inc every 20ms | ||||||
|     if (datif_noResponseCtr>250)   // no life sign from device controller (DC) for about 3s |     if (datif_noResponseCtr>250)   // no life sign from device controller (DC) for about 3s | ||||||
|         epi_resetDcDataValid(3);    // DC data has not updated for >=5s -> no longer valid! |         gpi_storeDcDataValid(0);    // DC data has not updated for >=5s -> no longer valid! | ||||||
|  |  | ||||||
|     // Ueberwachung ob ein oder mehrere Commands am Stueck erfolgreich waren |     // Ueberwachung ob ein oder mehrere Commands am Stueck erfolgreich waren | ||||||
|     if (gpi_wantToResetSupervision()) |     if (gpi_wantToResetSupervision()) | ||||||
| @@ -176,7 +168,8 @@ char T_datif::datif_cycleSend() | |||||||
|     // c) gar keine Antwort, Timeout nach 100ms -> 2x wiederholen (nach einer Luecke von 10ms ) |     // c) gar keine Antwort, Timeout nach 100ms -> 2x wiederholen (nach einer Luecke von 10ms ) | ||||||
|     // cycl_running=0: nichts zu tun    1: Mitteilung: Kommando wurde soeben abgesendet, 2,3,4 = Wiederholung |     // cycl_running=0: nichts zu tun    1: Mitteilung: Kommando wurde soeben abgesendet, 2,3,4 = Wiederholung | ||||||
|  |  | ||||||
|     if (cycl_running) |     if (cycl_running)   // 21.9.23 doRepeat hier raus sonst gehts warten auch nicht mehr (BL) | ||||||
|  |      //   if (cycl_running && doRepeat) | ||||||
|     { |     { | ||||||
|         // request is still running, wait for response before next sending |         // request is still running, wait for response before next sending | ||||||
|         //qDebug()<< "datif wait for response"; |         //qDebug()<< "datif wait for response"; | ||||||
| @@ -184,41 +177,47 @@ char T_datif::datif_cycleSend() | |||||||
|         datif_trigger->start(20);   // ruft "this" (datif_cycleSend) erneut in 20ms auf |         datif_trigger->start(20);   // ruft "this" (datif_cycleSend) erneut in 20ms auf | ||||||
|                 // mit 10 kein Unterscheid weil Zykluszeit grösser |                 // mit 10 kein Unterscheid weil Zykluszeit grösser | ||||||
|  |  | ||||||
|         cycl_running++;     // inc every 20ms, warte auf Antwort |         cycl_running++;     // inc every 20...30ms  // warte max 100ms auf Antwort | ||||||
|  |         if (cycl_running >80 && cycl_running <95)   // neu 13.9.23     mind. 40 damit Templates | ||||||
|         if (cycl_running >= GOTRESP_SENDGAP) |                                                                     // in Folge gedruckt werden koennen | ||||||
|  |                                                     // 95: muss nur kleiner sein als die 100 fuer die Luecke | ||||||
|  |                                                     // 17.10.23:  50--> 80 | ||||||
|         { |         { | ||||||
|             // got response, wait just one (this) cycle before next sending |             // 100ms vergangen, bisher keine Antwort, also Kommando wiederholen | ||||||
|             cycl_running=0; |  | ||||||
|             return 0; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         if (cycl_running >=RESPONSEWAITTIME ) |  | ||||||
|         { |  | ||||||
|             // bisher keine Antwort, also Kommando wiederholen |  | ||||||
|             qDebug()<< "datif timeout no response for wr/rd cmd "<< keepLastWrCmd << " " << keepLastRdCmd;             |             qDebug()<< "datif timeout no response for wr/rd cmd "<< keepLastWrCmd << " " << keepLastRdCmd;             | ||||||
|             cycl_running = 0;       // gleich wiederholen weil ja schon ewig nichts mehr reinkam |             cycl_running = 0;       // gleich wiederholen weil ja schon ewig nichts mehr reinkam | ||||||
|             datif_cmdWasPerformed=2;    //  NO :(( |             datif_cmdWasPerformed=2;    //  NO :(( | ||||||
|             gpi_storeLastResult(8); |             gpi_storeLastResult(8); | ||||||
|             return 0; |  | ||||||
|         } |         } | ||||||
| /* |  | ||||||
|  * Unsinn, wird nie durchlaufen |         if (cycl_running>=101)    // 100 + 1 | ||||||
|         if (cycl_running>=(RESPONSEWAITTIME+6))  // 3.7.24: 101-->110 |  | ||||||
|         { |         { | ||||||
|             // Antwort ist gekommen, also nach kurzer Luecke naechstes (datif_cmdWasPerformed==1) |             // Antwort ist gekommen, also nach kurzer Luecke naechstes (datif_cmdWasPerformed==1) | ||||||
|             //      oder nochmal gleiches (datif_cmdWasPerformed==2) Kommando senden |             //      oder nochmal gleiches (datif_cmdWasPerformed==2) Kommando senden | ||||||
|             //qDebug()<< "datif got any response"; |             //qDebug()<< "datif got any response"; | ||||||
|             cycl_running=0;             |             cycl_running=0;             | ||||||
|         } |         } | ||||||
| */ |  | ||||||
|         // hier stoppen, weil Antwort des letzten Cmds noch nicht da |         // hier stoppen, weil Antwort des letzten Cmds noch nicht da | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     if (m_hw->dcDownloadRequested()) { // only happens in ca-master | ||||||
|  |         m_hw->dcDownloadResetRequest(); | ||||||
|  |  | ||||||
|  |         // start download-thread. | ||||||
|  |         m_downloadThread = new DownloadThread(m_hw); | ||||||
|  |         m_downloadThread->start(); | ||||||
|  |  | ||||||
|  |         int cnt = 10; | ||||||
|  |         while (--cnt > 0 && !m_downloadThread->isRunning()) { | ||||||
|  |             QThread::msleep(100); | ||||||
|  |         } | ||||||
|  |         if (cnt <= 0) { | ||||||
|  |             qCritical() << "DOWNLOAD-THREAD NOT RUNNING WITHIN 1000ms"; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     // 17.7.2023: repeat commands if result was !=OK  ------------------------------------------------------------------- |     // 17.7.2023: repeat commands if result was !=OK  ------------------------------------------------------------------- | ||||||
|     if (datif_cmdWasPerformed==2 && doRepeat)       // Cmd was not or false performed und Wiederholen erwuenscht |     if (datif_cmdWasPerformed==2 && doRepeat)       // Cmd was not or false performed und Wiederholen erwuenscht | ||||||
| @@ -234,7 +233,6 @@ char T_datif::datif_cycleSend() | |||||||
|             datif_kindOfCmd=0; |             datif_kindOfCmd=0; | ||||||
|             cycl_running=0; |             cycl_running=0; | ||||||
|             gpi_storeOverallResult(2); |             gpi_storeOverallResult(2); | ||||||
|             qCritical()<<"datif, error no response to wr/rd "<<keepLastWrCmd<<" "<<keepLastRdCmd; |  | ||||||
|             return 0; |             return 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -261,7 +259,7 @@ char T_datif::datif_cycleSend() | |||||||
|             datif_cmdWasPerformed=0; |             datif_cmdWasPerformed=0; | ||||||
|         } else |         } else | ||||||
|         { |         { | ||||||
|             qCritical()  << "datif: unknown cmd, stop repeating wr/rd:" << keepLastWrCmd << " " << keepLastRdCmd; |             qDebug()  << "datif: unknown cmd, stop repeating wr/rd:" << keepLastWrCmd << " " << keepLastRdCmd; | ||||||
|             datif_cmdWasPerformed=0; |             datif_cmdWasPerformed=0; | ||||||
|             cycl_running=0; |             cycl_running=0; | ||||||
|             datif_kindOfCmd=0; |             datif_kindOfCmd=0; | ||||||
| @@ -292,10 +290,8 @@ char T_datif::datif_cycleSend() | |||||||
|             myDCIF->setUserReadData(nextRdCmd); |             myDCIF->setUserReadData(nextRdCmd); | ||||||
|             myDCIF->sendUserData(selectedSlaveAddr); |             myDCIF->sendUserData(selectedSlaveAddr); | ||||||
|  |  | ||||||
|    qDebug()<<"Datif send long FD cmd (wr/rd): "<<nextWrCmd<< " / " << nextRdCmd << "Dlen:" << length; |             //qDebug()<<"Datif send long FD cmd (wr/rd): "<<nextWrCmd<< " / " << nextRdCmd | ||||||
|     //      << "    data:" << data[0]<< " " << data[1]<< " " << data[2]<< " " << data[3] |             //        << " " << data[0]<< " " << data[1]<< " " << data[2]<< " " << data[3]; | ||||||
|    //       << " " << data[4]<< " " << data[5]<< " " << data[6]<< " " << data[7] |  | ||||||
|     //      << " " << data[8]<< " " << data[9]<< " " << data[10]<< " " << data[11]; |  | ||||||
|  |  | ||||||
|             cycl_running=1;     // 1: start transmission |             cycl_running=1;     // 1: start transmission | ||||||
|             datif_kindOfCmd=2; |             datif_kindOfCmd=2; | ||||||
| @@ -322,7 +318,7 @@ char T_datif::datif_cycleSend() | |||||||
|             myDCIF->setUserReadData(nextRdCmd); |             myDCIF->setUserReadData(nextRdCmd); | ||||||
|             myDCIF->sendUserData(selectedSlaveAddr); |             myDCIF->sendUserData(selectedSlaveAddr); | ||||||
|  |  | ||||||
|    qDebug()<<"Datif send short FD cmd (wr/rd): "<<nextWrCmd<< " / " << nextRdCmd << "   "; |             //qDebug()<<"Datif send short FD cmd (wr/rd): "<<nextWrCmd<< " / " << nextRdCmd << "   " | ||||||
|             //        << blockNum << " " << dat1 << " " << dat2<< " " << dat3<< " " << dat4; |             //        << blockNum << " " << dat1 << " " << dat2<< " " << dat3<< " " << dat4; | ||||||
|  |  | ||||||
|             cycl_running=1;     // 1: start transmission |             cycl_running=1;     // 1: start transmission | ||||||
| @@ -359,7 +355,7 @@ char T_datif::datif_cycleSend() | |||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         dif_scanStep=0;         // always start from beginning |         dif_scanStep=0;         // always start from beginning | ||||||
|         epi_resetDcDataValid(4); |         gpi_storeDcDataValid(0); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     datif_cmdWasPerformed=0;    // 0: no response by now |     datif_cmdWasPerformed=0;    // 0: no response by now | ||||||
| @@ -372,20 +368,9 @@ char T_datif::datif_cycleSend() | |||||||
| char T_datif::sendINrequestsAutomatic(void) | char T_datif::sendINrequestsAutomatic(void) | ||||||
| { | { | ||||||
|     //qDebug() << "send IN request " << dif_scanStep; |     //qDebug() << "send IN request " << dif_scanStep; | ||||||
|     //uint8_t datif_autoRequCommandList[30]={11, 12, 14, 17, 18, 19, 22, 23, 27, 30, | //    uint8_t datif_autoRequCommandList[50]={11, 12, 18, 104, 106, 103, 14, 27, 109, 17, 19, 23, 30, 31, 32, 33, 114, 35}; | ||||||
|     //                                       31, 32, 33, 35, 102, 103, 104, 106, 107, 109, |     uint8_t datif_autoRequCommandList[30]={11, 12, 14, 17, 18, 19, 22, 23, 27, 30, 31, 32, 33, 35, 102, 103, 104, 106, 107, 109, 114,0,0,0,0,0,0,0,0,0}; | ||||||
|     //                                       114,0,0,0,0,0,0,0,0,0}; |     uint8_t datif_maxNrCommands=21, datif_sendNow; | ||||||
|  |  | ||||||
|     // extension 6.12.23, complete list: |  | ||||||
|     uint8_t datif_autoRequCommandList[40]={11, 12, 14, 17, 18, 19, 21, 22, 23, 24, |  | ||||||
|                                            25, 27, 30, 31, 32, 33, 34, 35, 39, 40, |  | ||||||
|                                            41, 42, 102,103,104,106,107,108,109,110, |  | ||||||
|                                            112,113,114,115,116,0,  0,  0, 0,  0}; |  | ||||||
|     uint8_t datif_maxNrCommands=35, datif_sendNow; |  | ||||||
|  |  | ||||||
|     // send quicker while transaction is ongoing: |  | ||||||
|     uint8_t datif_vendRequCommandList[15]={102,107,108,110,112,115,116,31,32,40,41,42,23,0,0}; |  | ||||||
|     uint8_t datif_maxVendingCmds=13; |  | ||||||
|  |  | ||||||
|     // special commands: |     // special commands: | ||||||
|     // 102: get IOs run constantly!!! |     // 102: get IOs run constantly!!! | ||||||
| @@ -394,46 +379,41 @@ char T_datif::sendINrequestsAutomatic(void) | |||||||
|     // 19:  get time and date and Extra values. poll occasionally and if needed |     // 19:  get time and date and Extra values. poll occasionally and if needed | ||||||
|     // 107, 22: MDB: poll if needed |     // 107, 22: MDB: poll if needed | ||||||
|  |  | ||||||
|     //doRepeat=true;  // 20.9.23 15uhr (after release) |     doRepeat=true;  // 20.9.23 15uhr (after release) | ||||||
|     doRepeat=false; // 3.7.24 off, is repeated cyclic anyway |     if (datif_sendSlowCmd>0) | ||||||
|  |  | ||||||
|     if (gpi_getNowCoinPay()) |  | ||||||
|     { |  | ||||||
|         // send only important commands while transaction in progress |  | ||||||
|         if (datif_pNextCmd>=datif_maxVendingCmds ) datif_pNextCmd=0; |  | ||||||
|         datif_sendNow=datif_vendRequCommandList[datif_pNextCmd++]; |  | ||||||
|         if (datif_sendNow>0)    // never send Command 0 |  | ||||||
|         { |  | ||||||
|             datif_sendIOrequest(0, datif_sendNow, 0); |  | ||||||
|             //qDebug() << "datif, VEND-request: " << datif_sendNow; |  | ||||||
|         } else |  | ||||||
|             datif_pNextCmd=0;       // falls in der Liste 0 vorkommt dann von vorne beginnen |  | ||||||
|  |  | ||||||
|     } else |  | ||||||
|     { |  | ||||||
|         // no transaction, request all but request DI's more frequently |  | ||||||
|         if (datif_sendSlowCmd>0)    // send slow and fast commands alternating |  | ||||||
|     { |     { | ||||||
|         // send special command, slowly |         // send special command, slowly | ||||||
|             if (datif_pNextCmd>=datif_maxNrCommands ) datif_pNextCmd=0; |  | ||||||
|         datif_sendNow=datif_autoRequCommandList[datif_pNextCmd++]; |         datif_sendNow=datif_autoRequCommandList[datif_pNextCmd++]; | ||||||
|  |         if (datif_pNextCmd >= datif_maxNrCommands) | ||||||
|  |             datif_pNextCmd=0; | ||||||
|         if (datif_sendNow>0)    // never send Command 0 |         if (datif_sendNow>0)    // never send Command 0 | ||||||
|             { |  | ||||||
|             datif_sendIOrequest(0, datif_sendNow, 0); |             datif_sendIOrequest(0, datif_sendNow, 0); | ||||||
|                // qDebug() << "datif, auto-requ: " << datif_sendNow; |         else | ||||||
|             } else |  | ||||||
|             datif_pNextCmd=0;       // falls in der Liste 0 vorkommt dann von vorne beginnen |             datif_pNextCmd=0;       // falls in der Liste 0 vorkommt dann von vorne beginnen | ||||||
|  |  | ||||||
|  |         //qDebug()<< "datif send request " << datif_sendNow; | ||||||
|  |  | ||||||
|  |     } else | ||||||
|  |     { | ||||||
|  |         if (gpi_getNowCoinPay()) | ||||||
|  |         { | ||||||
|  |             // request coin input, high priority | ||||||
|  |             datif_sendIOrequest(0, 112, 0); | ||||||
|  |             //qDebug()<< "datif send request 112 get coins"; | ||||||
|         } else |         } else | ||||||
|         { |         { | ||||||
|             // request inputs, high priority |             // request inputs, high priority | ||||||
|             datif_sendIOrequest(0, 31, 0);         // 102 |             datif_sendIOrequest(0, 31, 0);         // 102 | ||||||
|             // while coin collection DIs are polled slower |             // while coin collection DIs are polled slowly with datif_autoRequCommandList[] | ||||||
|             //qDebug()<< "datif send requ.31 get DIs"; |  | ||||||
|  |             //qDebug()<< "datif send request 102 get DIs"; | ||||||
|         } |         } | ||||||
|         if (++datif_sendSlowCmd>1) datif_sendSlowCmd=0;     // 0,1,0,1,0,1,0.... |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     if (++datif_sendSlowCmd>1) datif_sendSlowCmd=0;     // 0,1,0,1,0,1,0.... | ||||||
|  |  | ||||||
|     return 0;       // 25.9.2023, wichtig sonst bleibt die komplette PTU stehen!!!! |     return 0;       // 25.9.2023, wichtig sonst bleibt die komplette PTU stehen!!!! | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -477,7 +457,7 @@ char T_datif::loadRecDataFromFrame() | |||||||
|     uint32_t ultmp; |     uint32_t ultmp; | ||||||
|     //int portNr; |     //int portNr; | ||||||
|     bool ret; |     bool ret; | ||||||
|     uint8_t uctmp;  //, nn;  //, res;      // maxai |     uint8_t uctmp;  //, res;      // maxai | ||||||
|     char ctmp; |     char ctmp; | ||||||
|     //static uint8_t lastResult; |     //static uint8_t lastResult; | ||||||
|     //uint8_t prnResult; |     //uint8_t prnResult; | ||||||
| @@ -493,7 +473,7 @@ char T_datif::loadRecDataFromFrame() | |||||||
|     if (gpi_getNowIsBootload()) |     if (gpi_getNowIsBootload()) | ||||||
|     { |     { | ||||||
|         datif_cmdWasPerformed=1; |         datif_cmdWasPerformed=1; | ||||||
|         cycl_running=GOTRESP_SENDGAP;         // stop waiting for response and wait 1cycle till next sending |         cycl_running=100;         // stop waiting for response and wait 1cycle till next sending | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -519,11 +499,11 @@ char T_datif::loadRecDataFromFrame() | |||||||
|                 receivedData[12], receivedData[13], receivedData[14], receivedData[15]); |                 receivedData[12], receivedData[13], receivedData[14], receivedData[15]); | ||||||
|         */ |         */ | ||||||
|         datif_cmdWasPerformed=2;    //  NO :(( |         datif_cmdWasPerformed=2;    //  NO :(( | ||||||
|         cycl_running=GOTRESP_SENDGAP;         // stop waiting for response and wait 1cycle till next sending |         cycl_running=100;         // stop waiting for response and wait 1cycle till next sending | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|     datif_cmdWasPerformed=1;    // YES :), stop repeating |     datif_cmdWasPerformed=1;    // YES :), stop repeating | ||||||
|     cycl_running=GOTRESP_SENDGAP;             // stop waiting for response |     cycl_running=100;             // stop waiting for response | ||||||
|  |  | ||||||
|     //qDebug() << "datif: got valid response "; |     //qDebug() << "datif: got valid response "; | ||||||
|  |  | ||||||
| @@ -561,9 +541,6 @@ char T_datif::loadRecDataFromFrame() | |||||||
|         localStr.append(ctmp); |         localStr.append(ctmp); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (readSource==0) |  | ||||||
|         return 0;       // done |  | ||||||
|  |  | ||||||
|     //qDebug() << "got HW version: " << localStr; |     //qDebug() << "got HW version: " << localStr; | ||||||
|     switch (readSource) // = request command |     switch (readSource) // = request command | ||||||
|     { |     { | ||||||
| @@ -942,6 +919,22 @@ char T_datif::loadRecDataFromFrame() | |||||||
|         break; |         break; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // ab hier neu:    12.4.23 | ||||||
|  |  | ||||||
|     case CMD2DC_RDBK_DEV_PARA:      //14 |     case CMD2DC_RDBK_DEV_PARA:      //14 | ||||||
| /* | /* | ||||||
|             buf66[0]=devPara.kindOfPrinter; |             buf66[0]=devPara.kindOfPrinter; | ||||||
| @@ -992,24 +985,22 @@ char T_datif::loadRecDataFromFrame() | |||||||
|     case 112:       // get inserted amount in cent in sum |     case 112:       // get inserted amount in cent in sum | ||||||
|         // byte 0..3: amount just paid   4,5:last coin type  6,7: last coin value |         // byte 0..3: amount just paid   4,5:last coin type  6,7: last coin value | ||||||
|         newInsertedAmount=uchar2ulong(receivedData[3],receivedData[2],receivedData[1],receivedData[0]); |         newInsertedAmount=uchar2ulong(receivedData[3],receivedData[2],receivedData[1],receivedData[0]); | ||||||
|         uitmp=uchar2uint(receivedData[5],receivedData[4]);  // type of last coin |         uitmp=uchar2uint(receivedData[5],receivedData[4]); | ||||||
|         uit2=uchar2uint(receivedData[7],receivedData[6]);  //  value of last coin |         uit2=uchar2uint(receivedData[7],receivedData[6]); | ||||||
|         //if (uitmp>0) // nur 1x bei neuer Münze  6.10.23 aendern: |         //if (uitmp>0) // nur 1x bei neuer Münze  6.10.23 aendern: beim Wechsler hat die kleinste Muenze immer coin type 0! | ||||||
|                         // beim Wechsler hat die kleinste Muenze immer coin type 0! |         if (uit2>0) | ||||||
|         if (uitmp>10000 || uit2>10000) |  | ||||||
|         { |  | ||||||
|             uitmp=0; |  | ||||||
|             uit2=0; |  | ||||||
|         } |  | ||||||
|         if ((newInsertedAmount != lastInsertedAmount) || uit2>0 ) |  | ||||||
|         { |         { | ||||||
|             gpi_storeCurrentPayment(newInsertedAmount, uitmp, uit2); |             gpi_storeCurrentPayment(newInsertedAmount, uitmp, uit2); | ||||||
|             emit datif_gotNewCoin();    // OR BILL  if (uitmp & 0x8000)>0 |             //void gpi_storeCurrentPayment(uint32_t insertedAmount, uint16_t lastCoinType, uint16_t lastCoinValue) | ||||||
|  |             if (newInsertedAmount != lastInsertedAmount) | ||||||
|  |             { | ||||||
|  |                 emit datif_gotNewCoin(); | ||||||
|                 //qDebug()<<"emit new coin"; |                 //qDebug()<<"emit new coin"; | ||||||
|             lastInsertedAmount=newInsertedAmount; |  | ||||||
|             //qCritical()<<"datif 112 store and emit new coin "<<newInsertedAmount<<" "<<uitmp<<" "<<uit2; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|  |                 lastInsertedAmount=newInsertedAmount; | ||||||
|  |             } | ||||||
|  |               // qDebug()<<"datif   store new coin"<<newInsertedAmount<<" "<<uitmp<<" "<<uit2; | ||||||
|  |         } | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
|     case 113:       // get wake source, 8byte |     case 113:       // get wake source, 8byte | ||||||
| @@ -1039,19 +1030,29 @@ char T_datif::loadRecDataFromFrame() | |||||||
|         break; |         break; | ||||||
|  |  | ||||||
|     case 31:        // Get dynamic machine conditions (doors, voltage, alarm….) |     case 31:        // Get dynamic machine conditions (doors, voltage, alarm….) | ||||||
|                     // first 64 bytes, rest comes with cmd 34 |         if (RdDleng>50) | ||||||
|  |  | ||||||
|         if (RdDleng>60) |  | ||||||
|         { |         { | ||||||
|             epi_setDcDataValid();    // DC-Data are valid as DC responded. |             gpi_storeDcDataValid(1);    // DC-Data are valid as DC responded. | ||||||
|                                         // Could be set to every response but this (31) |                                         // Could be set to every response but this (31) | ||||||
|                                         // is a very common and very important request |                                         // is a very common and very important request | ||||||
|             gpi_storeDynMachineConditions(RdDleng, receivedData); |             gpi_storeDynMachineConditions(RdDleng, receivedData); | ||||||
|  |         } | ||||||
|             gpi_storeDI_CoinAttach(receivedData[6]);    // new, 14.2.24 needed for direct coin insertion |         /* funktioniert, ist aber nicht nötig. Signal wird nach dem shared memory erzeugt | ||||||
|  |         prnResult=receivedData[52]; | ||||||
|  |         if (prnResult != lastResult) | ||||||
|  |         { | ||||||
|  |             // new result | ||||||
|  |             if (prnResult==1) | ||||||
|  |             { | ||||||
|  |                 emit datif_templatePrintFinished_OK(); | ||||||
|             } else |             } else | ||||||
|             qDebug()<<"datif received cmd31 with "<<RdDleng<<" bytes only"; |             if (prnResult==2) | ||||||
|  |             { | ||||||
|  |                 emit datif_templatePrintFinished_Err(); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             lastResult=prnResult; | ||||||
|  |         }*/ | ||||||
|  |  | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
| @@ -1067,22 +1068,24 @@ char T_datif::loadRecDataFromFrame() | |||||||
|         gpi_storeDCbackupAccNr(RdDleng, receivedData); |         gpi_storeDCbackupAccNr(RdDleng, receivedData); | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
|     case 34:        // Get dynamic machine conditions part 2 |  | ||||||
|         if (RdDleng>5) |  | ||||||
|         { |  | ||||||
|             gpi_storeDynMachCond2(RdDleng, receivedData); |  | ||||||
|             //qDebug()<<"datif rec. cmd34: "; |  | ||||||
|             //for (int nn=0; nn<64; nn++) |  | ||||||
|              //   qDebug() << nn << " : " << receivedData[nn] << " "; |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         break; |  | ||||||
|  |  | ||||||
|     case 35: |     case 35: | ||||||
|         gpi_storeMifCardType(RdDleng, receivedData); |         gpi_storeMifCardType(RdDleng, receivedData); | ||||||
|         break; |         break; | ||||||
|     case 38:        // Get stored account record backup |     case 38:        // Get stored account record backup | ||||||
|  |         // readAddress,  &RdDleng, receivedData | ||||||
|  |         //if (RdDleng>50)       // 1.8.23 nach Verlängerung des Datensatzes um 20byte falsch!!! | ||||||
|  |         //{ | ||||||
|             gpi_storeVaultRecord(readAddress, receivedData );   // always/max 64byte |             gpi_storeVaultRecord(readAddress, receivedData );   // always/max 64byte | ||||||
|  | /* | ||||||
|  |             qDebug()<<"datif cmd38 got vault data. blockNr: "<<readAddress; | ||||||
|  |             if (readAddress==0) | ||||||
|  |             for (nn=0; nn<64; nn+=8) | ||||||
|  |             { | ||||||
|  |                 qDebug()<<receivedData[nn]<<" "<<receivedData[nn+1]<<" "<<receivedData[nn+2]<<" "<<receivedData[nn+3]<<" " | ||||||
|  |                          <<receivedData[nn+4]<<" "<<receivedData[nn+5]<<" "<<receivedData[nn+6]<<" "<<receivedData[nn+7]; | ||||||
|  |             } | ||||||
|  | */ | ||||||
|  |         //} | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
|     case 39: |     case 39: | ||||||
| @@ -1120,7 +1123,9 @@ char T_datif::loadRecDataFromFrame() | |||||||
|         break; |         break; | ||||||
|  |  | ||||||
|     case 42:        // get BNA box content and value of types |     case 42:        // get BNA box content and value of types | ||||||
|         //qDebug()<<  "CAslave datif_got 42"; | //        qDebug()<<  "CAmaster datif_got 42 "; | ||||||
|  | //        for (uctmp=0; uctmp<64; uctmp++) | ||||||
|  | //            qDebug()<<receivedData[uctmp]<<" "; | ||||||
|  |  | ||||||
|         if (RdDleng>60) |         if (RdDleng>60) | ||||||
|         { |         { | ||||||
| @@ -1128,9 +1133,6 @@ char T_datif::loadRecDataFromFrame() | |||||||
|         } |         } | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
|     default: |  | ||||||
|         qCritical()<<"datif, error received unknown cmd "<< readSource; |  | ||||||
|  |  | ||||||
|     } |     } | ||||||
|     readSource=0;   // 17.05.2023: to avoid multiple recording |     readSource=0;   // 17.05.2023: to avoid multiple recording | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										261
									
								
								src/hwapi.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										261
									
								
								src/hwapi.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -5,17 +5,27 @@ | |||||||
|  * This api uses stored data and returns them in the following functions |  * This api uses stored data and returns them in the following functions | ||||||
|  * created: Q1/2020 TS until Q2/21 |  * created: Q1/2020 TS until Q2/21 | ||||||
|  |  | ||||||
|  see history in hwapi.h | 14.7.23TS: patch for correct printer state in line 3364 in sys_getDeviceConditions(struct T_moduleCondition *devCond) const | ||||||
|  |  | ||||||
|  | 8.9.2023 two new functions (end of file) for mifare test. Interface version 4.4   DC4.40...4.43 | ||||||
|  |  | ||||||
|  | 14.09.2023: Verriegelung eingebaut, nur noch gültige Abr.Daten zurückgeben, Suchbegriff: <epi_restoreVaultRecord> | ||||||
|  |             alle Mifare-Funktionen ueberprueft und ggf verbessert | ||||||
|  |     18.09.2023: Signal "Kasse entnommen" und Signale "Tuer auf/zu" ueberprueft | ||||||
|  |  | ||||||
|  | 20.9.2023: in datif die Abfrage der DynMachineData massiv beschleunigt | ||||||
|  |             und hier in hwapi die entprellten Werte fuer Tueren und Kasse verwenden. | ||||||
|  |             Problem war: Signal "Kasse entnommen" war zu langsam -> manchmal abr nicht gesendet | ||||||
|  |  | ||||||
| */ | */ | ||||||
|  |  | ||||||
| #include "hwapi.h" | #include "hwapi.h" | ||||||
| #include "download_thread.h" |  | ||||||
| #include "reporting_thread.h" | #include "reporting_thread.h" | ||||||
|  | #include "download_thread.h" | ||||||
|  |  | ||||||
|  | #include <algorithm> | ||||||
| #include <cstring> | #include <cstring> | ||||||
| #include <QThread> | #include <atomic> | ||||||
| #include <QDebug> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| static uint32_t hwapi_lastStartAmount; | static uint32_t hwapi_lastStartAmount; | ||||||
| static uint32_t hwapi_lastTotalAmount; | static uint32_t hwapi_lastTotalAmount; | ||||||
| @@ -26,15 +36,9 @@ static uint8_t bl_startupStep; | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| hwapi::hwapi(QObject *parent) : QObject(parent) | hwapi::hwapi(QWidget *parent) : QObject(parent) | ||||||
| { | { | ||||||
|     // constructor |     // constructor | ||||||
|     qCritical() << "             hwapi::hwapi() APP_VERSION:" << APP_VERSION; |  | ||||||
|     qCritical() << "          hwapi::hwapi() APP_BUILD_DATE:" << APP_BUILD_DATE; |  | ||||||
|     qCritical() << "          hwapi::hwapi() APP_BUILD_TIME:" << APP_BUILD_TIME; |  | ||||||
|     qCritical() << "    hwapi::hwapi() APP_EXTENDED_VERSION:" << APP_EXTENDED_VERSION; |  | ||||||
|     qCritical() << "hwapi::hwapi() APP_EXTENDED_VERSION_LIB:" << APP_EXTENDED_VERSION_LIB; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     // create or attach shared memory segment |     // create or attach shared memory segment | ||||||
|     m_sharedMem = SharedMem::getShm(sizeof(SharedMem)); |     m_sharedMem = SharedMem::getShm(sizeof(SharedMem)); | ||||||
| @@ -51,21 +55,9 @@ hwapi::hwapi(QObject *parent) : QObject(parent) | |||||||
| //    { | //    { | ||||||
|  |  | ||||||
| #ifdef THIS_IS_CA_MASTER | #ifdef THIS_IS_CA_MASTER | ||||||
|  |         myDatif = new T_datif(this);    // für die  CAslave-Lib auskommentieren! | ||||||
| #ifdef THIS_IS_CA_SLAVE | #else | ||||||
| #error "SLAVE LIB COMPILED INTO MASTER" |     qCritical()<<"hwapi: error CAslave cannot include T_datif"; | ||||||
| #endif |  | ||||||
|  |  | ||||||
|         myDatif = new T_datif();    // für die  CAslave-Lib auskommentieren! |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifdef THIS_IS_CA_SLAVE |  | ||||||
|  |  | ||||||
| #ifdef THIS_IS_CA_MASTER |  | ||||||
| #error "MASTER LIB COMPILED INTO MASTER" |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //    } | //    } | ||||||
| @@ -117,11 +109,16 @@ hwapi::hwapi(QObject *parent) : QObject(parent) | |||||||
|     connect(runProcess, SIGNAL(runProc_doorCoinBoxInserted()),          this, SLOT(sub_slotCoin14())); // hwapi_doorCoinBoxInserted())); |     connect(runProcess, SIGNAL(runProc_doorCoinBoxInserted()),          this, SLOT(sub_slotCoin14())); // hwapi_doorCoinBoxInserted())); | ||||||
|     connect(runProcess, SIGNAL(runProc_doorCBinAndAllDoorsClosed()),    this, SLOT(sub_slotCoin15())); // hwapi_doorCBinAndAllDoorsClosed())); |     connect(runProcess, SIGNAL(runProc_doorCBinAndAllDoorsClosed()),    this, SLOT(sub_slotCoin15())); // hwapi_doorCBinAndAllDoorsClosed())); | ||||||
|     connect(runProcess, SIGNAL(runProc_doorAllDoorsClosed()),           this, SLOT(sub_slotCoin16())); // hwapi_doorAllDoorsClosed())); |     connect(runProcess, SIGNAL(runProc_doorAllDoorsClosed()),           this, SLOT(sub_slotCoin16())); // hwapi_doorAllDoorsClosed())); | ||||||
|     connect(runProcess, SIGNAL(runProc_coinAttached()),                 this, SLOT(coinAttached())); |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void hwapi::hwapi_slotPayProc(void) | void hwapi::hwapi_slotPayProc(void) | ||||||
| { | { | ||||||
|  |     //cash_paymentProcessing(); | ||||||
|  |     //doors_supervise(); | ||||||
|  |     //dcBL_cycle(); | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -215,9 +212,6 @@ void hwapi::sub_slotCoin16(void) | |||||||
|     emit hwapi_doorAllDoorsClosed(); |     emit hwapi_doorAllDoorsClosed(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void hwapi::coinAttached() { |  | ||||||
|     emit hwapi_coinAttached(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -1756,10 +1750,8 @@ QString hwapi::mif_getCardDataStr(uint8_t blockNumber) const | |||||||
|  |  | ||||||
| uint8_t hwapi::prn_getHwState(struct Tprn_hw_state *prn_hw_state) const | uint8_t hwapi::prn_getHwState(struct Tprn_hw_state *prn_hw_state) const | ||||||
| { | { | ||||||
|     // return value: |     // return printer hardware state: power is on? rs-driver on? rs_switch ok? hw-ready-line ok? | ||||||
|     //       0:   unknown           1: printer OK |     //        printer on error or ok? | ||||||
|     //       100: printer OK but paper near end |  | ||||||
|     //       200: not connected      201: printer on error     202: no paper |  | ||||||
|  |  | ||||||
|     return runProcess->prn_getHwState(prn_hw_state); |     return runProcess->prn_getHwState(prn_hw_state); | ||||||
|  |  | ||||||
| @@ -1767,8 +1759,13 @@ uint8_t hwapi::prn_getHwState(struct Tprn_hw_state *prn_hw_state) const | |||||||
|  |  | ||||||
| bool hwapi::prn_isUpAndReady(void) const | bool hwapi::prn_isUpAndReady(void) const | ||||||
| { | { | ||||||
|     // gefixt am 24.5.2024 |     // 25.5.2023: geht nicht richtig :(  bringt immer false obwohl Drucker OK | ||||||
|     return runProcess->prn_isUpAndReady(); |     struct Tprn_hw_state prnHwNow; | ||||||
|  |  | ||||||
|  |     prn_getHwState(&prnHwNow); | ||||||
|  |     if (prnHwNow.inIdle && prnHwNow.rsSwOk && prnHwNow.rsDrvOk && prnHwNow.powerRdBk ) | ||||||
|  |         return true; | ||||||
|  |     return false; | ||||||
| } | } | ||||||
|  |  | ||||||
| void hwapi::prn_getCurrentFontSetting(struct Tprn_currentSettings *prn_fonts) const | void hwapi::prn_getCurrentFontSetting(struct Tprn_currentSettings *prn_fonts) const | ||||||
| @@ -1792,10 +1789,44 @@ void hwapi::prn_getCurrentFontSetting(struct Tprn_currentSettings *prn_fonts) co | |||||||
|  |  | ||||||
| void hwapi::prn_sendText(QByteArray *buf) const | void hwapi::prn_sendText(QByteArray *buf) const | ||||||
| { | { | ||||||
|     runProcess->prn_sendText(buf); |     uint16_t nn, pp, mm, leng_byt, leng_blk, llb, freeStak; | ||||||
|     // 23.5.2024TS: moved function down to runProc in order to have it available there. |     uint8_t  tmp66[66]; | ||||||
|     // here in hwapi only a wrapper left |  | ||||||
|     // ( this also supports the idea to keep hwapi short :) |     epi_clearDynMachineConditions();    // 24.6.23 | ||||||
|  |     gpi_storeDcDataValid(0); | ||||||
|  |  | ||||||
|  |     // komplett aendern 11.9.23 | ||||||
|  |     memset(tmp66,0,66); | ||||||
|  |     leng_byt=buf->size(); | ||||||
|  |     freeStak=check4freeFDstack(); | ||||||
|  |     freeStak<<=6; | ||||||
|  |     if ( leng_byt > freeStak) | ||||||
|  |     { | ||||||
|  |         leng_byt=freeStak;      // shorten the buffer as we cannot return an error (void function) | ||||||
|  |     } | ||||||
|  |     llb=leng_byt % 64;      // length of last block, >0 if not dividable by 64 | ||||||
|  |     leng_blk=leng_byt / 64; | ||||||
|  |  | ||||||
|  |     pp=0; | ||||||
|  |     for (nn=0; nn<leng_blk; nn++) | ||||||
|  |     { | ||||||
|  |         for (mm=0; mm<64; mm++) | ||||||
|  |             tmp66[mm]=buf->at(pp++); | ||||||
|  |         longFDcmd_set(CMD2DC_PRI_PRINT_TXT, 0,0,64, tmp66); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (llb>0) | ||||||
|  |     { | ||||||
|  |  | ||||||
|  |         //leng_blk++;         // z.B. 200 = 3 volle blocks und ein block mit nur 8byte | ||||||
|  |         memset(tmp66,0,66); | ||||||
|  |         for (mm=0; mm<llb; mm++) | ||||||
|  |             tmp66[mm]=buf->at(pp++); | ||||||
|  |         for (mm=llb; mm<64; mm++) | ||||||
|  |             tmp66[mm]=0; | ||||||
|  |         longFDcmd_set(CMD2DC_PRI_PRINT_TXT, 0,0,64, tmp66); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1804,8 +1835,6 @@ void hwapi::prn_sendPrnSysCmd(uint8_t para1, uint8_t para2, uint32_t para3) cons | |||||||
|     // send three byte through to printer, see printers manual |     // send three byte through to printer, see printers manual | ||||||
|     //sendWRcmd _setSendCommand8(SENDDIRCMD_PRN_SYS_CMD, para1, para2, 0, para3); hat gar nicht funktioniert |     //sendWRcmd _setSendCommand8(SENDDIRCMD_PRN_SYS_CMD, para1, para2, 0, para3); hat gar nicht funktioniert | ||||||
|  |  | ||||||
|     runProcess->prn_sendPrnSysCmd(para1, para2, para3); |  | ||||||
|     /* |  | ||||||
|     uint8_t data[64]; |     uint8_t data[64]; | ||||||
|     uint32_t ultmp=para3; |     uint32_t ultmp=para3; | ||||||
|     memset(data, 0,64); |     memset(data, 0,64); | ||||||
| @@ -1819,7 +1848,6 @@ void hwapi::prn_sendPrnSysCmd(uint8_t para1, uint8_t para2, uint32_t para3) cons | |||||||
|     data[7]=uint8_t(ultmp); |     data[7]=uint8_t(ultmp); | ||||||
|  |  | ||||||
|     longFDcmd_set(CMD2DC_PRI_SYS_CMD, 0, 0, 8, data); |     longFDcmd_set(CMD2DC_PRI_SYS_CMD, 0, 0, 8, data); | ||||||
|     */ |  | ||||||
| // getestet auf richtige uebertragung  am 11.9.23TS | // getestet auf richtige uebertragung  am 11.9.23TS | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -1837,7 +1865,7 @@ void hwapi::prn_sendPrnSetup(uint16_t paperSpeed, uint8_t density,  uint8_t alig | |||||||
|     //              byte3: alignment    'l', 'c', 'r' = left, center, right |     //              byte3: alignment    'l', 'c', 'r' = left, center, right | ||||||
|     //              byte4: orientation  0, 90, 180    = 0°, 90°, 180° rotation (by now not supported!) |     //              byte4: orientation  0, 90, 180    = 0°, 90°, 180° rotation (by now not supported!) | ||||||
|     // not batched! don't use twice within 100ms |     // not batched! don't use twice within 100ms | ||||||
| /* |  | ||||||
|     uint8_t buf[10]; |     uint8_t buf[10]; | ||||||
|     uint16_t uitmp; |     uint16_t uitmp; | ||||||
|  |  | ||||||
| @@ -1850,8 +1878,7 @@ void hwapi::prn_sendPrnSetup(uint16_t paperSpeed, uint8_t density,  uint8_t alig | |||||||
|     buf[4]=orientation; |     buf[4]=orientation; | ||||||
|     buf[5]=0; |     buf[5]=0; | ||||||
|     longFDcmd_set(CMD2DC_PRI_SETUP,0,0,5, buf); |     longFDcmd_set(CMD2DC_PRI_SETUP,0,0,5, buf); | ||||||
| */ |  | ||||||
|     runProcess->prn_sendPrnSetup(paperSpeed, density,  alignment, orientation); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void hwapi::prn_movePaper(uint8_t wayInMm, uint8_t direction) const | void hwapi::prn_movePaper(uint8_t wayInMm, uint8_t direction) const | ||||||
| @@ -2757,7 +2784,6 @@ bool hwapi::rtc_getExtendedTime(struct T_extTime *exTime) const | |||||||
|     epi_restoreExtendedTime(&len, buf); |     epi_restoreExtendedTime(&len, buf); | ||||||
|         // Puffer in struct eintragen: |         // Puffer in struct eintragen: | ||||||
|     LL=sizeof(struct T_extTime); |     LL=sizeof(struct T_extTime); | ||||||
|     if (LL>64) LL=64; |  | ||||||
|     start = &(exTime->Hours); |     start = &(exTime->Hours); | ||||||
|     nn=0; |     nn=0; | ||||||
|     do |     do | ||||||
| @@ -2870,8 +2896,6 @@ bool hwapi::prn_printTemplate(uint8_t nrOftemplate) const | |||||||
| { | { | ||||||
|     // return true if sending, false if cmd-stack is full |     // return true if sending, false if cmd-stack is full | ||||||
|  |  | ||||||
|     qCritical() << __PRETTY_FUNCTION__ << "RESET DC DATA VALID"; |  | ||||||
|  |  | ||||||
|     epi_clearDynMachineConditions();    // 24.6.23 |     epi_clearDynMachineConditions();    // 24.6.23 | ||||||
|     gpi_storeDcDataValid(0); |     gpi_storeDcDataValid(0); | ||||||
|  |  | ||||||
| @@ -2976,8 +3000,6 @@ bool hwapi::log_getVaultRecord(struct T_vaultRecord *retVR) const | |||||||
|  |  | ||||||
| bool hwapi::prn_printAccountReceipt(void) const | bool hwapi::prn_printAccountReceipt(void) const | ||||||
| { | { | ||||||
|     qCritical() << __PRETTY_FUNCTION__ << "RESET DC DATA VALID"; |  | ||||||
|  |  | ||||||
|     epi_clearDynMachineConditions();    // 24.6.23 |     epi_clearDynMachineConditions();    // 24.6.23 | ||||||
|     gpi_storeDcDataValid(0); |     gpi_storeDcDataValid(0); | ||||||
|     return sendFDcmd_set(154, 0,0, 0,0,0,0); |     return sendFDcmd_set(154, 0,0, 0,0,0,0); | ||||||
| @@ -2985,8 +3007,6 @@ bool hwapi::prn_printAccountReceipt(void) const | |||||||
|  |  | ||||||
| bool hwapi::prn_printTestTicket(void) const | bool hwapi::prn_printTestTicket(void) const | ||||||
| { | { | ||||||
|     qCritical() << __PRETTY_FUNCTION__ << "RESET DC DATA VALID"; |  | ||||||
|  |  | ||||||
|     // return true if sending to DC OK, false if cmd-stack is full |     // return true if sending to DC OK, false if cmd-stack is full | ||||||
|     epi_clearDynMachineConditions();    // 24.6.23 |     epi_clearDynMachineConditions();    // 24.6.23 | ||||||
|     gpi_storeDcDataValid(0); |     gpi_storeDcDataValid(0); | ||||||
| @@ -3042,9 +3062,7 @@ bool hwapi::cash_cancelPayment(void) const | |||||||
| { | { | ||||||
|     // DB1: 1=encash    2=cancel & return coins |     // DB1: 1=encash    2=cancel & return coins | ||||||
|     //      3=stop and keep coins in escrow |     //      3=stop and keep coins in escrow | ||||||
|     //epi_setNowCoinPay(false);    // new since 20.9.23 |     epi_setNowCoinPay(false);    // new since 20.9.23 | ||||||
|     // am 6.12.23 wieder raus, waehrend Druck und wechseln auch schnell abfragen |  | ||||||
|  |  | ||||||
|     //qCritical() << "cash cancel payment and return coins"; |     //qCritical() << "cash cancel payment and return coins"; | ||||||
|     return sendFDcmd_set(156, 0,0, 2,0,0,0); |     return sendFDcmd_set(156, 0,0, 2,0,0,0); | ||||||
| } | } | ||||||
| @@ -3054,8 +3072,7 @@ bool hwapi::cash_stopPayment(void) const | |||||||
| { | { | ||||||
|     // DB1: 1=encash    2=cancel & return coins |     // DB1: 1=encash    2=cancel & return coins | ||||||
|     //      3=stop and keep coins in escrow |     //      3=stop and keep coins in escrow | ||||||
|     //epi_setNowCoinPay(false);    // new since 20.9.23 |     epi_setNowCoinPay(false);    // new since 20.9.23 | ||||||
|                                    // am 6.12.23 wieder raus, waehrend Druck und wechseln auch schnell abfragen |  | ||||||
|     //qCritical() << "cash stop payment and keep coins in escrow"; |     //qCritical() << "cash stop payment and keep coins in escrow"; | ||||||
|    // qCritical() << "emitting signal StopByPushbutton 2"; |    // qCritical() << "emitting signal StopByPushbutton 2"; | ||||||
|     emit hwapi_payStopByPushbutton(); |     emit hwapi_payStopByPushbutton(); | ||||||
| @@ -3138,11 +3155,10 @@ void hwapi::sys_getDeviceConditions(struct T_moduleCondition *devCond) const | |||||||
|     uint8_t *start; |     uint8_t *start; | ||||||
|     uint8_t  buf[70], leng; |     uint8_t  buf[70], leng; | ||||||
|  |  | ||||||
|     epi_restoreDeviceConditions(&leng, buf);    // leng is less then 64 |     epi_restoreDeviceConditions(&leng, buf); | ||||||
|  |  | ||||||
|         // Puffer in struct eintragen: |         // Puffer in struct eintragen: | ||||||
|     LL=sizeof(struct T_moduleCondition); |     LL=sizeof(struct T_moduleCondition); | ||||||
|     if (LL>64) LL=64; |  | ||||||
|     start = &devCond->ram; |     start = &devCond->ram; | ||||||
|     nn=0; |     nn=0; | ||||||
|     do |     do | ||||||
| @@ -3184,27 +3200,26 @@ void hwapi::sys_getDeviceConditions(struct T_moduleCondition *devCond) const | |||||||
|  |  | ||||||
| void hwapi::sys_getDynMachineConditions(uint8_t *leng, uint8_t *data) const | void hwapi::sys_getDynMachineConditions(uint8_t *leng, uint8_t *data) const | ||||||
| { | { | ||||||
|     // not complete anymore |  | ||||||
|     epi_restoreDynMachineConditions(leng, data); |     epi_restoreDynMachineConditions(leng, data); | ||||||
| } | } | ||||||
|  |  | ||||||
| void hwapi::sys_getDynMachineConditions(struct T_dynamicCondition *dynMachCond) const | void hwapi::sys_getDynMachineConditions(struct T_dynamicCondition *dynMachCond) const | ||||||
| { | { | ||||||
|     uint8_t  buf[130], leng; |  | ||||||
|  |     uint16_t LL, nn; | ||||||
|  |     char *start; | ||||||
|  |     uint8_t  buf[70], leng; | ||||||
|  |  | ||||||
|     epi_restoreDynMachineConditions(&leng, buf); |     epi_restoreDynMachineConditions(&leng, buf); | ||||||
|     memcpy(dynMachCond, buf, sizeof(*dynMachCond)); // copy 64byte to the struct |         // Puffer in struct eintragen: | ||||||
|         // 3.7.24: stimmt nicht mehr weil struct im Ram die word grenzen einhaelt |     LL=sizeof(struct T_dynamicCondition); | ||||||
|         // also ab hier einzeln uebertragen |     start = &dynMachCond->allDoorsDebounced; | ||||||
|     dynMachCond->totalNrOfCuts = uchar2ulong(buf[57],buf[56],buf[55],buf[54]); |     nn=0; | ||||||
|     dynMachCond->nextAccountNumber = uchar2uint(buf[59], buf[58]); |     do | ||||||
|     dynMachCond->nrOfBillsInBox = uchar2uint(buf[61], buf[60]); |     { | ||||||
|  |         *start = buf[nn]; | ||||||
|     // 8.5.24TS, as the DC struct is >64byte now, it comes in two parts: |         start++; | ||||||
|     epi_restoreDynMachCond2(&leng, buf); |     } while(++nn<LL); | ||||||
|     dynMachCond->amountInBillbox = uchar2ulong(buf[3], buf[2],buf[1],buf[0]); |  | ||||||
|     dynMachCond->UbatAtLastPrint = uchar2uint(buf[5], buf[4]); |  | ||||||
|     memcpy(&dynMachCond->reserve01, &buf[8], 56); // rest reserve |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -3288,15 +3303,25 @@ void hwapi::sys_sendDeviceParameter(struct T_devices *deviceSettings) const | |||||||
|  |  | ||||||
| void hwapi::sys_restoreDeviceParameter(struct T_devices *deviceSettings) const | void hwapi::sys_restoreDeviceParameter(struct T_devices *deviceSettings) const | ||||||
| { | { | ||||||
|  |     // attention: only applies if function "sys_sendDeviceParameter()" was used to send this settings before | ||||||
|  |     //          cannot be used to see settings programmed by JsonFile | ||||||
|     uint8_t buf[64]; |     uint8_t buf[64]; | ||||||
|     uint8_t LL; |     uint8_t LL, nn; | ||||||
|     tslib_strclr(buf,0,64); |     tslib_strclr(buf,0,64); | ||||||
|  |     uint8_t *start; | ||||||
|  |  | ||||||
|     epi_restoreRbDeviceSettings(&LL, buf); |     //runProcess->epi_restore64BdevParameter(&LL, buf); // wozu die??? | ||||||
|  |     epi_restoreRbDeviceSettings(&LL, buf);      // viel besser, stimmt immer | ||||||
|  |  | ||||||
|     Q_STATIC_ASSERT(sizeof(*deviceSettings) <= sizeof(buf)); |     // Puffer in struct eintragen: | ||||||
|  |     start = &deviceSettings->kindOfPrinter; | ||||||
|  |     nn=0; | ||||||
|  |     do | ||||||
|  |     { | ||||||
|  |         *start = buf[nn]; | ||||||
|  |         start++; | ||||||
|  |     } while(++nn<LL); | ||||||
|  |  | ||||||
|     memcpy(deviceSettings, buf, sizeof(*deviceSettings)); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| bool hwapi::sys_areDCdataValid(void) const | bool hwapi::sys_areDCdataValid(void) const | ||||||
| @@ -3367,7 +3392,6 @@ void hwapi::prn_requestCurrentDynData(void) const | |||||||
| { | { | ||||||
|     sendFDcmd_set(0,39,0,0,0,0,0);    // rd data dynData |     sendFDcmd_set(0,39,0,0,0,0,0);    // rd data dynData | ||||||
|     epi_clearDynData(); |     epi_clearDynData(); | ||||||
|     epi_clearDynMachCond2(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| bool hwapi::prn_getCurrentDynamicPrnValuesFromDC(uint8_t *dynPrnVal ) const | bool hwapi::prn_getCurrentDynamicPrnValuesFromDC(uint8_t *dynPrnVal ) const | ||||||
| @@ -3409,8 +3433,6 @@ bool hwapi::prn_printKombiticket(uint8_t nrOfKombi) const | |||||||
|     if ((nrOfKombi<1) || (nrOfKombi>8)) |     if ((nrOfKombi<1) || (nrOfKombi>8)) | ||||||
|         return false; |         return false; | ||||||
|  |  | ||||||
|     qCritical() << __PRETTY_FUNCTION__ << "RESET DC DATA VALID"; |  | ||||||
|  |  | ||||||
|     epi_clearDynMachineConditions();    // 24.6.23 |     epi_clearDynMachineConditions();    // 24.6.23 | ||||||
|     gpi_storeDcDataValid(0); |     gpi_storeDcDataValid(0); | ||||||
|  |  | ||||||
| @@ -3541,8 +3563,6 @@ bool hwapi::log_getVaultData(uint8_t *data) const | |||||||
| // new from 1.8.23 | // new from 1.8.23 | ||||||
| bool hwapi::prn_printOneAccountReceipt(uint16_t accountNr) const | bool hwapi::prn_printOneAccountReceipt(uint16_t accountNr) const | ||||||
| { | { | ||||||
|     qCritical() << __PRETTY_FUNCTION__ << "RESET DC DATA VALID"; |  | ||||||
|  |  | ||||||
|     // print one out of eight stored last accounting receipts |     // print one out of eight stored last accounting receipts | ||||||
|     // function log_getHoldAccountNumbers() gives a list of acc-Nr. of the stored receipts |     // function log_getHoldAccountNumbers() gives a list of acc-Nr. of the stored receipts | ||||||
|     epi_clearDynMachineConditions();    // 24.6.23 |     epi_clearDynMachineConditions();    // 24.6.23 | ||||||
| @@ -4047,8 +4067,8 @@ int8_t hwapi::bl_blockAutoResponse(void) const | |||||||
| void hwapi::sys_requestJsonVersions(uint8_t  jsonNr) const | void hwapi::sys_requestJsonVersions(uint8_t  jsonNr) const | ||||||
| { | { | ||||||
|     // send one request for every single version |     // send one request for every single version | ||||||
|     // jsonNr=1...36, 1=config file (cust.Nr) 2=devices  3=cash  4,5=empty |     // jsonNr=1...36, 1=config file (cust.Nr) 2=devices  3=cash  4=res. | ||||||
|     //      6=printer template 1 ..... 37= template 32 |     //      5=printer template 1 ..... 36= template 32 | ||||||
|     sendFDcmd_set(0, 21, jsonNr,0,0,0,0); |     sendFDcmd_set(0, 21, jsonNr,0,0,0,0); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -4253,7 +4273,7 @@ bool hwapi::bna_getAllParameters(struct T_bna *bna) const | |||||||
|     bna->intendedAccept = uchar2uint(buf[31], buf[30]); |     bna->intendedAccept = uchar2uint(buf[31], buf[30]); | ||||||
|     bna->pad2=0; |     bna->pad2=0; | ||||||
|     pp=32; |     pp=32; | ||||||
|     for (nn=0; nn<8; nn++)  // was 16!!! // 8.5.24 reduced |     for (nn=0; nn<16; nn++) | ||||||
|     { |     { | ||||||
|         bna->billDenomination[nn] = uchar2uint(buf[pp+1], buf[pp]); |         bna->billDenomination[nn] = uchar2uint(buf[pp+1], buf[pp]); | ||||||
|        pp+=2; |        pp+=2; | ||||||
| @@ -4357,17 +4377,6 @@ uint16_t hwapi::bna_getStackerLevel(uint32_t *amountInStacker, uint16_t *countOf | |||||||
|     return anzahl; |     return anzahl; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // new, 14.3.24TS |  | ||||||
| bool hwapi::cash_isCollectionStarted(void) const |  | ||||||
| { |  | ||||||
|     struct T_dynamicCondition myDynMachCond; |  | ||||||
|     sys_getDynMachineConditions(&myDynMachCond); |  | ||||||
|     if (myDynMachCond.paymentInProgress >=2) |  | ||||||
|         return true; |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| QObject const *hwapi::getAPI() { | QObject const *hwapi::getAPI() { | ||||||
|     return this; |     return this; | ||||||
| } | } | ||||||
| @@ -4624,61 +4633,7 @@ bool hwapi::dcDownloadGetRunning() const { | |||||||
|     return data ? data->m_downLoadDC.m_running.load() : 0; |     return data ? data->m_downLoadDC.m_running.load() : 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadGetFinished() const | bool hwapi::dcDownloadGetFinished() const { | ||||||
| { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |     SharedMem const *data = SharedMem::getDataConst(); | ||||||
|     return data ? data->m_downLoadDC.m_running.load() : 0; |     return data ? data->m_downLoadDC.m_running.load() : 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| //uint16_t dcDownloadGetTotalBlockNumber() const override; |  | ||||||
| //uint16_t dcDownloadGetCurrentBlockNumber() const override; |  | ||||||
| //virtual QObject const *getAPI() override; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void hwapi::mod_switchResetline(void) |  | ||||||
| { |  | ||||||
|     sendFDcmd_set(171,0,0, 2,0,0,0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| // new from 22.5.2024, print Json-Printer-Template which |  | ||||||
| // is stored locally here in PTU memory, |  | ||||||
| // rather then loading several jsons to DC and tell it to print (until now) |  | ||||||
| // the local printer-json can have any length using predefined commands |  | ||||||
| // printing a local printer-json happens like this: |  | ||||||
| // 1) select a file to be printed from memory |  | ||||||
| // 2) load, parse, translate and save the file with following function |  | ||||||
| // 3) set dynamics (values from current transaction) |  | ||||||
| // 4) send saved file to printer one or several times |  | ||||||
| // hint: dynamics can be changed at any time without reloading the ticket, just repeat 3) and 4) |  | ||||||
|  |  | ||||||
| void hwapi::prn_translateLocalPrinterJson(QByteArray jsonFile2print) const |  | ||||||
| { |  | ||||||
|     runProcess->sys_parseFile( jsonFile2print); |  | ||||||
|     runProcess->sys_translateKeys(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void hwapi::prnStoreDynamics(char *bufferDynPrintVars[], uint8_t nrOfDyns) const |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     runProcess->prnStoreDynamics(bufferDynPrintVars, nrOfDyns); |  | ||||||
|     // store nrOfDyns (up to 16) dynamics before printing |  | ||||||
|     // max length = 16 byte per dynamic |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void hwapi::prn_printTranslatedTicket(void) const |  | ||||||
| { |  | ||||||
|     runProcess->prnStartDirectPrinting(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| uint8_t hwapi::prn_waitForDirectTicket(void) const |  | ||||||
| { |  | ||||||
|     return runProcess->prn_getDirectPrintResult(); |  | ||||||
|         // return:  0: just printing, wait |  | ||||||
|         //          1: OK - last print was succesful |  | ||||||
|         //          2: error - not printed |  | ||||||
|         //              2: printer error  3: no connection to DC |  | ||||||
|  |  | ||||||
| } |  | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								src/main.cpp
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								src/main.cpp
									
									
									
									
									
								
							| @@ -1,16 +1,5 @@ | |||||||
| #ifdef WIN32 |  | ||||||
|  |  | ||||||
| #include <QCoreApplication> | #ifndef WIN32 | ||||||
| #include "tslib.h" |  | ||||||
|  |  | ||||||
| int main(int argc, char *argv[]) |  | ||||||
| { |  | ||||||
|     QCoreApplication a(argc, argv); |  | ||||||
|  |  | ||||||
|     return a.exec(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| #undef _FORTIFY_SOURCE | #undef _FORTIFY_SOURCE | ||||||
|  |  | ||||||
| @@ -18,11 +7,11 @@ int main(int argc, char *argv[]) | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  |  | ||||||
| // Must define the interpreter to be the dynamic linker | // Must define the interpreter to be the dynamic linker | ||||||
| //#ifdef __LP64__ | #ifdef __LP64__ | ||||||
| //#error "__LP64__ not defined for PTU5" | #error "__LP64__ not defined for PTU5" | ||||||
| //#else | #else | ||||||
| //const char service_interp[] __attribute__((section(".interp"))) = "/lib/ld-linux-armhf.so.3"; | const char service_interp[] __attribute__((section(".interp"))) = "/lib/ld-linux-armhf.so.3"; | ||||||
| //#endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| int main(int argc, char *argv[]) { | int main(int argc, char *argv[]) { | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								src/prot.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										10
									
								
								src/prot.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -97,22 +97,14 @@ void T_prot::setRecLen(uint16_t ReadCmd) | |||||||
|  |  | ||||||
| void T_prot::setUserWriteData(uint16_t WriteCmd, uint16_t WrAddr, uint8_t  WrDatLen, uint8_t *data) | void T_prot::setUserWriteData(uint16_t WriteCmd, uint16_t WrAddr, uint8_t  WrDatLen, uint8_t *data) | ||||||
| { | { | ||||||
|     int nn; |  | ||||||
|     WriteCommand=WriteCmd; |     WriteCommand=WriteCmd; | ||||||
|     WriteAddr=WrAddr; |     WriteAddr=WrAddr; | ||||||
|     WrDataLength=WrDatLen; |     WrDataLength=WrDatLen; | ||||||
|     if (WrDataLength>FRAME_DATALEN) |     if (WrDataLength>FRAME_DATALEN) | ||||||
|         WrDataLength=FRAME_DATALEN; |         WrDataLength=FRAME_DATALEN; | ||||||
|  |  | ||||||
|     // ui8BLsendData[BL_DATA_LEN]; |     for (int nn=0; nn<WrDataLength; nn++) | ||||||
|  |  | ||||||
|     for (nn=0; nn<WrDataLength; nn++) |  | ||||||
|         ui8OutputData[nn]=data[nn]; |         ui8OutputData[nn]=data[nn]; | ||||||
|  |  | ||||||
|     // clear the rest. added at 26.6.2024TS. important for printer text |  | ||||||
|     for (nn=WrDataLength; nn<FRAME_DATALEN; nn++) |  | ||||||
|         ui8OutputData[nn]=0; |  | ||||||
|  |  | ||||||
|     SendDataValid=1;    // always set WR first |     SendDataValid=1;    // always set WR first | ||||||
|     kindOfData=0;    // 0: binaries, 1:text |     kindOfData=0;    // 0: binaries, 1:text | ||||||
|     this->setRecLen(100);   // default: short response |     this->setRecLen(100);   // default: short response | ||||||
|   | |||||||
							
								
								
									
										1817
									
								
								src/runProc.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										1817
									
								
								src/runProc.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										6
									
								
								src/sendWRcmd.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										6
									
								
								src/sendWRcmd.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -19,11 +19,7 @@ void sendWRcmd_INI(void) | |||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| uint8_t sendWRcmd_getStackSize(void) | // Command Stack for commands without parameters | ||||||
| { |  | ||||||
|     return CMDSTACKDEPTH;       // defined in shared_mem_buffer.h |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| //static uint16_t nextAsynchsendCmd0[CMDSTACKDEPTH]; | //static uint16_t nextAsynchsendCmd0[CMDSTACKDEPTH]; | ||||||
|   | |||||||
							
								
								
									
										122
									
								
								src/storeINdata.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										122
									
								
								src/storeINdata.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -9,7 +9,6 @@ | |||||||
| // gpi: grafical access to PI: access from external devices over device controller FOR GUI | // gpi: grafical access to PI: access from external devices over device controller FOR GUI | ||||||
| // epi: external access from GUI to PI:  FOR external devices (DC) | // epi: external access from GUI to PI:  FOR external devices (DC) | ||||||
|  |  | ||||||
| // Change log: 8.5.24TS: clear all oversize buffers (if only 32 of 64bytes are used then fill the rest with 0) |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1002,8 +1001,6 @@ bool epi_getDI_auxPwr(void) | |||||||
| void gpi_storeDI_GsmPowerIsOn(bool di_gsm_PwrOn) | void gpi_storeDI_GsmPowerIsOn(bool di_gsm_PwrOn) | ||||||
| { | { | ||||||
|     SharedMem::write()->di_gsmPwrOn=di_gsm_PwrOn; |     SharedMem::write()->di_gsmPwrOn=di_gsm_PwrOn; | ||||||
|     //qDebug()<<"store In Data Gsm Pwr = "<< di_gsm_PwrOn; |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| bool epi_getDI_gsmPwr(void) | bool epi_getDI_gsmPwr(void) | ||||||
| @@ -1543,8 +1540,6 @@ void gpi_storeMdbResponse(uint8_t leng, uint8_t *data) | |||||||
|     //tslib_strcpy(data, SharedMem::write()->Sdata_RecBuff, uint16_t(Sdata_mdbNrOfRecData)); |     //tslib_strcpy(data, SharedMem::write()->Sdata_RecBuff, uint16_t(Sdata_mdbNrOfRecData)); | ||||||
|     for (nn=0; nn<leng; nn++) |     for (nn=0; nn<leng; nn++) | ||||||
|         SharedMem::write()->Sdata_RecBuff[nn] = data[nn]; |         SharedMem::write()->Sdata_RecBuff[nn] = data[nn]; | ||||||
|     for (nn=leng; nn<40; nn++) |  | ||||||
|         SharedMem::write()->Sdata_RecBuff[nn] = 0; |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1571,8 +1566,6 @@ void gpi_storeEmpSettings(uint8_t leng, uint8_t *data) | |||||||
|     //tslib_strcpy(data, SharedMem::write()->Sdata_emp_settingsBuff, leng); |     //tslib_strcpy(data, SharedMem::write()->Sdata_emp_settingsBuff, leng); | ||||||
|     for (nn=0; nn<leng; nn++) |     for (nn=0; nn<leng; nn++) | ||||||
|         SharedMem::write()->Sdata_emp_settingsBuff[nn] = data[nn]; |         SharedMem::write()->Sdata_emp_settingsBuff[nn] = data[nn]; | ||||||
|     for (nn=leng; nn<64; nn++) |  | ||||||
|         SharedMem::write()->Sdata_emp_settingsBuff[nn] = 0; |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1678,9 +1671,6 @@ void gpi_storeRbDeviceSettings(uint8_t leng, uint8_t *data)       // getestet am | |||||||
|     //tslib_strcpy(data, SharedMem::write()->Sdata_DeviceSettingBuff, leng); |     //tslib_strcpy(data, SharedMem::write()->Sdata_DeviceSettingBuff, leng); | ||||||
|     for (nn=0; nn<leng; nn++) |     for (nn=0; nn<leng; nn++) | ||||||
|         SharedMem::write()->Sdata_DeviceSettingBuff[nn] = data[nn]; |         SharedMem::write()->Sdata_DeviceSettingBuff[nn] = data[nn]; | ||||||
|     for (nn=leng; nn<64; nn++) |  | ||||||
|         SharedMem::write()->Sdata_DeviceSettingBuff[nn] = 0; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1782,25 +1772,15 @@ void epi_clearCurrentPayment(void) | |||||||
|  |  | ||||||
| void gpi_storeCurrentPayment(uint32_t insertedAmount, uint16_t lastCoinType, uint16_t lastCoinValue) | void gpi_storeCurrentPayment(uint32_t insertedAmount, uint16_t lastCoinType, uint16_t lastCoinValue) | ||||||
| { | { | ||||||
|     uint8_t pLC; |     uint8_t pLC=SharedMem::read()->p_lastCoin; | ||||||
|  |  | ||||||
|     // 21.3.24 attention: if bit 15 in lastCoinType is set then we got a bill not a coin |  | ||||||
|     SharedMem::write()->store_insertedAmount=insertedAmount; |     SharedMem::write()->store_insertedAmount=insertedAmount; | ||||||
|     if (lastCoinType & 0x8000) |  | ||||||
|     { |  | ||||||
|         // then it's a banknote |  | ||||||
|         //qCritical()<<"gpi_storeCurrentPayment got banknote, total: "<<insertedAmount; |  | ||||||
|     } else |  | ||||||
|     { |  | ||||||
|         //qCritical()<<"gpi_storeCurrentPayment "<<insertedAmount<<" " << lastCoinType<<" " << lastCoinValue; |  | ||||||
|         pLC=SharedMem::read()->p_lastCoin; |  | ||||||
|     SharedMem::write()->store_lastCoinType[pLC]=lastCoinType; |     SharedMem::write()->store_lastCoinType[pLC]=lastCoinType; | ||||||
|     SharedMem::write()->store_lastCoinValue[pLC]=lastCoinValue; |     SharedMem::write()->store_lastCoinValue[pLC]=lastCoinValue; | ||||||
|     pLC++; |     pLC++; | ||||||
|     SharedMem::write()->p_lastCoin=pLC; |     SharedMem::write()->p_lastCoin=pLC; | ||||||
|     SharedMem::write()->store_curPayNewCoin++; |     SharedMem::write()->store_curPayNewCoin++; | ||||||
|     } |  | ||||||
|  |  | ||||||
|  |     //qDebug()<<"gpi_storeCurrentPayment "<<insertedAmount<<" " << lastCoinType<<" " << lastCoinValue; | ||||||
| } | } | ||||||
|  |  | ||||||
| uint32_t epi_CurrentPaymentGetAmount(void) | uint32_t epi_CurrentPaymentGetAmount(void) | ||||||
| @@ -1838,13 +1818,6 @@ bool epi_CurrentPaymentGetAllCoins(uint16_t *types, uint16_t *values) | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* |  | ||||||
| int nn; |  | ||||||
| for (nn=0; nn<8; nn++) |  | ||||||
| { |  | ||||||
|     data[nn]=SharedMem::read()->store_bnaCollect[nn]; |  | ||||||
| } |  | ||||||
| */ |  | ||||||
|  |  | ||||||
| //uint64_t stor_wakSrc; | //uint64_t stor_wakSrc; | ||||||
| //uint8_t  stor_reason; | //uint8_t  stor_reason; | ||||||
| @@ -1921,10 +1894,6 @@ void gpi_storeDeviceConditions(uint8_t leng, uint8_t *data) | |||||||
|     //tslib_strcpy(data, SharedMem::write()->store_deviceCond, leng); |     //tslib_strcpy(data, SharedMem::write()->store_deviceCond, leng); | ||||||
|     for (nn=0; nn<leng; nn++) |     for (nn=0; nn<leng; nn++) | ||||||
|         SharedMem::write()->store_deviceCond[nn]=data[nn]; |         SharedMem::write()->store_deviceCond[nn]=data[nn]; | ||||||
|     // clear the rest |  | ||||||
|     for (nn=leng; nn<64; nn++) |  | ||||||
|         SharedMem::write()->store_deviceCond[nn]=0; |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void epi_restoreDeviceConditions(uint8_t *leng, uint8_t *data) | void epi_restoreDeviceConditions(uint8_t *leng, uint8_t *data) | ||||||
| @@ -1960,8 +1929,6 @@ void gpi_storeDynMachineConditions(uint8_t leng, uint8_t *data) | |||||||
| //    tslib_strcpy(data, SharedMem::write()->store_machCond, leng); | //    tslib_strcpy(data, SharedMem::write()->store_machCond, leng); | ||||||
|     for (nn=0; nn<leng; nn++) |     for (nn=0; nn<leng; nn++) | ||||||
|         SharedMem::write()->store_machCond[nn] = data[nn]; |         SharedMem::write()->store_machCond[nn] = data[nn]; | ||||||
|     for (nn=leng; nn<64; nn++) |  | ||||||
|         SharedMem::write()->store_machCond[nn] = 0; |  | ||||||
|  |  | ||||||
|  } |  } | ||||||
|  |  | ||||||
| @@ -2017,7 +1984,7 @@ void epi_iniVRstorage(void) | |||||||
| void gpi_storeVaultRecord(uint8_t blkNr, uint8_t *data ) | void gpi_storeVaultRecord(uint8_t blkNr, uint8_t *data ) | ||||||
| { | { | ||||||
|     uint16_t start=blkNr, ii; |     uint16_t start=blkNr, ii; | ||||||
|     qDebug()<<"storing vault data "<<blkNr; |     //qDebug()<<"storing vault data "<<blkNr; | ||||||
|     SharedMem::write()->store_gotNrBlocksOfVaultRec |= (1<<start);  // setze pro Block ein bit, wir brauchen block 0...5 |     SharedMem::write()->store_gotNrBlocksOfVaultRec |= (1<<start);  // setze pro Block ein bit, wir brauchen block 0...5 | ||||||
|                                                 // also muss store_gotNrBlocksOfVaultRec auf 0x1F stehen |                                                 // also muss store_gotNrBlocksOfVaultRec auf 0x1F stehen | ||||||
|     start<<=6;      // *64 |     start<<=6;      // *64 | ||||||
| @@ -2087,60 +2054,13 @@ uint16_t epi_getNrOfCoinsInCashBox(void) | |||||||
|  |  | ||||||
| void gpi_storeDcDataValid(bool isVal) | void gpi_storeDcDataValid(bool isVal) | ||||||
| { | { | ||||||
|     bool now=SharedMem::read()->store_DcDataAreValid; |  | ||||||
|     if (isVal != now) |  | ||||||
|     { |  | ||||||
|     SharedMem::write()->store_DcDataAreValid = isVal; |     SharedMem::write()->store_DcDataAreValid = isVal; | ||||||
| #ifdef THIS_IS_CA_MASTER |  | ||||||
|         qDebug()<<"master lib sets DcDataValid to "<<isVal; |  | ||||||
| #else |  | ||||||
|         qDebug()<<"slave lib sets DcDataValid to "<<isVal; |  | ||||||
| #endif |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void epi_setDcDataValid(void) |  | ||||||
| { |  | ||||||
|     bool now=SharedMem::read()->store_DcDataAreValid; |  | ||||||
|     if (now==false) |  | ||||||
|     { |  | ||||||
|         SharedMem::write()->store_DcDataAreValid = true; |  | ||||||
| #ifdef THIS_IS_CA_MASTER |  | ||||||
|         qDebug()<<"master lib SET DcDataValid"; |  | ||||||
| #else |  | ||||||
|         qDebug()<<"slave lib SET DcDataValid"; |  | ||||||
| #endif |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void epi_resetDcDataValid(char reason) |  | ||||||
| { |  | ||||||
|     bool now=SharedMem::read()->store_DcDataAreValid; |  | ||||||
|     if (now==true) |  | ||||||
|     { |  | ||||||
|         SharedMem::write()->store_DcDataAreValid = false; |  | ||||||
| #ifdef THIS_IS_CA_MASTER |  | ||||||
|         switch (reason) |  | ||||||
|         { |  | ||||||
|             case 1: qDebug()<<"master lib RESET DcDataValid startup"; break; |  | ||||||
|             case 2: qDebug()<<"master lib RESET DcDataValid port closed"; break; |  | ||||||
|             case 3: qDebug()<<"master lib RESET DcDataValid no more data"; break; |  | ||||||
|             case 4: qDebug()<<"master lib RESET DcDataValid manuell"; break; |  | ||||||
|             default: qDebug()<<"master lib RESET DcDataValid ---"; break; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #else |  | ||||||
|         qDebug()<<"slave lib RESET DcDataValid"; |  | ||||||
|         Q_UNUSED(reason); |  | ||||||
| #endif |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool epi_areDcDataValid() | bool epi_areDcDataValid() | ||||||
| { | { | ||||||
|     return SharedMem::read()->store_DcDataAreValid; |     return SharedMem::read()->store_DcDataAreValid; | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // .................................................................................... | // .................................................................................... | ||||||
| @@ -2371,7 +2291,6 @@ void epi_getJsonVersion(uint8_t  jsonNr, char *versionString) | |||||||
|             versionString[nn] = SharedMem::read()->store_jsonVersion[nn][lrd]; |             versionString[nn] = SharedMem::read()->store_jsonVersion[nn][lrd]; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // korrektur 8.5.24: printer versionen auf 6...37 (nicht 5..36) |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -2478,40 +2397,7 @@ void epi_restoreBnaContent(uint8_t  *data) | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| // new, 8.5.24 |  | ||||||
| //uint8_t store_machCon2len; |  | ||||||
| //uint8_t store_machCon2[66]; |  | ||||||
|  |  | ||||||
| void epi_clearDynMachCond2(void) |  | ||||||
| { |  | ||||||
|     uint8_t nn; |  | ||||||
|     SharedMem::write()->store_machCon2len=0; |  | ||||||
|     for (nn=0; nn<64; nn++) |  | ||||||
|         SharedMem::write()->store_machCon2[nn] = 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void gpi_storeDynMachCond2(uint8_t leng, uint8_t *data) |  | ||||||
| { |  | ||||||
|     uint8_t nn; |  | ||||||
|     if (leng>64) leng=64; |  | ||||||
|     SharedMem::write()->store_machCon2len=leng; |  | ||||||
|     for (nn=0; nn<leng; nn++) |  | ||||||
|         SharedMem::write()->store_machCon2[nn] = data[nn]; |  | ||||||
|     for (nn=leng; nn<64; nn++) |  | ||||||
|         SharedMem::write()->store_machCon2[nn] = 0; |  | ||||||
|  |  | ||||||
|  } |  | ||||||
|  |  | ||||||
| void epi_restoreDynMachCond2(uint8_t *leng, uint8_t *data) |  | ||||||
| { |  | ||||||
|     uint8_t nn, LL; |  | ||||||
|     LL=SharedMem::read()->store_machCon2len; |  | ||||||
|     *leng=LL; |  | ||||||
|  |  | ||||||
|     for (nn=0; nn<LL; nn++) |  | ||||||
|         data[nn] = SharedMem::read()->store_machCon2[nn]; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										371
									
								
								src/tslib.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										371
									
								
								src/tslib.cpp
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -610,374 +610,3 @@ bool tslib_strComp(uint8_t *buf, char *compStr) | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| char biox_StrComp(char *S1, char *S2, int len) |  | ||||||
| { |  | ||||||
|     // retval=1 wenn gleich; ? in S2 =Jokerzeichen |  | ||||||
|  |  | ||||||
|     int    ii; |  | ||||||
|  |  | ||||||
|     for (ii=0; ii<len; ii++) |  | ||||||
|     { |  | ||||||
|         if ((S1[ii] != S2[ii]) && (S2[ii] != '?') ) |  | ||||||
|             return (0); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return(1); |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // ***************************************************************************************** |  | ||||||
|  |  | ||||||
| uint16_t tslib_StrLen(char *str) |  | ||||||
| { |  | ||||||
|     uint16_t    zz; |  | ||||||
|  |  | ||||||
|     for (zz=0; zz<0xF000; zz++) |  | ||||||
|         if (str[zz]==0) |  | ||||||
|             return(zz); |  | ||||||
|  |  | ||||||
|     return(0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| // ***************************************************************************************** |  | ||||||
|  |  | ||||||
| uint16_t biox_StrLenInt(uint16_t *str) |  | ||||||
| { |  | ||||||
|     uint16_t    zz; |  | ||||||
|  |  | ||||||
|     for (zz=0; zz<0xF000; zz++) |  | ||||||
|         if (str[zz]==0) |  | ||||||
|             return(zz); |  | ||||||
|  |  | ||||||
|     return(0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // ***************************************************************************************** |  | ||||||
|  |  | ||||||
| void biox_MemCpy(uint8_t *src, uint8_t *dest, uint16_t Len) |  | ||||||
| { |  | ||||||
|     // copy "Len" bytes from target to destination |  | ||||||
|     // if Len==0 then copy until first NULL in targ |  | ||||||
|  |  | ||||||
|     uint16_t    zz=0; |  | ||||||
|     if (Len==0) |  | ||||||
|     { |  | ||||||
|         while(src[zz]>0) |  | ||||||
|         { |  | ||||||
|             dest[zz]=src[zz]; |  | ||||||
|             zz++; |  | ||||||
|         } |  | ||||||
|         dest[zz]=0;     // termination |  | ||||||
|     } else |  | ||||||
|     { |  | ||||||
|         // Len>0  --> copy "Len" bytes |  | ||||||
|         for (zz=0; zz<Len; zz++) |  | ||||||
|             dest[zz]=src[zz]; |  | ||||||
|  |  | ||||||
|         dest[zz]=0;     // termination |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void tslib_itoa(int n, char *str) |  | ||||||
| { |  | ||||||
|     // -23456 -> str[0]='-'   str[1]='2' ...[5]='6' str[6]=0 |  | ||||||
|     // 5      -> str[0]='5'   str[1..6]=0 |  | ||||||
|  |  | ||||||
|     uint8_t   pp, zi[7]; |  | ||||||
|     int itmp, pi=0; |  | ||||||
|  |  | ||||||
|     for (pp=0;pp<7;pp++) |  | ||||||
|     { |  | ||||||
|         str[pp]=0; |  | ||||||
|         zi[pp]=0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     itmp=n; |  | ||||||
|     pp=0; |  | ||||||
|  |  | ||||||
|     if (itmp==0) |  | ||||||
|         str[pp++]=0x30; |  | ||||||
|  |  | ||||||
|     if (itmp<0) |  | ||||||
|     { |  | ||||||
|         str[pp++]='-'; |  | ||||||
|         itmp*=-1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     while(itmp>0) |  | ||||||
|     { |  | ||||||
|         zi[pi++]=itmp%10; |  | ||||||
|         itmp/=10; |  | ||||||
|     } |  | ||||||
|     // now: zi[0]=6  zi[1]=5   zi[2]=4    zi[3]=3   zi[4]=2   zi[5]=0   zi[6]=0    pi=4 |  | ||||||
|     while (pi>0) |  | ||||||
|         str[pp++]=zi[--pi]+0x30; |  | ||||||
|  |  | ||||||
|     //str[0]='-'; str[1]='1'; str[3]='3';  // Test |  | ||||||
|  } |  | ||||||
|  |  | ||||||
| // *********************************************************************************************** |  | ||||||
|  |  | ||||||
| void tslib_uitoa(unsigned int n, char *str) |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     uint8_t   pp, zi[6]; |  | ||||||
|     unsigned int itmp; |  | ||||||
|     int pi=0; |  | ||||||
|  |  | ||||||
|     for (pp=0;pp<6;pp++) |  | ||||||
|     { |  | ||||||
|         str[pp]=0; |  | ||||||
|         zi[pp]=0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     itmp=n; |  | ||||||
|     pp=0; |  | ||||||
|  |  | ||||||
|     if (itmp==0) |  | ||||||
|         str[pp++]=0x30; |  | ||||||
|  |  | ||||||
|     while(itmp>0) |  | ||||||
|     { |  | ||||||
|         zi[pi++]=itmp%10; |  | ||||||
|         itmp/=10; |  | ||||||
|     } |  | ||||||
|     // now: zi[0]=6  zi[1]=5   zi[2]=4    zi[3]=3   zi[4]=2   zi[5]=0      pi=4 |  | ||||||
|     while (pi>0) |  | ||||||
|         str[pp++]=zi[--pi]+0x30; |  | ||||||
|  |  | ||||||
|     //str[0]='-'; str[1]='1'; str[3]='3';  // Test |  | ||||||
|  } |  | ||||||
|  |  | ||||||
| // *********************************************************************************************** |  | ||||||
|  |  | ||||||
| void tslib_ltoa(long n, char *str) |  | ||||||
| { |  | ||||||
|     // -2147483647 -> str[0]='-'   str[1]='2' ...[10]='6' str[11]=0 |  | ||||||
|  |  | ||||||
|     uint8_t   pp, zi[12]; |  | ||||||
|     int pi=0; |  | ||||||
|     long ltmp; |  | ||||||
|  |  | ||||||
|     for (pp=0;pp<12;pp++) |  | ||||||
|     { |  | ||||||
|         str[pp]=0; |  | ||||||
|         zi[pp]=0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     ltmp=n; |  | ||||||
|     pp=0; |  | ||||||
|  |  | ||||||
|     if (ltmp==0) |  | ||||||
|         str[pp++]=0x30; |  | ||||||
|  |  | ||||||
|     if (ltmp<0) |  | ||||||
|     { |  | ||||||
|         str[pp++]='-'; |  | ||||||
|         ltmp*=-1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     while(ltmp>0) |  | ||||||
|     { |  | ||||||
|         zi[pi++]=ltmp%10; |  | ||||||
|         ltmp/=10; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     while (pi>0) |  | ||||||
|         str[pp++]=zi[--pi]+0x30; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // *********************************************************************************************** |  | ||||||
|  |  | ||||||
| void tslib_ultoa(unsigned long n, char *str) |  | ||||||
| { |  | ||||||
|     // 0... ->4294967296   str[0]='4'   str[1]='2' ...[9]='6' str[10]=0   str[11]=0 |  | ||||||
|  |  | ||||||
|     uint8_t   pp, zi[12]; |  | ||||||
|     int pi=0; |  | ||||||
|     unsigned long ltmp; |  | ||||||
|  |  | ||||||
|     for (pp=0;pp<12;pp++) |  | ||||||
|     { |  | ||||||
|         str[pp]=0; |  | ||||||
|         zi[pp]=0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     ltmp=n; |  | ||||||
|     pp=0; |  | ||||||
|  |  | ||||||
|     if (ltmp==0) |  | ||||||
|         str[pp++]=0x30; |  | ||||||
|  |  | ||||||
|     while(ltmp>0) |  | ||||||
|     { |  | ||||||
|         zi[pi++]=ltmp%10; |  | ||||||
|         ltmp/=10; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     while (pi>0) |  | ||||||
|         str[pp++]=zi[--pi]+0x30; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // *********************************************************************************************** |  | ||||||
|  |  | ||||||
| void tslib_uitobin(unsigned int  decval, char *str) |  | ||||||
| { |  | ||||||
|     uint16_t    dv, bb; |  | ||||||
|     int     ll; |  | ||||||
|  |  | ||||||
|     dv=decval; |  | ||||||
|     ll=8;                // show 8 bit |  | ||||||
|     if (dv>255) ll=16;   // show 16 bit |  | ||||||
|     str[ll--]=0;         // terminierung |  | ||||||
|  |  | ||||||
|     bb=0; |  | ||||||
|     do |  | ||||||
|     { |  | ||||||
|         if (dv & (1<<bb) ) str[ll]=0x31; else str[ll]=0x30; |  | ||||||
|         bb++; ll--; |  | ||||||
|     } while(ll>=0); |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // *********************************************************************************************** |  | ||||||
|  |  | ||||||
| long tslib_atol( char *AscString) |  | ||||||
| { |  | ||||||
|     // change ascii string ( of ascii numbers '0'..'9') to number |  | ||||||
|     // AscString must be 0-terminated! |  | ||||||
|     // a leading '-' is ignored, a'.' or a ',' stops calculation |  | ||||||
|  |  | ||||||
|     //aufruf mit ("1234") |  | ||||||
|     // aus IDE: ucatmp[0]='1'   ucatmp[3]='4'   ucatmp[4]='0'      sl=4 |  | ||||||
|  |  | ||||||
|     unsigned long ultmp; |  | ||||||
|     unsigned char uctmp1, minus=0; |  | ||||||
|     unsigned int  sl, zz; |  | ||||||
|  |  | ||||||
|     sl=tslib_StrLen(AscString); |  | ||||||
|     if (sl>10) sl=10;            // mehr passt im ULONG nicht rein! |  | ||||||
|  |  | ||||||
|     ultmp=0; |  | ||||||
|     for (zz=0; zz<sl; zz++) |  | ||||||
|     { |  | ||||||
|         uctmp1=AscString[zz]; |  | ||||||
|         if (zz==0 && uctmp1=='-') |  | ||||||
|             minus=1; |  | ||||||
|         else |  | ||||||
|         if (uctmp1>0x2F && uctmp1<0x3A) |  | ||||||
|         { |  | ||||||
|             ultmp*=10;      // nur wenn eine neue Ziffer dazukommt und vor der addition! |  | ||||||
|             uctmp1-=0x30; |  | ||||||
|             ultmp+=(uint32_t)uctmp1; |  | ||||||
|  |  | ||||||
|         } else |  | ||||||
|         if (uctmp1=='.' || uctmp1==',' || uctmp1==0 ) |  | ||||||
|         { |  | ||||||
|             if (minus) |  | ||||||
|                 ultmp*=(-1); |  | ||||||
|             return(ultmp); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (minus) |  | ||||||
|         ultmp*=(-1); |  | ||||||
|     return(ultmp); |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // ***************************************************************************************** |  | ||||||
|  |  | ||||||
| unsigned long tslib_atoul( char *AscString) |  | ||||||
| { |  | ||||||
|     // change ascii string ( of ascii numbers '0'..'9') to number |  | ||||||
|     // AscString must be 0-terminated! |  | ||||||
|     // a leading '-' is ignored, a'.' or a ',' stops calculation |  | ||||||
|  |  | ||||||
|     //aufruf mit ("1234") |  | ||||||
|     // aus IDE: ucatmp[0]='1'   ucatmp[3]='4'   ucatmp[4]='0'      sl=4 |  | ||||||
|  |  | ||||||
|     unsigned long ultmp; |  | ||||||
|     unsigned char uctmp1; |  | ||||||
|     unsigned int  sl, zz; |  | ||||||
|  |  | ||||||
|     sl=tslib_StrLen(AscString); |  | ||||||
|     if (sl>10) sl=10;            // mehr passt im ULONG nicht rein! |  | ||||||
|  |  | ||||||
|     ultmp=0; |  | ||||||
|     for (zz=0; zz<sl; zz++) |  | ||||||
|     { |  | ||||||
|         uctmp1=AscString[zz]; |  | ||||||
|         if (uctmp1>0x2F && uctmp1<0x3A) |  | ||||||
|         { |  | ||||||
|             ultmp*=10;      // nur wenn eine neue Ziffer dazukommt und vor der addition! |  | ||||||
|             uctmp1-=0x30; |  | ||||||
|             ultmp+=(uint32_t)uctmp1; |  | ||||||
|  |  | ||||||
|         } else |  | ||||||
|         if (uctmp1=='.' || uctmp1==',' || uctmp1==0 ) |  | ||||||
|             return(ultmp); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return(ultmp); |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // ***************************************************************************************** |  | ||||||
|  |  | ||||||
| unsigned int tslib_ah2ui( char *AscString) |  | ||||||
| { |  | ||||||
|     // change hex ascii string ( of ascii numbers '0'..'9', 'A' or 'a' ...'F','f') to number |  | ||||||
|     // AscString must be 0-terminated! |  | ||||||
|     // Example: "1A0C" = 6668 |  | ||||||
|  |  | ||||||
|     //unsigned long ultmp; |  | ||||||
|     unsigned char uctmp1; |  | ||||||
|     unsigned int  sl, zz, uitmp; |  | ||||||
|  |  | ||||||
|     sl=tslib_StrLen(AscString); |  | ||||||
|     if (sl>4) sl=4; |  | ||||||
|  |  | ||||||
|     uitmp=0; |  | ||||||
|     for (zz=0; zz<sl; zz++) |  | ||||||
|     { |  | ||||||
|         uctmp1=AscString[zz]; |  | ||||||
|  |  | ||||||
|         if (uctmp1>=0x30 && uctmp1<=0x39) |  | ||||||
|         { |  | ||||||
|             uitmp<<=4;      // nur wenn eine neue Ziffer dazukommt und vor der addition! |  | ||||||
|             uctmp1-=0x30; |  | ||||||
|             uitmp+=(uint16_t)uctmp1; |  | ||||||
|         } else |  | ||||||
|  |  | ||||||
|         if (uctmp1>='A' && uctmp1<='F') |  | ||||||
|         { |  | ||||||
|             uitmp<<=4; |  | ||||||
|             uctmp1-=0x37; |  | ||||||
|             uitmp+=(uint16_t)uctmp1; |  | ||||||
|         } else |  | ||||||
|  |  | ||||||
|         if (uctmp1>='a' && uctmp1<='f') |  | ||||||
|         { |  | ||||||
|             uitmp<<=4; |  | ||||||
|             uctmp1-=0x57; |  | ||||||
|             uitmp+=(uint16_t)uctmp1; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return(uitmp); |  | ||||||
|  |  | ||||||
| } |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user