From d400f022161ff47f02cd0ea95a5076d0187ecd4d Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期五, 30 一月 2026 15:11:06 +0800
Subject: [PATCH] 1.接上,日志完善;

---
 SourceCode/Bond/Servo/CMaster.h |  290 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 282 insertions(+), 8 deletions(-)

diff --git a/SourceCode/Bond/Servo/CMaster.h b/SourceCode/Bond/Servo/CMaster.h
index 3868b59..20d4c3d 100644
--- a/SourceCode/Bond/Servo/CMaster.h
+++ b/SourceCode/Bond/Servo/CMaster.h
@@ -1,43 +1,317 @@
-#pragma once
+锘�#pragma once
 #include <list>
+#include <unordered_set>
 #include "CEquipment.h"
 #include "CEFEM.h"
 #include "CBonder.h"
+#include "CLoadPort.h"
+#include "CFliper.h"
+#include "CAligner.h"
+#include "CVacuumBake.h"
+#include "CBakeCooling.h"
+#include "CMeasurement.h"
+#include "CArm.h"
+#include "CArmTray.h"
 #include "CCLinkIEControl.h"
+#include "CRobotTask.h"
+#include "ProcessJob.h"
+#include "CControlJob.h"
+#include "../DAQBridge/core/Collector.h"
+#include "CJobDataS.h"
 
+class CModel;
+
+
+#define CTStep_Unknow                   0
+#define CTStep_LoadPort_Aligner         1
+#define CTStep_Aligner_Fliper           2
+#define CTStep_Fliper_Bonder1           3
+#define CTStep_Bonder1_Bonder2          4
+#define CTStep_Bonder2_VacuumBake       5
+#define CTStep_VacuumBake_VacuumBake    6
+#define CTStep_VacuumBake_BakeCooling   7
+#define CTStep_BakeCooling_BakeCooling1 8
+#define CTStep_BakeCooling_BakeCooling2 9
+#define CTStep_BakeCooling_BakeCooling3 10
+#define CTStep_BakeCooling_Measurement  11
+#define CTStep_Measurement_LoadPort     12
+#define CTStep_begin                    CTStep_LoadPort_Aligner
+#define CTStep_end                      CTStep_Measurement_LoadPort
+
+#define ER_CODE_NOERROR                0
+#define ER_CODE_OPERATION_MODE_FAIL    -1
+#define ER_CODE_AOI_NG                 -2
 
 namespace SERVO {
+    enum class MASTERSTATE {
+        READY = 0,
+        STARTING,
+        RUNNING,
+        RUNNING_CONTINUOUS_TRANSFER,
+        RUNNING_BATCH,
+        STOPPING,
+        MSERROR,
+        ATHERERROR
+    };
+
+    enum class CurveMode {
+        Production = 0,
+        EmptyChamber
+    };
+
+    typedef std::function<void(void* pMaster, MASTERSTATE state)> ONMASTERSTATECHANGED;
     typedef std::function<void(void* pMaster, CEquipment* pEiuipment, BOOL bAlive)> ONEQALIVE;
-    typedef std::function<void(void* pEiuipment, CStep* pStep, int code, void* pData)> ONEQSTEPEVENT;
+    typedef std::function<void(CStep* pStep, int code, void* pData)> ONEQSTEPEVENT;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, int state, int alarmId, int unitId, int level)> ONEQALARM;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, CVcrEventReport* pReport)> ONEQVCREVENTREPORT;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, int code)> ONEQDATACHANGED;
+    typedef std::function<void(void* pMaster, CRobotTask* pTask, int code)> ONROBOTTASKEVENT;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, short status, __int64 data)> ONLOADPORTSTATUSCHANGED;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, int slotNo, PROCESS_STATE prevState, PROCESS_STATE state)> ONPROCESSSTATECHANGED;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, const std::vector<CParam>& params)> ONPROCESSDATAREPORTEX;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, const std::vector<CParam>& params)> ONSVDATAREPORT;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, int port, CJobDataS* pJobDataS)> ONJOBRECEIVED;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, int port, CJobDataS* pJobDataS)> ONJOBSENTOUT;
+    typedef std::function<void(void* pMaster, CEquipment* pEquipment, int unitId, int status, int reason)> ONEQSTATUSCHANGEDEX;
+    typedef std::function<void(void* pMaster, int round)> ONCTROUNDEND;
+    typedef std::function<void(void* pMaster, void* pj)> ONPJSTART;
+    typedef std::function<void(void* pMaster)> ONCONTROLJOBCHANGED;
     typedef struct _MasterListener
     {
+        ONMASTERSTATECHANGED    onMasterStateChanged;
         ONEQALIVE				onEqAlive;
         ONEQALIVE		        onEqCimStateChanged;
-        ONEQSTEPEVENT		    onEqStepEvent;
+        ONEQALARM               onEqAlarm;
+        ONEQVCREVENTREPORT	    onEqVcrEventReport;
+        ONEQDATACHANGED         onEqDataChanged;
+        ONROBOTTASKEVENT        onRobotTaskEvent;
+        ONLOADPORTSTATUSCHANGED	onLoadPortStatusChanged;
+        ONPROCESSSTATECHANGED   onProcessStateChanged;
+        ONSVDATAREPORT          onSVDataReport;
+        ONPROCESSDATAREPORTEX   onProcessDataReport;
+        ONJOBRECEIVED           onJobReceived;
+        ONJOBSENTOUT            onJobSentOut;
+        ONEQSTATUSCHANGEDEX       onEqStatusChanged;
+        ONCTROUNDEND            onCTRoundEnd;
+        ONPJSTART               onCjStart;
+        ONPJSTART               onCjEnd;
+        ONPJSTART               onPjStart;
+        ONPJSTART               onPjEnd;
+        ONPJSTART               onPanelStart;
+        ONPJSTART               onPanelEnd;
+        ONCONTROLJOBCHANGED     onControlJobChanged;
     } MasterListener;
 
-    class CMaster
+    class CMaster : public IResourceView
     {
     public:
         CMaster();
-        ~CMaster();
+        virtual ~CMaster();
 
 
     public:
+        void setModelCtx(CModel* pModel);
         void setListener(MasterListener listener);
+        CRobotTask* getActiveRobotTask();
         int init();
         int term();
+        int start();
+        int startContinuousTransfer();
+        int startBatch();
+        int stop(int nErCode = ER_CODE_NOERROR);
+        void clearError();
+        ULONGLONG getRunTime();
+        MASTERSTATE getState();
+        void setCurveMode(CurveMode mode);
+        CurveMode getCurveMode() const;
+        unsigned DispatchProc();
+        unsigned ReadBitsProc();
         void onTimer(UINT nTimerid);
+        std::list<CEquipment*>& getEquipmentList();
         CEquipment* getEquipment(int id);
+        CEquipment* getEquipment(int id) const;
+        void setCacheFilepath(const char* pszFilepath);
+        int abortCurrentTask();
+        int restoreCurrentTask();
+        int resendCurrentTask();
+        void setPortTypeEx(unsigned int index, BOOL enable, int type, int mode,
+            int cassetteType, int transferMode, BOOL autoChangeEnable);
+        void setPortType(unsigned int index, int type);
+        void setPortCassetteType(unsigned int index, SERVO::CassetteType type);
+        void setPortEnable(unsigned int index, BOOL bEnable);
+        void setCompareMapsBeforeProceeding(BOOL bCompare);
+        void setJobMode(BOOL bJobMode);
+        void datetimeSync(SYSTEMTIME& time);
+        void enableEventReport(bool bEnable);
+        void enableAlarmReport(bool bEnable);
+        bool isAlarmReportEnable();
+        int proceedWithCarrier(unsigned int port);
+        int carrierRelease(unsigned int port);
+        int getContinuousTransferCount();
+        void setContinuousTransferCount(int round);
+        int setProcessJobs(std::vector<CProcessJob*>& pjs);
+        std::vector<CProcessJob*>& getProcessJobs();
+        CProcessJob* getProcessJob(const std::string& id);
+        int setControlJob(CControlJob& controlJob);
+        CControlJob* getControlJob();
+        CLoadPort* getPortWithCarrierId(const std::string& carrierId) const;
+        bool saveState() const;
+        bool loadState();
+        void setStateFile(const std::string& path);
+        int getWipGlasses(std::vector<CGlass*>& glasses);
+        void test();
+        bool moveGlassToBuf(int eqid, int slotNo);
+        bool moveGlassToSlot(int eqid, int slotNo);
+        int getPortCassetteSnSeed(int port);
+        void setPortCassetteSnSeed(int port, int seed);
+        CGlass* getGlass(int scrPort, int scrSlot);
+        uint32_t SlotToMid(int eqid, int slot);
 
     private:
-        int addEquipment(CEquipment* pEquipment);
-        int addEFEM(StepListener& listener);
+        inline void lock() { EnterCriticalSection(&m_criticalSection); }
+        inline void unlock() { LeaveCriticalSection(&m_criticalSection); }
+        int addToEquipmentList(CEquipment* pEquipment);
+        CLoadPort* addLoadPort(int index);
+        CFliper* addFliper();
+        CVacuumBake* addVacuumBake();
+        CAligner* addAligner();
+        CEFEM* addEFEM();
+        CArm* addArm();
+        CArmTray* addArmTray(int index);
+        CBonder* addBonder(int index);
+        CBakeCooling* addBakeCooling();
+        CMeasurement* addMeasurement();
+        void connectEquipments();
+        int saveCache();
+        int saveCacheAndBackups();
+        int readCache();
+        void serialize(CArchive& ar);
+        void setState(MASTERSTATE state);
+        CRobotTask* createTransferTask(CEquipment* pSrcEq, CEquipment* pTarEq,
+            MaterialsType primaryType = MaterialsType::G1, MaterialsType secondaryType = MaterialsType::G2,
+            int armNo = 1, BOOL bJobMode = FALSE);
+        CRobotTask* createTransferTask_bonder_to_bakecooling(CEquipment* pSrcEq, CEquipment* pTarEq);
+        CRobotTask* createTransferTask_bake_to_cooling(CEquipment* pSrcEq);
+        CRobotTask* createTransferTask_bakecooling_to_measurement(CEquipment* pSrcEq, CEquipment* pTarEq);
+        CRobotTask* createTransferTask_restore(CEquipment* pEqSrc, CLoadPort** pPorts);
+        CRobotTask* createTransferTask_continuous_transfer(CEquipment* pSrcEq, int nSrcSlot,
+            CEquipment* pTarEq, int nTarSlot, int armNo = 1);
+
+    public:
+        // 鈥斺�� IResourceView 瑕嗗啓 鈥斺�旓紙娉ㄦ剰 const锛�
+        bool isProcessJobsEmpty() const override;
+        bool recipeExists(const std::string& ppid) const override;
+        bool carrierPresent(const std::string& carrierId) const override;
+        bool slotUsable(const std::string& carrierId, uint16_t slot) const override;
+        bool ceidDefined(uint32_t ceid) const override;
+        void setAllowedCeids(const std::vector<unsigned int>& ceids);
+        void handleCollectionEvent(uint32_t ceid);
+        bool raiseSoftAlarm(int alarmId,
+            const std::string& desc,
+            int level = -1,
+            int deviceId = 0,
+            int unitId = 0,
+            const char* deviceName = "Software",
+            const char* unitName = "App");
+
+    public:
+        int getLastError();
+        std::string& getLastErrorText();
+
+    public:
+        // 鏂板鍑芥暟
+        CProcessJob* acquireNextProcessJob();
+        CGlass* acquireNextGlass();
+        int acquireGlassToQueue();
+        bool addGlassToQueue(CGlass* pGlass);
+        bool glassFromQueueToInPorcess(CGlass* pGlass);
+        bool glassFromInPorcessToComplete(CGlass* pGlass);
+        bool processJobFromInPorcessToComplete(CProcessJob* pProcessJob);
+        bool checkAndUpdatePjComplete(CProcessJob* pJob);
+        bool checkAndUpdateCjComplete(CControlJob* pJob);
+        CProcessJob* getGlassProcessJob(CGlass* pGlass);
+        bool completeControlJob();
+        bool forceCompleteControlJob(std::string description);
+        bool canCreateControlJob();
+        bool canCompleteControlJob();
+        bool canDeleteControlJob();
+        
+        // DAQ Bridge 鐩稿叧
+        Collector* getCollector() const { return m_pCollector; }
 
     private:
+        CRITICAL_SECTION m_criticalSection;
         MasterListener m_listener;
         CCCLinkIEControl m_cclink;
         std::list<CEquipment*> m_listEquipment;
+        std::string m_strFilepath;
+        BOOL m_bDataModify;
+        bool m_bContinuousTransfer;
+        bool m_bBatch;
+
+    private:
+        /* 鐩戞帶姣旂壒浣嶇殑绾跨▼*/
+        HANDLE m_hEventReadBitsThreadExit[2];
+        HANDLE m_hReadBitsThreadHandle;
+        unsigned m_nReadBitsThreadAddr;
+
+        // 璋冨害绾跨▼
+        HANDLE m_hDispatchEvent;
+        HANDLE m_hEventDispatchThreadExit[2];
+        HANDLE m_hDispatchThreadHandle;
+        unsigned m_nDispatchThreadAddr;
+
+        // 鍚姩鏃堕棿锛岃繍琛屾椂闂达紝鐘舵��
+        ULONGLONG m_ullStartTime;
+        ULONGLONG m_ullRunTime;
+        MASTERSTATE m_state;
+        CurveMode m_curveMode;
+
+        // 褰撳墠浠诲姟鍜屽凡瀹屾垚浠诲姟鍒楄〃
+        CRobotTask* m_pActiveRobotTask;
+        std::list< CRobotTask* > m_listTask;
+
+        // 閿欒浠g爜
+        int m_nLastError;
+        std::string m_strLastError;
+
+        // 鍦ㄥ紑濮嬪伐鑹哄墠鏄惁闇�瑕佸厛姣旇緝 map
+        BOOL m_isCompareMapsBeforeProceeding;
+        BOOL m_bJobMode;
+
+        // 鍗冧紶鍦堟暟璁℃暟
+        int m_nContinuousTransferCount;
+        int m_nContinuousTransferStep;
+        int m_nContinuousWorkingPort;
+        int m_nContinuousWorkingSlot;
+
+        // 宸茬粡寮�濮嬪鐞嗙殑 ProcessJob 鍒楄〃
+        std::vector<CProcessJob*> m_inProcesJobs;
+        std::vector<CProcessJob*> m_completeProcessJobs;
+        std::vector<CGlass*> m_queueGlasses;
+        std::vector<CGlass*> m_inProcesGlasses;
+        std::vector<CGlass*> m_completeGlasses;
+
+    private:
+        bool m_bEnableEventReport;
+        bool m_bEnableAlarmReport;
+        bool m_bPauseAlarmRaised;
+        SERVO::CControlJob* m_pControlJob;
+        std::vector<SERVO::CProcessJob*> m_processJobs;
+        std::string m_strStatePath;
+        CModel* m_pModelCtx;
+
+        int m_nTestFlag;
+        std::list<CGlass*> m_bufGlass;
+        std::unordered_set<uint32_t> m_allowedCeids;
+
+    private:
+        Collector* m_pCollector = nullptr;
+        void CreateDAQBridgeServer();
+        inline void notifyControlJobChanged() {
+            if (m_listener.onControlJobChanged) {
+                m_listener.onControlJobChanged(this);
+            }
+        }
     };
 }
-

--
Gitblit v1.9.3