forked from GerhardHoffmann/DCLibraries
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			1.99.1
			...
			bugfix_mas
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8ee6fa24d9 | |||
| 786c4332ee | 
| @@ -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\\\" | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| CONFIG += plugin | CONFIG += plugin | ||||||
| QT -= gui | QT -= gui | ||||||
| QT += serialport | QT += widgets serialport | ||||||
|  |  | ||||||
|  |  | ||||||
| win32 { | win32 { | ||||||
| @@ -90,9 +90,7 @@ HEADERS += \ | |||||||
|     $${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 |  | ||||||
|  |  | ||||||
| SOURCES += \ | SOURCES += \ | ||||||
|     $${PWD}/src/datei.cpp \ |     $${PWD}/src/datei.cpp \ | ||||||
| @@ -103,9 +101,7 @@ SOURCES += \ | |||||||
|     $${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 |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # INTERFACE = DeviceController | # INTERFACE = DeviceController | ||||||
|   | |||||||
							
								
								
									
										170
									
								
								dCArun/CArun.cpp
									
									
									
									
									
								
							
							
						
						
									
										170
									
								
								dCArun/CArun.cpp
									
									
									
									
									
								
							| @@ -1,170 +0,0 @@ | |||||||
| #include "CArun.h" |  | ||||||
| #include "datei.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(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 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,56 +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 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(); |  | ||||||
|  |  | ||||||
| signals: |  | ||||||
|  |  | ||||||
|  |  | ||||||
| private slots: |  | ||||||
|     void chainControl(); |  | ||||||
|  |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| #endif // CARUN_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,31 +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 \ |  | ||||||
|     main.cpp \ |     main.cpp \ | ||||||
|  |     mainwindow.cpp \ | ||||||
|     tslib.cpp \ |     tslib.cpp \ | ||||||
|  |     win01_com.cpp \ | ||||||
|     datei.cpp |     datei.cpp | ||||||
|  |  | ||||||
| HEADERS += \ | HEADERS += \ | ||||||
|     CArun.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 | ||||||
							
								
								
									
										609
									
								
								dCArun/win01_com.cpp
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										609
									
								
								dCArun/win01_com.cpp
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,609 @@ | |||||||
|  | #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" | ||||||
|  |     QString  bs, cn; | ||||||
|  |     int br, ci; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     this->updateGui(); | ||||||
|  |     *nextScreen=0;   // 0=no change | ||||||
|  |     *useNavi=0; | ||||||
|  |  | ||||||
|  |     if (myStep==0) | ||||||
|  |     { | ||||||
|  |         // 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 | ||||||
|  |             HWaccess->dc_openSerial(br,bs,cn,1); | ||||||
|  |             CB_portSel->setCurrentIndex(ci);    // den Port aus der Datei hier vorgeben | ||||||
|  |             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 | ||||||
|  |         myStep++; | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==1) | ||||||
|  |     { | ||||||
|  |         if (!myTO->isActive()) | ||||||
|  |         { | ||||||
|  |             if (HWaccess->dc_isPortOpen()) | ||||||
|  |             { | ||||||
|  |                 myStep++; | ||||||
|  |             } else | ||||||
|  |             { | ||||||
|  |                 myStep=6;   // 13.12.23: start Autoconnect cycle | ||||||
|  |                 qDebug()<<"CArunGui: port is still closed, restarting.."; | ||||||
|  |             } | ||||||
|  |             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=6;   // 13.12.23: start Autoconnect cycle | ||||||
|  |                 qDebug()<<"CArunGui: got no answer from DC, retry.."; | ||||||
|  |             } | ||||||
|  |             myTO->start(100); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==4) | ||||||
|  |     { | ||||||
|  |         HWaccess->dc_autoRequest(1); | ||||||
|  |         AutSendButton->setChecked(true);        // taste "druecken" | ||||||
|  |         myStep++; | ||||||
|  |         myTO->start(2000); | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==5) | ||||||
|  |     { | ||||||
|  |         if (!myTO->isActive()) | ||||||
|  |         { | ||||||
|  |             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++; | ||||||
|  |                 myTO->start(100); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==6) | ||||||
|  |     { | ||||||
|  |         // restart autoconnect cycle | ||||||
|  |         myTO->start(100);     // restart | ||||||
|  |         myStep=0; | ||||||
|  |     } else | ||||||
|  |  | ||||||
|  |     if (myStep==7) | ||||||
|  |     { | ||||||
|  |         // stay here, DC connection is up and running | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     } else | ||||||
|  |     { | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (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> | ||||||
|   | |||||||
| @@ -1,37 +0,0 @@ | |||||||
| #ifndef DOWNLOAD_THREAD_H_INCLUDED |  | ||||||
| #define DOWNLOAD_THREAD_H_INCLUDED |  | ||||||
|  |  | ||||||
| #include <QThread> |  | ||||||
| #include <QString> |  | ||||||
| #include <QByteArray> |  | ||||||
|  |  | ||||||
| class hwinf; |  | ||||||
| class DownloadThread : public QThread { |  | ||||||
|     Q_OBJECT |  | ||||||
|  |  | ||||||
| public: |  | ||||||
|     enum class DownloadResult {OK, ERROR, TIMEOUT, NOP}; |  | ||||||
|  |  | ||||||
|     DownloadThread(hwinf *hw); |  | ||||||
|     ~DownloadThread(); |  | ||||||
|  |  | ||||||
| protected: |  | ||||||
|     // download thread does not have a running event queue, and therefore |  | ||||||
|     // no slots. signals work the usual way. |  | ||||||
|     void run() override; |  | ||||||
|  |  | ||||||
| private: |  | ||||||
|     DownloadResult sendStatus(int ret) const; |  | ||||||
|     DownloadResult sendNextAddress(int bNum) const; |  | ||||||
|     DownloadResult sendNextDataBlock(QByteArray const &binary, int bNum) const; |  | ||||||
|     bool startBootloader() const; |  | ||||||
|     bool stopBootloader() const; |  | ||||||
|     QByteArray loadBinaryDCFile(QString dcFileName) const; |  | ||||||
|     bool resetDeviceController() const; |  | ||||||
|     DownloadResult dcDownloadBinary(QByteArray const &b) const; |  | ||||||
|  |  | ||||||
|     hwinf *m_hw; |  | ||||||
|     QString m_fileToDownload; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| #endif // DOWNLOAD_THREAD_H_INCLUDED |  | ||||||
| @@ -27,6 +27,7 @@ V4.0  6.9.2023: activating DC-Bootloader in slve-lib (SM) | |||||||
| #define hwapi_H | #define hwapi_H | ||||||
|  |  | ||||||
| #include <stdint.h> | #include <stdint.h> | ||||||
|  | //#include <QTabWidget> | ||||||
| #include <QtPlugin> | #include <QtPlugin> | ||||||
| #include <QTimer> | #include <QTimer> | ||||||
| #include <QObject> | #include <QObject> | ||||||
| @@ -79,8 +80,7 @@ V4.0  6.9.2023: activating DC-Bootloader in slve-lib (SM) | |||||||
|  |  | ||||||
|  |  | ||||||
| class QSharedMemory; | class QSharedMemory; | ||||||
| class DownloadThread; |  | ||||||
| class ReportingThread; |  | ||||||
| class hwapi :   public QObject, | class hwapi :   public QObject, | ||||||
|                 public hwinf |                 public hwinf | ||||||
| { | { | ||||||
| @@ -92,12 +92,10 @@ private: | |||||||
|     void sub_storeSendingText(QByteArray *buf) const; |     void sub_storeSendingText(QByteArray *buf) const; | ||||||
|     QTimer *hwapi_TimerPayment; |     QTimer *hwapi_TimerPayment; | ||||||
|     QSharedMemory *m_sharedMem; |     QSharedMemory *m_sharedMem; | ||||||
|     ReportingThread *m_reportingThread; |  | ||||||
|     DownloadThread *m_downloadThread; |  | ||||||
|     //QTimer *hwapi_triggerBL; |     //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 | ||||||
| @@ -1318,51 +1316,10 @@ 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 |  | ||||||
|     bool dcDownloadRequest(QString const &fileToDownload) const override; |  | ||||||
|     bool dcDownloadRequested() const override; |  | ||||||
|     bool dcDownloadResetRequest() const override; |  | ||||||
|     bool dcDownloadRequestAck() const override; |  | ||||||
|     bool dcDownloadRunning() const override; |  | ||||||
|     bool dcDownloadFinished() override; |  | ||||||
|  |  | ||||||
|     bool dcDownloadReportStart() const override; |  | ||||||
|     bool dcDownloadReportRunning() const override; |  | ||||||
|     bool dcDownloadReportFinished() override; |  | ||||||
|  |  | ||||||
|     bool dcDownloadThreadStart() override; |  | ||||||
|     bool dcDownloadThreadRunning() const override; |  | ||||||
|     void dcDownloadThreadFinalize(DownloadThread *) override; |  | ||||||
|     bool dcDownloadThreadFinished() const override; |  | ||||||
|     bool dcDownloadReportThreadStart() override; |  | ||||||
|     bool dcDownloadReportThreadRunning() const override; |  | ||||||
|     void dcDownloadReportThreadFinalize() override; |  | ||||||
|     void dcDownloadReportThreadQuit() override; |  | ||||||
|     bool dcDownloadReportThreadFinished() const override; |  | ||||||
|  |  | ||||||
|     QString dcDownloadFileName() const override; |  | ||||||
|     bool dcDownloadSetRequested(bool) override; |  | ||||||
|     bool dcDownloadSetRunning(bool) override; |  | ||||||
|     bool dcDownloadSetFinished(bool) override; |  | ||||||
|     void dcDownloadSetTotalBlockNumber(uint16_t totalBlockNumber) override; |  | ||||||
|     void dcDownloadSetCurrentBlockNumber(uint16_t currentBlockNumber) override; |  | ||||||
|     bool dcDownloadGetRequested() const override; |  | ||||||
|     bool dcDownloadGetRunning() const override; |  | ||||||
|     bool dcDownloadGetFinished() const override; |  | ||||||
|     uint16_t dcDownloadGetTotalBlockNumber() const override; |  | ||||||
|     uint16_t dcDownloadGetCurrentBlockNumber() const override; |  | ||||||
|  |  | ||||||
|     virtual QObject const *getAPI() override; |  | ||||||
|  |  | ||||||
| signals: | 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_OK(void) const override; | ||||||
|     void hwapi_templatePrintFinished_Err(void) const override; |     void hwapi_templatePrintFinished_Err(void) const override; | ||||||
|  |  | ||||||
| @@ -1387,7 +1344,9 @@ signals: | |||||||
|     void hwapi_doorCBinAndAllDoorsClosed(void) const override; |     void hwapi_doorCBinAndAllDoorsClosed(void) const override; | ||||||
|     void hwapi_doorAllDoorsClosed(void) const override; |     void hwapi_doorAllDoorsClosed(void) const override; | ||||||
|  |  | ||||||
|     void hwapi_coinAttached() const override; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  private slots: |  private slots: | ||||||
|     //void hwapi_slotPrintFinished_OK(void); |     //void hwapi_slotPrintFinished_OK(void); | ||||||
| @@ -1415,7 +1374,8 @@ signals: | |||||||
|     void sub_slotCoin15(void); |     void sub_slotCoin15(void); | ||||||
|     void sub_slotCoin16(void); |     void sub_slotCoin16(void); | ||||||
|  |  | ||||||
|     void coinAttached(); |  | ||||||
|  |  | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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 | ||||||
| @@ -183,53 +182,44 @@ struct T_moduleCondition | |||||||
|         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; | ||||||
|         // 10 |  | ||||||
|         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; | ||||||
|         // 20 |  | ||||||
|         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;			// can only be tested by usage |         uint8_t	changer;			// can only be tested by usage | ||||||
|  |  | ||||||
|         uint8_t   coinBlocker;		// can only be tested by usage |         uint8_t   coinBlocker;		// can only be tested by usage | ||||||
|         uint8_t   billReader;			// 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   alarmState; | ||||||
|         uint8_t   res11; |         uint8_t   res11; | ||||||
|         uint8_t   res12; |         uint8_t   res12; | ||||||
|         // 30 |  | ||||||
|         uint8_t   res13; |         uint8_t   res13; | ||||||
|         uint8_t     padd01; | // 31 | ||||||
|         uint8_t     padd02; |  | ||||||
|         uint8_t     padd03; |  | ||||||
|         uint32_t   padd04; |  | ||||||
|         uint32_t   padd05; |  | ||||||
|         uint32_t   padd06; |  | ||||||
|         uint32_t   padd07; |  | ||||||
|         // 50 |  | ||||||
|         uint32_t   padd08; |  | ||||||
|         uint32_t   padd09; |  | ||||||
|         uint32_t   padd10; |  | ||||||
|         uint16_t   padd11; |  | ||||||
|         // 64 |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // ATTENTION: struct length must be 64 exactly!!! |  | ||||||
| struct T_dynamicCondition | struct T_dynamicCondition | ||||||
| { | { | ||||||
|         char allDoorsDebounced; |         char allDoorsDebounced; | ||||||
| @@ -238,11 +228,10 @@ 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; | ||||||
| @@ -277,7 +266,6 @@ struct T_dynamicCondition | |||||||
|  |  | ||||||
|         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; | ||||||
| @@ -287,10 +275,10 @@ 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]; | ||||||
|         uint8_t     resultOfLastTemplPrint; |         uint8_t     resultOfLastTemplPrint; | ||||||
|                     // 0: unknown or printing in progress |                     // 0: unknown or printing in progress | ||||||
| @@ -304,15 +292,7 @@ struct T_dynamicCondition | |||||||
|                     //			bit5: printer not ready |                     //			bit5: printer not ready | ||||||
|         uint8_t     startupTestIsRunning; |         uint8_t     startupTestIsRunning; | ||||||
|  |  | ||||||
|         uint8_t     padd01; |         //54 | ||||||
|         uint8_t     padd02; |  | ||||||
|         uint8_t     padd03; |  | ||||||
|         //50 |  | ||||||
|         uint32_t   padd04; |  | ||||||
|         uint32_t   padd05; |  | ||||||
|         uint32_t   padd06; |  | ||||||
|         uint16_t   padd07; |  | ||||||
|         // 64 |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| struct T_extTime | struct T_extTime | ||||||
| @@ -349,7 +329,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 | ||||||
| @@ -358,33 +337,27 @@ 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 | ||||||
|     UCHAR	CoinEscrow; |     UCHAR	CoinEscrow; | ||||||
|     UCHAR   CoinRejectUnit; |     UCHAR   CoinRejectUnit; | ||||||
|  |  | ||||||
|     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 | ||||||
|  |  | ||||||
|     UCHAR	autoOpen;				// 1: open door covers after valid ATBcard |     UCHAR	autoOpen;				// 1: open door covers after valid ATBcard | ||||||
|     UCHAR	printAccReceipt;		// 0/1 |     UCHAR	printAccReceipt;		// 0/1 | ||||||
|     UCHAR   printDoorReceipt; |     UCHAR   printDoorReceipt; | ||||||
|     UCHAR   printTokenTicket; |     UCHAR   printTokenTicket; | ||||||
|  |  | ||||||
|     UINT	VaultFullWarnLevel; |     UINT	VaultFullWarnLevel; | ||||||
|     UINT	VaultFullErrorLevel; |     UINT	VaultFullErrorLevel; | ||||||
|     // 30 |  | ||||||
|     UINT    BattEmptyWarnLevel; |     UINT    BattEmptyWarnLevel; | ||||||
|     UINT    BattEmptyErrorLevel; |     UINT    BattEmptyErrorLevel; | ||||||
|     uint32_t     padd01; |  | ||||||
|     uint32_t     padd02; |  | ||||||
|     uint32_t     padd03; |  | ||||||
|     uint32_t     padd04; |  | ||||||
|     uint32_t     padd05; |  | ||||||
|     uint32_t     padd06; |  | ||||||
|     uint32_t     padd07; |  | ||||||
|     uint16_t     padd08; |  | ||||||
|     // 64 |  | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -441,7 +414,6 @@ struct T_bna | |||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class DownloadThread; |  | ||||||
| class hwinf | class hwinf | ||||||
| { | { | ||||||
|  |  | ||||||
| @@ -2326,77 +2298,10 @@ 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 |  | ||||||
|     virtual bool dcDownloadRequest(QString const &fileToDownload) const { |  | ||||||
|         Q_UNUSED(fileToDownload); |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|     virtual bool dcDownloadRequested() const { return false; } |  | ||||||
|     virtual bool dcDownloadResetRequest() const { return false; } |  | ||||||
|     virtual bool dcDownloadRequestAck() const { return false; } |  | ||||||
|     virtual bool dcDownloadRunning() const { return false; } |  | ||||||
|     virtual bool dcDownloadFinished() { return false; } |  | ||||||
|  |  | ||||||
|     virtual bool dcDownloadReportStart() const { return false; } |  | ||||||
|     virtual bool dcDownloadReportRunning() const { return true; } |  | ||||||
|     virtual bool dcDownloadReportFinished() { return true; } |  | ||||||
|  |  | ||||||
|     virtual bool dcDownloadThreadStart() { return false; } |  | ||||||
|     virtual bool dcDownloadThreadRunning() const { return true; } |  | ||||||
|     virtual void dcDownloadThreadFinalize(DownloadThread *) {} |  | ||||||
|     virtual bool dcDownloadThreadFinished() const { return true; } |  | ||||||
|     virtual bool dcDownloadReportThreadStart() { return false; } |  | ||||||
|     virtual bool dcDownloadReportThreadRunning() const { return true; } |  | ||||||
|     virtual void dcDownloadReportThreadFinalize() {} |  | ||||||
|     virtual void dcDownloadReportThreadQuit() {} |  | ||||||
|     virtual bool dcDownloadReportThreadFinished() const { return true; } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     virtual QString dcDownloadFileName() const { return ""; } |  | ||||||
|     virtual bool dcDownloadSetRequested(bool requested) { |  | ||||||
|        Q_UNUSED(requested); return false; |  | ||||||
|     } |  | ||||||
|     virtual bool dcDownloadSetRunning(bool running) { |  | ||||||
|        Q_UNUSED(running); return false; |  | ||||||
|     } |  | ||||||
|     virtual bool dcDownloadSetFinished(bool finished) { |  | ||||||
|        Q_UNUSED(finished); return false; |  | ||||||
|     } |  | ||||||
|     virtual void dcDownloadSetTotalBlockNumber(uint16_t totalBlockNumber) { |  | ||||||
|        Q_UNUSED(totalBlockNumber); |  | ||||||
|     } |  | ||||||
|     virtual void dcDownloadSetCurrentBlockNumber(uint16_t currentBlockNumber) { |  | ||||||
|        Q_UNUSED(currentBlockNumber); |  | ||||||
|     } |  | ||||||
|     virtual bool dcDownloadGetRequested() const { return false; } |  | ||||||
|     virtual bool dcDownloadGetRunning() const { return false; } |  | ||||||
|     virtual bool dcDownloadGetFinished() const { return false; } |  | ||||||
|     virtual uint16_t dcDownloadGetTotalBlockNumber() const { return 0; } |  | ||||||
|     virtual uint16_t dcDownloadGetCurrentBlockNumber() const { return 0; } |  | ||||||
|  |  | ||||||
|     virtual QObject const *getAPI() { return nullptr; } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| signals: | 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_OK(void) const=0; | ||||||
|     virtual void hwapi_templatePrintFinished_Err(void) const=0; |     virtual void hwapi_templatePrintFinished_Err(void) const=0; | ||||||
|  |  | ||||||
| @@ -2420,7 +2325,6 @@ signals: | |||||||
|     virtual void hwapi_doorCBinAndAllDoorsClosed(void) const=0; |     virtual void hwapi_doorCBinAndAllDoorsClosed(void) const=0; | ||||||
|     virtual void hwapi_doorAllDoorsClosed(void) const=0; |     virtual void hwapi_doorAllDoorsClosed(void) const=0; | ||||||
|  |  | ||||||
|     virtual void hwapi_coinAttached() const = 0; |  | ||||||
|  |  | ||||||
|     // NOTE: declaring a "pure virtual" "signal" should be an error and thus not valid. |     // NOTE: declaring a "pure virtual" "signal" should be an error and thus not valid. | ||||||
|     /* GH Version, bringt Fehler |     /* GH Version, bringt Fehler | ||||||
| @@ -2509,12 +2413,10 @@ 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 |  | ||||||
|  |  | ||||||
| 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 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,25 +0,0 @@ | |||||||
| #ifndef REPORTING_THREAD_H_INCLUDED |  | ||||||
| #define REPORTING_THREAD_H_INCLUDED |  | ||||||
|  |  | ||||||
| #include <QThread> |  | ||||||
| #include <QString> |  | ||||||
|  |  | ||||||
| class hwapi; |  | ||||||
| class ReportingThread : public QThread { |  | ||||||
|     Q_OBJECT |  | ||||||
|  |  | ||||||
| public: |  | ||||||
|     ReportingThread(hwapi *hw); |  | ||||||
|     ~ReportingThread(); |  | ||||||
|  |  | ||||||
| protected: |  | ||||||
|     // reporting thread does not have a running event queue, and therefore |  | ||||||
|     // no slots. signals work the usual way. |  | ||||||
|     void run() override; |  | ||||||
|  |  | ||||||
| private: |  | ||||||
|     hwapi *m_hw; |  | ||||||
|     QString m_fileToDownload; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| #endif // REPORTING_THREAD_H_INCLUDED |  | ||||||
| @@ -3,7 +3,7 @@ | |||||||
| #define RUN_PROCESS_H | #define RUN_PROCESS_H | ||||||
|  |  | ||||||
| #include <stdint.h> | #include <stdint.h> | ||||||
| #include <QObject> | #include <QMainWindow> | ||||||
| #include <QString> | #include <QString> | ||||||
| #include <QTimer> | #include <QTimer> | ||||||
| #include "tslib.h" | #include "tslib.h" | ||||||
| @@ -15,7 +15,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" | ||||||
| @@ -36,10 +35,6 @@ class T_runProc : public QObject | |||||||
|  |  | ||||||
|     void restoreDeviceParameter(struct T_devices *deviceSettings); |     void restoreDeviceParameter(struct T_devices *deviceSettings); | ||||||
|  |  | ||||||
| #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); | ||||||
| @@ -85,7 +80,6 @@ signals: | |||||||
|     void runProc_doorCBinAndAllDoorsClosed(void); |     void runProc_doorCBinAndAllDoorsClosed(void); | ||||||
|     void runProc_doorAllDoorsClosed(void); |     void runProc_doorAllDoorsClosed(void); | ||||||
|  |  | ||||||
|     void runProc_coinAttached(); |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -300,26 +300,9 @@ struct SharedMem | |||||||
|  |  | ||||||
|     uint8_t  p_nextFDcmdsInQueue; |     uint8_t  p_nextFDcmdsInQueue; | ||||||
|  |  | ||||||
|     // download of device controller and json files |  | ||||||
|     struct DCDownload { |  | ||||||
|         enum class FILE_INDEX { |  | ||||||
|             DC_BINARY = 0, DC2C_CASH = 1, DC2C_CONF = 2, DC2C_SERIAL=3, |  | ||||||
|             DC2C_PRINT_01, DC2C_PRINT_02, DC2C_PRINT_03, DC2C_PRINT_04, |  | ||||||
|             DC2C_PRINT_05, DC2C_PRINT_06, DC2C_PRINT_07, DC2C_PRINT_08, |  | ||||||
|             DC2C_PRINT_09, DC2C_PRINT_10, DC2C_PRINT_11, DC2C_PRINT_12, |  | ||||||
|             DC2C_PRINT_13, DC2C_PRINT_14, DC2C_PRINT_15, DC2C_PRINT_16, |  | ||||||
|             DC2C_PRINT_17, DC2C_PRINT_18, DC2C_PRINT_19, DC2C_PRINT_20, |  | ||||||
|             DC2C_PRINT_21, DC2C_PRINT_22, DC2C_PRINT_23, DC2C_PRINT_24, |  | ||||||
|             DC2C_PRINT_25, DC2C_PRINT_26, DC2C_PRINT_27, DC2C_PRINT_28, |  | ||||||
|             DC2C_PRINT_29, DC2C_PRINT_30, DC2C_PRINT_31, DC2C_PRINT_32 |  | ||||||
|         }; |  | ||||||
|         char m_filename[(int)FILE_INDEX::DC2C_PRINT_32][512]; |  | ||||||
|         std::atomic_ushort m_totalBlocks; |  | ||||||
|         std::atomic_ushort m_currentblockNumber; |  | ||||||
|         std::atomic_bool m_requested{false}; |  | ||||||
|         std::atomic_bool m_running{false}; |  | ||||||
|         std::atomic_bool m_finished{false}; |  | ||||||
|     } m_downLoadDC; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     static QSharedMemory *getShm(std::size_t s = 0); |     static QSharedMemory *getShm(std::size_t s = 0); | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| TEMPLATE = lib | TEMPLATE = lib | ||||||
| TARGET = CAmaster | TARGET = CAmaster | ||||||
| VERSION="1.0.1" | VERSION="1.0.0" | ||||||
|  |  | ||||||
| HEADERS += \ | HEADERS += \ | ||||||
|     ../include/com.h \ |     ../include/com.h \ | ||||||
| @@ -14,25 +14,6 @@ SOURCES += \ | |||||||
|  |  | ||||||
| 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 | ||||||
| DESTDIR=$${_PRO_FILE_PWD_}/../build | DESTDIR=$${_PRO_FILE_PWD_}/../build | ||||||
|   | |||||||
| @@ -1,29 +1,9 @@ | |||||||
| 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 | ||||||
| DESTDIR=$${_PRO_FILE_PWD_}/../build | DESTDIR=$${_PRO_FILE_PWD_}/../build | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1041,9 +1041,6 @@ char T_datif::loadRecDataFromFrame() | |||||||
|                                         // 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 |         /* funktioniert, ist aber nicht nötig. Signal wird nach dem shared memory erzeugt | ||||||
|         prnResult=receivedData[52]; |         prnResult=receivedData[52]; | ||||||
|   | |||||||
| @@ -1,320 +0,0 @@ | |||||||
| #include "download_thread.h" |  | ||||||
| #include "shared_mem_buffer.h" |  | ||||||
| #include "hwapi.h" |  | ||||||
|  |  | ||||||
| #include <QDebug> |  | ||||||
| #include <QDateTime> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| DownloadThread::DownloadThread(hwinf *hw) |  | ||||||
|   : m_hw(hw) |  | ||||||
|   , m_fileToDownload(m_hw->dcDownloadFileName()) { |  | ||||||
|     // connect(this, &QThread::finished, |  | ||||||
|     //        dynamic_cast<QObject const *>(m_hw), &QThread::deleteLater); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| DownloadThread::~DownloadThread() { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  /////////////////////////////////////////////////////////////////////////////// |  | ||||||
|  // |  | ||||||
|  //                        USING THE DC BOOTLOADER |  | ||||||
|  // |  | ||||||
|  /////////////////////////////////////////////////////////////////////////////// |  | ||||||
|  |  | ||||||
|  1  :   bl_reboot()     // send to application, want DC2 to reset (in order to |  | ||||||
|                         // start the bootloader) |  | ||||||
|                         // |  | ||||||
|                         // NOTE: this function is NOT reliable !!! Sometimes it |  | ||||||
|                         // simply does not work, in which case bl_startBL, |  | ||||||
|                         // bl_checkBL and bl_isUp do not work as well. |  | ||||||
|                         // Alas, there is no feedback if bl_reboot worked! |  | ||||||
|                         // |  | ||||||
|                         // NOTE: this function can be called only once per |  | ||||||
|                         // minute, because once called again, the controller |  | ||||||
|                         // performs some self-checks consuming some time. |  | ||||||
|                         // |  | ||||||
|                         // NOTE: after a successful bl_reboot(), the device is |  | ||||||
|                         // waiting about 4 seconds in the bootloader. To stay in |  | ||||||
|                         // the bootloader, we have to send the command |  | ||||||
|                         // bl_startBL(), which is kind of a misnomer, as it |  | ||||||
|                         // should be bl_doNotLeaveBL(). |  | ||||||
|                         // |  | ||||||
|  2  :   bl_startBL():   // send within 4s after DC power-on, otherwise |  | ||||||
|                         // bootloader is left. |  | ||||||
|                         // |  | ||||||
|                         // NOTE: a running bootloader is a MUST for the download |  | ||||||
|                         // process of a device controller firmware as it does |  | ||||||
|                         // the actual writing of the memory (the bl_reboot() |  | ||||||
|                         // from above erases the available memory). |  | ||||||
|                         // |  | ||||||
|  3  :   bl_check():     // send command to verify if bl is up |  | ||||||
|                         // |  | ||||||
|                         // NOTE: this command is kind of a request that we want |  | ||||||
|                         // to check if the bootloader is up. The device |  | ||||||
|                         // (actually the bootloader) responds with its version. |  | ||||||
|                         // |  | ||||||
|  4  :   bl_isUp():      // returns true if bl is up and running |  | ||||||
|                         // |  | ||||||
|                         // NOTE: we know what the bootloader version actually is |  | ||||||
|                         // as the bootloader does not change. By comparing the |  | ||||||
|                         // string received in the previous step with this known |  | ||||||
|                         // version string we know if the bootloader is up. |  | ||||||
|                         // |  | ||||||
|                         // NOTE FOR ALL PREVIOUS STEPS: execute them in their |  | ||||||
|                         // own slots each to be sure to receive any possible |  | ||||||
|                         // responds from the device. |  | ||||||
|                         // |  | ||||||
|  5  :   bl_sendAddress(blockNumber) |  | ||||||
|                         // send start address, nr of 64-byte block, start with 0 |  | ||||||
|                         // will be sent only for following block-numbers: |  | ||||||
|                         // 0, 1024, 2048, 3072 and 4096, so basically every |  | ||||||
|                         // 64kByte. |  | ||||||
|                         // for other addresses nothing happens |  | ||||||
|  |  | ||||||
|  6  :   bl_wasSendingAddOK() |  | ||||||
|                         // return val:  0: no response by now |  | ||||||
|                         //              1: error |  | ||||||
|                         //             10: OK |  | ||||||
|  |  | ||||||
|  7  :   bl_sendDataBlock() |  | ||||||
|                         // send 64 byte from bin file |  | ||||||
|  |  | ||||||
|  8  :   bl_sendLastBlock() |  | ||||||
|                         // send this command after all data are transferred |  | ||||||
|  |  | ||||||
|  9  :   bl_wasSendingDataOK() |  | ||||||
|                         // return val:  0: no response by now |  | ||||||
|                         //              1: error |  | ||||||
|                         //             10: OK |  | ||||||
|  |  | ||||||
|  10 :   bl_stopBL()     // leave bl and start (the new) application |  | ||||||
|                         // |  | ||||||
|                         // NOTE: this function MUST work under all conditions. |  | ||||||
|                         // Alas, there is no direct result for this command, so |  | ||||||
|                         // the only way of knowing it was successful is to ask |  | ||||||
|                         // the device if the bootloader is still running. |  | ||||||
|                         // There is no problem to repeat this command until the |  | ||||||
|                         // bootloader is really not running anymore. |  | ||||||
|  */ |  | ||||||
| void DownloadThread::run() { |  | ||||||
|     // download thread running in ca-master sends the dc-file down to firmware |  | ||||||
|     // TODO: send the json files as well |  | ||||||
|  |  | ||||||
|     m_hw->dcDownloadRequestAck(); |  | ||||||
|  |  | ||||||
|     qCritical() << "DownloadThread::run(): DOWNLOAD THREAD STARTED"; |  | ||||||
|  |  | ||||||
|     // load binary device controller file into memory |  | ||||||
|     QByteArray ba = loadBinaryDCFile(m_hw->dcDownloadFileName()); |  | ||||||
|     if (ba.size() > 0) { |  | ||||||
|         uint16_t const totalBlocks = (((ba.size())%64)==0) ? (ba.size()/64) : (ba.size()/64)+1; |  | ||||||
|         m_hw->dcDownloadSetTotalBlockNumber(totalBlocks); |  | ||||||
|  |  | ||||||
|         // fill last block of data to be sent with 0xFF |  | ||||||
|         ba = ba.leftJustified(totalBlocks*64, (char)(0xFF)); |  | ||||||
|  |  | ||||||
|         resetDeviceController(); |  | ||||||
|         if (startBootloader()) { |  | ||||||
|  |  | ||||||
|             qCritical() << "DownloadThread::run(): TOTAL NUMBER OF BYTES TO SEND TO DC" << ba.size(); |  | ||||||
|             qCritical() << "DownloadThread::run(): TOTAL NUMBER OF BLOCKS" << totalBlocks; |  | ||||||
|  |  | ||||||
|             int currentBlock = 0; |  | ||||||
|             DownloadResult res = DownloadResult::OK; |  | ||||||
|             qCritical() << "64-byte block " << currentBlock; |  | ||||||
|             while (res != DownloadResult::ERROR &&  currentBlock < totalBlocks) { |  | ||||||
|                 if ((res = sendNextAddress(currentBlock)) != DownloadResult::ERROR) { |  | ||||||
|                     if ((res = sendNextDataBlock(ba, currentBlock)) != DownloadResult::ERROR) { |  | ||||||
|                         m_hw->dcDownloadSetCurrentBlockNumber(currentBlock); |  | ||||||
|                         currentBlock += 1; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             qCritical() << "DownloadThread::run(): last 64-byte block %04d" << currentBlock; |  | ||||||
|  |  | ||||||
|             int const rest = ba.size() % 64; |  | ||||||
|             int const offset = ba.size() - rest; |  | ||||||
|             char const *startAddress = ba.constData() + offset; |  | ||||||
|  |  | ||||||
|             if (rest > 0) { |  | ||||||
|                 // SHOULD NEVER HAPPEN !!! |  | ||||||
|                 uint8_t local[66]; |  | ||||||
|                 memset(local, 0xFF, sizeof(local)); |  | ||||||
|                 memcpy(local, startAddress, rest); |  | ||||||
|                 qCritical() << "DownloadThread::run(): ERROR SEND REMAINING" << rest << "BYTES"; |  | ||||||
|                 m_hw->bl_sendDataBlock(64, local); |  | ||||||
|             } else { |  | ||||||
|                 m_hw->bl_sendLastBlock(); |  | ||||||
|                 m_hw->dcDownloadSetCurrentBlockNumber(currentBlock); |  | ||||||
|             } |  | ||||||
|             qCritical() << "DownloadThread::run(): last result" << (int)sendStatus(m_hw->bl_wasSendingDataOK()); |  | ||||||
|         } |  | ||||||
|         stopBootloader();   // there is no harm in stopping the bootloader even |  | ||||||
|     }                       // if it was not started at all |  | ||||||
|  |  | ||||||
| #if 0 |  | ||||||
|     // test code: |  | ||||||
|     uint16_t const totalBlocks = 100; |  | ||||||
|     m_hw->dcDownloadSetTotalBlockNumber(totalBlocks); |  | ||||||
|  |  | ||||||
|     for (uint16_t currentBlock = 0; currentBlock <= totalBlocks; ++currentBlock) { |  | ||||||
|         m_hw->dcDownloadSetCurrentBlockNumber(currentBlock); |  | ||||||
|         QThread::msleep(100); |  | ||||||
|     } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|     m_hw->dcDownloadSetRunning(false); |  | ||||||
|     m_hw->dcDownloadSetFinished(true); |  | ||||||
|  |  | ||||||
|     qCritical() << QDateTime::currentDateTime().toString(Qt::ISODate) + "DOWNLOAD THREAD FINISHED"; |  | ||||||
|  |  | ||||||
|     // the object deletes itself ! This is the last line in run(). |  | ||||||
|     // Never touch the object after this statement |  | ||||||
|     // m_hw->dcDownloadThreadFinalize(this); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| DownloadThread::DownloadResult DownloadThread::sendStatus(int ret) const { |  | ||||||
|     switch (ret) {                  // return values of dc are: |  | ||||||
|     case 0:                         // 0: no answer by now |  | ||||||
|         return DownloadResult::NOP; // 1: error |  | ||||||
|     case 10:                        // 10: success |  | ||||||
|         return DownloadResult::OK; |  | ||||||
|     default:; |  | ||||||
|     } |  | ||||||
|     return DownloadResult::ERROR; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| DownloadThread::DownloadResult |  | ||||||
| DownloadThread::sendNextAddress(int bNum) const { |  | ||||||
|     // sends address only if blockNumber is one of 0, 1024, 2048, 3072, 4096 |  | ||||||
|     int noAnswerCount = 0; |  | ||||||
|     int errorCount = 0; |  | ||||||
|     if ( bNum==0 || bNum==1024 || bNum==2048 || bNum==3072 || bNum==4096 ) { |  | ||||||
|         // qDebug() << "addr-block" << bNum << "..."; |  | ||||||
|         while (noAnswerCount <= 250) { |  | ||||||
|             m_hw->bl_sendAddress(bNum); |  | ||||||
|             QThread::msleep(100); |  | ||||||
|             DownloadResult const res = sendStatus(m_hw->bl_wasSendingAddOK()); |  | ||||||
|             if (res != DownloadResult::NOP) { |  | ||||||
|                 if (res == DownloadResult::ERROR) { |  | ||||||
|                     if (++errorCount >= 10) { |  | ||||||
|                         qCritical() << "addr-block" << bNum << "...FAILED"; |  | ||||||
|                         return res; |  | ||||||
|                     } |  | ||||||
|                 } else { // res == DownloadResult::OK |  | ||||||
|                     // qInfo() << "addr-block" << bNum << "...OK"; |  | ||||||
|  |  | ||||||
|                         // TODO: hier ins shared-mem schreiben |  | ||||||
|  |  | ||||||
|                     return res; |  | ||||||
|                 } |  | ||||||
|             } else { |  | ||||||
|                 noAnswerCount += 1; // no answer by now |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         // wait max. about 3 seconds |  | ||||||
|         return DownloadResult::TIMEOUT; |  | ||||||
|     } |  | ||||||
|     // blockNumber is not one of 0, 1024, 2048, 3072, 4096 -> do nothing |  | ||||||
|     return DownloadResult::NOP; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| DownloadThread::DownloadResult |  | ||||||
| DownloadThread::sendNextDataBlock(QByteArray const &binary, int bNum) const { |  | ||||||
|     uint8_t local[66]; |  | ||||||
|     int const bAddr = bNum * 64; |  | ||||||
|     int noAnswerCount = 0; |  | ||||||
|     int errorCount = 0; |  | ||||||
|  |  | ||||||
|     memcpy(local, binary.constData() + bAddr, 64); |  | ||||||
|     local[64] = local[65] = 0x00; |  | ||||||
|  |  | ||||||
|     // QByteArray b((const char *)(&local[0]), 64); |  | ||||||
|     // qCritical() << "SNDB" << bNum << b.size() << b.toHex(); |  | ||||||
|  |  | ||||||
|     while (noAnswerCount <= 250) { |  | ||||||
|         m_hw->bl_sendDataBlock(64, local); |  | ||||||
|         QThread::msleep(10); |  | ||||||
|         DownloadResult const res = sendStatus(m_hw->bl_wasSendingDataOK()); |  | ||||||
|         if (res != DownloadResult::NOP) { |  | ||||||
|             if (res == DownloadResult::ERROR) { |  | ||||||
|                 if (++errorCount >= 10) { |  | ||||||
|                     qCritical() << "data for block" << bNum << "...FAILED"; |  | ||||||
|                     return res; |  | ||||||
|                 } |  | ||||||
|             } else { |  | ||||||
|                 // qInfo() << "data for block" << bNum << "OK"; |  | ||||||
|  |  | ||||||
|                     // TODO: hier ins shared mem schreiben |  | ||||||
|  |  | ||||||
|                 return res; |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             noAnswerCount += 1; // no answer by now |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     // wait max. about 3 seconds |  | ||||||
|     return DownloadResult::TIMEOUT; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool DownloadThread::startBootloader() const { |  | ||||||
|     qDebug() << "starting bootloader..."; |  | ||||||
|     int nTry = 5; |  | ||||||
|     while (--nTry >= 0) { |  | ||||||
|         m_hw->bl_startBL(); |  | ||||||
|         QThread::msleep(5000); |  | ||||||
|         m_hw->bl_checkBL(); |  | ||||||
|         if (m_hw->bl_isUp()) { |  | ||||||
|             qInfo() << "starting bootloader...OK"; |  | ||||||
|             QThread::msleep(5000); |  | ||||||
|             return true; |  | ||||||
|         } else { |  | ||||||
|             qCritical() << "bootloader not up (" << nTry << ")"; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     qCritical() << "starting bootloader...FAILED"; |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool DownloadThread::stopBootloader() const { |  | ||||||
|     qDebug() << "stopping bootloader..."; |  | ||||||
|     int nTry = 5; |  | ||||||
|     while (--nTry >= 0) { |  | ||||||
|         m_hw->bl_stopBL(); |  | ||||||
|         QThread::msleep(500); |  | ||||||
|         if (!m_hw->bl_isUp()) { |  | ||||||
|             qInfo() << "stopping bootloader...OK"; |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     qCritical() << "stopping bootloader...FAILED"; |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool DownloadThread::resetDeviceController() const { |  | ||||||
|     qDebug() << "resetting device controller..."; |  | ||||||
|     m_hw->bl_rebootDC(); |  | ||||||
|     // wait maximally 3 seconds, before starting bootloader |  | ||||||
|     QThread::sleep(1); |  | ||||||
|     qInfo() << "resetting device controller...OK"; |  | ||||||
|     return true; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| QByteArray DownloadThread::loadBinaryDCFile(QString filename) const { |  | ||||||
|     qDebug() << "loading dc binary" << filename << "..."; |  | ||||||
|  |  | ||||||
|     QFile file(filename); // closed in destructor call |  | ||||||
|     if (!file.exists()) { |  | ||||||
|         qCritical() << file.fileName() << "does not exist"; |  | ||||||
|         return QByteArray(); |  | ||||||
|     } |  | ||||||
|     if (!file.open(QIODevice::ReadOnly)) { |  | ||||||
|         qCritical() << "cannot open file" << file.fileName(); |  | ||||||
|         return QByteArray(); |  | ||||||
|     } |  | ||||||
|     qInfo() << "loading dc binary" << filename << "...OK"; |  | ||||||
|     return file.readAll(); |  | ||||||
| } |  | ||||||
							
								
								
									
										294
									
								
								src/hwapi.cpp
									
									
									
									
									
								
							
							
						
						
									
										294
									
								
								src/hwapi.cpp
									
									
									
									
									
								
							| @@ -17,19 +17,9 @@ | |||||||
|             und hier in hwapi die entprellten Werte fuer Tueren und Kasse verwenden. |             und hier in hwapi die entprellten Werte fuer Tueren und Kasse verwenden. | ||||||
|             Problem war: Signal "Kasse entnommen" war zu langsam -> manchmal abr nicht gesendet |             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 |  | ||||||
|  |  | ||||||
| */ | */ | ||||||
|  |  | ||||||
| #include "hwapi.h" | #include "hwapi.h" | ||||||
| #include "download_thread.h" |  | ||||||
| #include "reporting_thread.h" |  | ||||||
|  |  | ||||||
| #include <cstring> |  | ||||||
| #include <QThread> |  | ||||||
| #include <QDebug> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| static uint32_t hwapi_lastStartAmount; | static uint32_t hwapi_lastStartAmount; | ||||||
| static uint32_t hwapi_lastTotalAmount; | static uint32_t hwapi_lastTotalAmount; | ||||||
| @@ -40,15 +30,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)); | ||||||
| @@ -131,7 +115,8 @@ 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) | ||||||
| @@ -229,9 +214,6 @@ void hwapi::sub_slotCoin16(void) | |||||||
|     emit hwapi_doorAllDoorsClosed(); |     emit hwapi_doorAllDoorsClosed(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void hwapi::coinAttached() { |  | ||||||
|     emit hwapi_coinAttached(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -4406,273 +4388,3 @@ uint16_t hwapi::bna_getStackerLevel(uint32_t *amountInStacker, uint16_t *countOf | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // 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() { |  | ||||||
|     return this; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadRequest(QString const &dcFileToDownload) const { |  | ||||||
|     SharedMem *data = SharedMem::getData(); |  | ||||||
|     if (!data) { |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     char *fNameBuffer = data->m_downLoadDC.m_filename[(int)SharedMem::DCDownload::FILE_INDEX::DC_BINARY]; |  | ||||||
|     size_t const size = sizeof(data->m_downLoadDC.m_filename); |  | ||||||
|  |  | ||||||
|     std::memset(fNameBuffer, 0x00, size); |  | ||||||
|     std::memcpy(fNameBuffer, dcFileToDownload.toStdString().c_str(), |  | ||||||
|                 std::min(size, strlen(fNameBuffer)-1)); |  | ||||||
|  |  | ||||||
|     data->m_downLoadDC.m_totalBlocks = 0; |  | ||||||
|     data->m_downLoadDC.m_currentblockNumber = 0; |  | ||||||
|  |  | ||||||
|     data->m_downLoadDC.m_requested = true; |  | ||||||
|     data->m_downLoadDC.m_running = false;   // download thread is not running |  | ||||||
|     data->m_downLoadDC.m_finished = true; |  | ||||||
|  |  | ||||||
|     return true; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadRequested() const { |  | ||||||
|     SharedMem const *data = SharedMem::getData(); |  | ||||||
|     // should be false at entry |  | ||||||
|     return data ? data->m_downLoadDC.m_requested.load() : false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadResetRequest() const { |  | ||||||
|     SharedMem *data = SharedMem::getData(); |  | ||||||
|     if (data) { |  | ||||||
|         data->m_downLoadDC.m_requested = false; |  | ||||||
|     } |  | ||||||
|     return true; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadRequestAck() const { |  | ||||||
|     SharedMem *data = SharedMem::getData(); |  | ||||||
|     if (data) { |  | ||||||
|         if (data->m_downLoadDC.m_requested) { |  | ||||||
|             data->m_downLoadDC.m_requested = false; |  | ||||||
|             data->m_downLoadDC.m_running = true; |  | ||||||
|             data->m_downLoadDC.m_finished = false; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadRunning() const { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |  | ||||||
|     if (data) { |  | ||||||
|         int cnt = 10; |  | ||||||
|         while (--cnt > 0) { |  | ||||||
|             bool running = data->m_downLoadDC.m_running.load(); |  | ||||||
|             bool finished = data->m_downLoadDC.m_finished.load(); |  | ||||||
|             if (!running || finished) { |  | ||||||
|                 if (cnt < 3) { |  | ||||||
|                     qCritical() << "DOWNLOAD THREAD NOT RUNNING" << running << finished; |  | ||||||
|                 } |  | ||||||
|                 QThread::msleep(500); |  | ||||||
|             } else break; |  | ||||||
|         } |  | ||||||
|         // qCritical() << "DOWNLOAD RUNNING" << cnt << (cnt > 0); |  | ||||||
|         return (cnt > 0); |  | ||||||
|     } |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void hwapi::dcDownloadThreadFinalize(DownloadThread *dthread) { |  | ||||||
|     delete dthread; |  | ||||||
|     m_downloadThread = nullptr; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadFinished() { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |  | ||||||
|     if (data) { |  | ||||||
|         int cnt = 10; |  | ||||||
|         while ((--cnt > 0) && |  | ||||||
|                ((data->m_downLoadDC.m_running.load() == true) && |  | ||||||
|                 (data->m_downLoadDC.m_finished.load() == false))) { |  | ||||||
|             QThread::sleep(1); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         //if (cnt > 0) { |  | ||||||
|         //    delete m_downloadThread; |  | ||||||
|         //    m_downloadThread = nullptr; |  | ||||||
|         //    return true; |  | ||||||
|         //} |  | ||||||
|     } |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // download thread |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadThreadStart() { |  | ||||||
|     m_downloadThread = new DownloadThread(this); |  | ||||||
|     if (m_downloadThread) { |  | ||||||
|         m_downloadThread->start(); |  | ||||||
|         int cnt  = 10; |  | ||||||
|         while (--cnt > 0 && !dcDownloadThreadRunning()) { |  | ||||||
|             QThread::msleep(200); |  | ||||||
|         } |  | ||||||
|         return (cnt > 0); |  | ||||||
|     } |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadThreadRunning() const { |  | ||||||
|     return (dcDownloadGetRunning() == true) |  | ||||||
|         && (dcDownloadGetFinished() == false); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadThreadFinished() const { |  | ||||||
|     return (dcDownloadThreadRunning() == false); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| // report thread |  | ||||||
| bool hwapi::dcDownloadReportThreadStart() { // only start reporting thread |  | ||||||
|     int cnt = 10;                           // if download thread is running |  | ||||||
|     while (--cnt > 0 && !dcDownloadRunning()) { |  | ||||||
|         QThread::msleep(500); |  | ||||||
|     } |  | ||||||
|     if (cnt > 0) { |  | ||||||
|         m_reportingThread = new ReportingThread(this); |  | ||||||
|         if (m_reportingThread) { |  | ||||||
|             m_reportingThread->start(); |  | ||||||
|             cnt  = 10; |  | ||||||
|             while (--cnt > 0 && !dcDownloadReportThreadRunning()) { |  | ||||||
|                 QThread::msleep(200); |  | ||||||
|             } |  | ||||||
|             return (cnt > 0); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadReportThreadRunning() const { |  | ||||||
|     return m_reportingThread ? m_reportingThread->isRunning() : false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void hwapi::dcDownloadReportThreadFinalize() { |  | ||||||
|     if (m_reportingThread) { |  | ||||||
|         if (m_reportingThread->isFinished()) { |  | ||||||
|             delete m_reportingThread; |  | ||||||
|             m_reportingThread = nullptr; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void hwapi::dcDownloadReportThreadQuit() { |  | ||||||
|     if (m_reportingThread) { |  | ||||||
|         m_reportingThread->quit(); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadReportThreadFinished() const { |  | ||||||
|     return m_reportingThread ? m_reportingThread->isFinished() : false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadReportStart() const { |  | ||||||
|     int cnt = 10; |  | ||||||
|     while (--cnt > 0 && !dcDownloadRunning()) { |  | ||||||
|         QThread::msleep(200); |  | ||||||
|     } |  | ||||||
|     return (cnt == 0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadReportRunning() const { |  | ||||||
|     return dcDownloadReportThreadRunning(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadReportFinished() { |  | ||||||
|     int cnt = 10; |  | ||||||
|     while (--cnt > 0 && !dcDownloadReportThreadFinished()) { |  | ||||||
|         QThread::sleep(1); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (cnt == 0 && !dcDownloadReportThreadFinished()) { |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (dcDownloadReportThreadFinished()) { |  | ||||||
|         delete m_reportingThread; |  | ||||||
|         m_reportingThread = nullptr; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return true; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| QString hwapi::dcDownloadFileName() const { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |  | ||||||
|     return data ? data->m_downLoadDC.m_filename[(int)SharedMem::DCDownload::FILE_INDEX::DC_BINARY] : ""; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadSetRequested(bool requested) { |  | ||||||
|     SharedMem *data = SharedMem::getData(); |  | ||||||
|     if (data) { |  | ||||||
|         data->m_downLoadDC.m_requested = requested; |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadSetRunning(bool running) { |  | ||||||
|     SharedMem *data = SharedMem::getData(); |  | ||||||
|     if (data) { |  | ||||||
|         data->m_downLoadDC.m_running = running; |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadSetFinished(bool finished) { |  | ||||||
|     SharedMem *data = SharedMem::getData(); |  | ||||||
|     if (data) { |  | ||||||
|         data->m_downLoadDC.m_finished = finished; |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void hwapi::dcDownloadSetTotalBlockNumber(uint16_t totalBlockNumber) { |  | ||||||
|     SharedMem::getData()->m_downLoadDC.m_totalBlocks = totalBlockNumber; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void hwapi::dcDownloadSetCurrentBlockNumber(uint16_t currentBlockNumber) { |  | ||||||
|     SharedMem::getData()->m_downLoadDC.m_currentblockNumber = currentBlockNumber; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| uint16_t hwapi::dcDownloadGetTotalBlockNumber() const { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |  | ||||||
|     return data ? data->m_downLoadDC.m_totalBlocks.load() : 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| uint16_t hwapi::dcDownloadGetCurrentBlockNumber() const { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |  | ||||||
|     return data ? data->m_downLoadDC.m_currentblockNumber.load() : 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadGetRequested() const { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |  | ||||||
|     return data ? data->m_downLoadDC.m_requested.load() : 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadGetRunning() const { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |  | ||||||
|     return data ? data->m_downLoadDC.m_running.load() : 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool hwapi::dcDownloadGetFinished() const { |  | ||||||
|     SharedMem const *data = SharedMem::getDataConst(); |  | ||||||
|     return data ? data->m_downLoadDC.m_running.load() : 0; |  | ||||||
| } |  | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								src/main.cpp
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								src/main.cpp
									
									
									
									
									
								
							| @@ -18,11 +18,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[]) { | ||||||
|   | |||||||
| @@ -1,155 +0,0 @@ | |||||||
| #include "reporting_thread.h" |  | ||||||
| #include "shared_mem_buffer.h" |  | ||||||
| #include "hwapi.h" |  | ||||||
|  |  | ||||||
| #include <QDateTime> |  | ||||||
| #include <QDebug> |  | ||||||
|  |  | ||||||
| ReportingThread::ReportingThread(hwapi *hw) |  | ||||||
|   : m_hw(hw) |  | ||||||
|   , m_fileToDownload(m_hw->dcDownloadFileName()) { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ReportingThread::~ReportingThread() { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // download thread running in ca-slave sends reports of download process to |  | ||||||
| // each component which has connects for the corresponding signals. |  | ||||||
| void ReportingThread::run() { |  | ||||||
|  |  | ||||||
|     qCritical() << QDateTime::currentDateTime() << "START DOWNLOAD THREAD"; |  | ||||||
|  |  | ||||||
|     static QString report(""); |  | ||||||
|  |  | ||||||
|     int cnt = 5; |  | ||||||
|     while (!m_hw->dcDownloadGetRunning()) { |  | ||||||
|         if (--cnt > 0) { |  | ||||||
|             report =  QString("%1 waiting for download to start %2") |  | ||||||
|                             .arg(QDateTime::currentDateTime().toString(Qt::ISODate)) |  | ||||||
|                             .arg(cnt); |  | ||||||
|             qCritical() << __LINE__ << "STATUS" << report; |  | ||||||
|             emit m_hw->hwapi_reportDCDownloadStatus(report); |  | ||||||
|             QThread::sleep(1); |  | ||||||
|         } else break; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| #if 0 |  | ||||||
|     if (cnt == 0) { |  | ||||||
|         m_hw->dcDownloadResetRequest(); |  | ||||||
|         status = QString("%1 reset download request") |  | ||||||
|                         .arg(QDateTime::currentDateTime().toString(Qt::ISODate)); |  | ||||||
|         qCritical() << __LINE__ << "STATUS" << status; |  | ||||||
|         emit m_hw->hwapi_reportDCDownloadStatus(status); |  | ||||||
|  |  | ||||||
|         cnt = 5; |  | ||||||
|         while (!m_hw->dcDownloadRunning()) { |  | ||||||
|             if (--cnt > 0) { |  | ||||||
|                 QThread::sleep(1); |  | ||||||
|             } else break; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if (cnt == 0) { |  | ||||||
|             status = QString("%1 download request failure") |  | ||||||
|                             .arg(QDateTime::currentDateTime().toString(Qt::ISODate)); |  | ||||||
|             qCritical() << __LINE__ << "STATUS" << status; |  | ||||||
|             emit m_hw->hwapi_reportDCDownloadFailure(status); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     uint16_t const tnr = 1750; |  | ||||||
|     uint16_t cnr = 0; |  | ||||||
|  |  | ||||||
|     while (cnr <= tnr) { |  | ||||||
|         QThread::msleep(100); |  | ||||||
|         QString report(""); |  | ||||||
|  |  | ||||||
|         if (cnr > 0) { |  | ||||||
|             double percent = ((double)cnr / (double)tnr) * 100.0; |  | ||||||
|             report = QString(": total blocks %1, current block %2 [%3]") |  | ||||||
|                     .arg(tnr).arg(cnr).arg(percent, 0, 'f', 2); |  | ||||||
|         } else { |  | ||||||
|             report = QString(": total blocks %1, current block %2 [0]") |  | ||||||
|                     .arg(tnr).arg(cnr); |  | ||||||
|         } |  | ||||||
|         status = QDateTime::currentDateTime().toString(Qt::ISODate) + report; |  | ||||||
|  |  | ||||||
|         qCritical() << "STATUS" << status; |  | ||||||
|  |  | ||||||
|         emit m_hw->hwapi_reportDCDownloadStatus(status); |  | ||||||
|         cnr += 1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (tnr == cnr) { |  | ||||||
|         m_hw->hwapi_reportDCDownloadSuccess( |  | ||||||
|             QString("SUCCESS DOWNLOADING") + m_fileToDownload); |  | ||||||
|     } else { |  | ||||||
|         m_hw->hwapi_reportDCDownloadFailure( |  | ||||||
|             QString("ERROR DOWNLOADING %1 (total blocks=%2, sent blocks=%3)") |  | ||||||
|                 .arg(m_fileToDownload).arg(tnr).arg(cnr)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|     uint16_t const totalBlocks = m_hw->dcDownloadGetTotalBlockNumber(); |  | ||||||
|  |  | ||||||
|     qCritical() << QDateTime::currentDateTime() << "TOTAL BLOCKS" << totalBlocks; |  | ||||||
|  |  | ||||||
|     if (totalBlocks) { |  | ||||||
|         qint64 const start = QDateTime::currentMSecsSinceEpoch(); |  | ||||||
|         double durationMillis = 0; |  | ||||||
|         uint16_t currentBlockNumber = 0; |  | ||||||
|  |  | ||||||
|         while (m_hw->dcDownloadGetRunning()) { |  | ||||||
|             currentBlockNumber = m_hw->dcDownloadGetCurrentBlockNumber(); |  | ||||||
|  |  | ||||||
|             durationMillis += QDateTime::currentMSecsSinceEpoch() - start; |  | ||||||
|  |  | ||||||
|             double const timeAveragePerBlock = (currentBlockNumber > 0) ? (durationMillis / currentBlockNumber) : durationMillis; |  | ||||||
|             double const estimatedSecondsLeft = (timeAveragePerBlock * (totalBlocks - currentBlockNumber)) / 1000.0; |  | ||||||
|  |  | ||||||
|             double percent = ((double)currentBlockNumber / (double)totalBlocks) * 100.0; |  | ||||||
|             report = QString(": total blocks %1, current block %2 [%3] (est. time left: %4s)") |  | ||||||
|                         .arg(totalBlocks) |  | ||||||
|                         .arg(currentBlockNumber) |  | ||||||
|                         .arg(percent, 0, 'f', 2) |  | ||||||
|                         .arg(estimatedSecondsLeft, 0, 'f', 2); |  | ||||||
|  |  | ||||||
|             qCritical() << "RT report" << report; |  | ||||||
|  |  | ||||||
|             emit m_hw->hwapi_reportDCDownloadStatus(report); |  | ||||||
|             QThread::msleep(100); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         QThread::msleep(100); |  | ||||||
|  |  | ||||||
|         if (totalBlocks == currentBlockNumber) { |  | ||||||
|             m_hw->hwapi_reportDCDownloadSuccess( |  | ||||||
|                 QString("SUCCESS DOWNLOADING") + m_fileToDownload); |  | ||||||
|         } else { |  | ||||||
|             m_hw->hwapi_reportDCDownloadFailure( |  | ||||||
|                 QString("ERROR DOWNLOADING %1 (total blocks=%2, sent blocks=%3)") |  | ||||||
|                     .arg(m_fileToDownload).arg(totalBlocks).arg(currentBlockNumber)); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     qCritical() << QDateTime::currentDateTime() << __PRETTY_FUNCTION__ |  | ||||||
|                 << QString("line=%1 REPORT THREAD ABOUT TO FINISH").arg(__LINE__); |  | ||||||
|  |  | ||||||
|     cnt = 10; |  | ||||||
|  |  | ||||||
|     bool running = m_hw->dcDownloadGetRunning(); |  | ||||||
|     bool finished = m_hw->dcDownloadGetFinished(); |  | ||||||
|  |  | ||||||
|     while (--cnt > 0 && (running && !finished)) { |  | ||||||
|         qCritical() << QDateTime::currentDateTime() << __PRETTY_FUNCTION__ |  | ||||||
|                     << QString("line=%1 REPORT THREAD: WAIT FOR END OF DOWNLOAD THREAD %2 %3 (%4)") |  | ||||||
|             .arg(__LINE__).arg(running).arg(finished).arg(cnt); |  | ||||||
|         QThread::sleep(1); |  | ||||||
|         running = m_hw->dcDownloadGetRunning(); |  | ||||||
|         finished = m_hw->dcDownloadGetFinished(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     qCritical() << QDateTime::currentDateTime() << __PRETTY_FUNCTION__ |  | ||||||
|                 << QString("line=%1 FINISH REPORT THREAD").arg(__LINE__); |  | ||||||
| } |  | ||||||
| @@ -48,16 +48,6 @@ T_runProc::T_runProc() | |||||||
| void T_runProc::runProc_slotProcess(void) | void T_runProc::runProc_slotProcess(void) | ||||||
| { | { | ||||||
| #ifndef THIS_IS_CA_MASTER | #ifndef THIS_IS_CA_MASTER | ||||||
|     bool const coinAttached = epi_getDI_CoinAttach(); |  | ||||||
|     // exchange: (atomically) replaces the underlying value of m_coinAttached |  | ||||||
|     // with the value of coinAttached, returns the value of m_coinAttached |  | ||||||
|     // before the call |  | ||||||
|     if (m_coinAttached.exchange(coinAttached) == false) { |  | ||||||
|         if (coinAttached) { |  | ||||||
|             // old value was false, and new value is true |  | ||||||
|             emit runProc_coinAttached(); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     cash_paymentProcessing(); |     cash_paymentProcessing(); | ||||||
|     doors_supervise(); |     doors_supervise(); | ||||||
|     bl_performComplStart();     // neu 1.12.23 |     bl_performComplStart();     // neu 1.12.23 | ||||||
|   | |||||||
| @@ -12,7 +12,6 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| // store power on/off condition of the devices to control the data request | // store power on/off condition of the devices to control the data request | ||||||
|  |  | ||||||
| //static bool indat_savePrnPwr; | //static bool indat_savePrnPwr; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user