From e8a27bb203fe2aff70390a5eca002d7438da9b0f Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期三, 22 十月 2025 14:24:34 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang

---
 SourceCode/Bond/Servo/ServoCommo.h |   56 +++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 55 insertions(+), 1 deletions(-)

diff --git a/SourceCode/Bond/Servo/ServoCommo.h b/SourceCode/Bond/Servo/ServoCommo.h
index 1e63c8e..8c4c7ea 100644
--- a/SourceCode/Bond/Servo/ServoCommo.h
+++ b/SourceCode/Bond/Servo/ServoCommo.h
@@ -2,6 +2,36 @@
 #include <string>
 #include <vector>
 
+
+#define CHECK_READ_STEP_SIGNAL(addr, data, size) {							\
+	BOOL bFlag = isBitOn(data, size, addr);									\
+	SERVO::CStep* pStep = getStep(addr);									\
+	if (pStep != nullptr) {													\
+		((CReadStep*)pStep)->onReadSignal(bFlag ? addr : 0);				\
+	}																		\
+}
+
+#define CHECK_WRITE_STEP_SIGNAL(addr, data, size) {							\
+	BOOL bFlag = isBitOn(data, size, addr);									\
+	SERVO::CStep* pStep = getStep(addr);									\
+	if (pStep != nullptr) {													\
+		((CWriteStep*)pStep)->onRecvSignal(bFlag ? addr : 0);				\
+	}																		\
+}
+
+#define CHECK_RUN_ACTIVE_ROBOT_TASK(art) {									\
+	if (art != nullptr) {													\
+		art->pick();														\
+		std::string strDescription = art->getDescription();					\
+		unlock();															\
+		if (m_listener.onRobotTaskEvent != nullptr) {						\
+			m_listener.onRobotTaskEvent(this, art, ROBOT_EVENT_CREATE);		\
+		}																	\
+		LOGI("创建新任务<%s>...", strDescription.c_str());					\
+		continue;															\
+	}																		\
+}
+
 namespace SERVO {
 #define BLOCK_BUFFER_MAX			1024
 #define ALIVE_TIMEOUT				15
@@ -14,7 +44,14 @@
 		OK = 1,
 		NG,
 	};
-	typedef RET JobDataRequestAck;
+	using JobDataRequestAck = RET;
+
+	enum class InspResult
+	{
+		NotInspected = 0,  // 初始化状态,尚未检测
+		Pass,              // 检测合格
+		Fail               // 检测不合格
+	};
 
 	enum class PortType {
 		Loading = 1,
@@ -36,6 +73,7 @@
 	};
 
 	enum class MaterialsType {
+		G0 = 0,
 		G1 = 1,
 		G2 = 2,
 		G1G2 = 3
@@ -185,5 +223,21 @@
 	/* EQ Data changed code */
 #define EDCC_FETCHOUT_JOB				1000	/* 取片 */
 #define EDCC_STORED_JOB					1001	/* 放片 */
+
+
+	/* Cassette Ctrl CMD */
+#define CCC_MAP_DOWNLOAD			1
+#define CCC_CLAMP					2
+#define CCC_UNCLAMP					3
+#define CCC_RECLAMP					4
+#define CCC_PROCESS_START			5
+#define CCC_PROCESS_START_BY_COUNT	6
+#define CCC_PROCESS_PAUSE			7
+#define CCC_PROCESS_RESUME			8
+#define CCC_PROCESS_ABORT			9
+#define CCC_PROCESS_CANCEL			10
+#define CCC_PROCESS_END				11
+#define CCC_ID_UPDATE				12
+#define CCC_MAP_UPDATE				13
 }
 

--
Gitblit v1.9.3