From 6b6297c6fc0aa5c059d35732c7ee22ebca93967f Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期三, 14 一月 2026 15:43:40 +0800
Subject: [PATCH] 1.修复以下问题: ProceedWithCarrier 直接发 CCC_PROCESS_START:CModel::onCarrierAction 在 CompareMapsBeforeProceeding 关闭时,收到 ProceedWithCarrier 就调用 master.proceedWithCarrier(仅发送 Cassette Process Start,不校验 PJ/CJ 是否存在、SlotMap 是否验通过)。若 Host 流程异常(未下 PJ/CJ)或本地尚未准备好,会把设备推进加工态但无作业可跑。

---
 SourceCode/Bond/Servo/CVariable.cpp |   25 +++++++++++++++++++++++++
 1 files changed, 25 insertions(+), 0 deletions(-)

diff --git a/SourceCode/Bond/Servo/CVariable.cpp b/SourceCode/Bond/Servo/CVariable.cpp
index e9c5d83..e7b916c 100644
--- a/SourceCode/Bond/Servo/CVariable.cpp
+++ b/SourceCode/Bond/Servo/CVariable.cpp
@@ -43,6 +43,9 @@
 		if (_strcmpi("A20", pszFormat) == 0) {
 			return SVFromat::A20;
 		}
+		if (_strcmpi("L", pszFormat) == 0) {
+			return SVFromat::L;
+		}
 
 		return SVFromat::U1;
 	}
@@ -64,6 +67,9 @@
 		}
 		if (SVFromat::A20 == format) {
 			return "A20";
+		}
+		if (SVFromat::L == format) {
+			return "L";
 		}
 
 		return "U1";
@@ -113,6 +119,11 @@
 		m_strValue = strTemp;
 	}
 
+	void CVariable::setValue(std::vector<CVariable>& vars)
+	{
+		m_varsValue = vars;
+	}
+
 	std::string CVariable::getValue()
 	{
 		std::string strRet;
@@ -125,4 +136,18 @@
 
 		return strRet;
 	}
+
+	__int64 CVariable::getIntValue()
+	{
+		if (m_format == SVFromat::U1 || m_format == SVFromat::U2 || m_format == SVFromat::I2) {
+			return m_nValue;
+		}
+
+		return 0;
+	}
+
+	std::vector<CVariable>& CVariable::getVarsValue()
+	{
+		return m_varsValue;
+	}
 }
\ No newline at end of file

--
Gitblit v1.9.3