From da9df9d46ed3fc50e0c03497bd9f76b8aa1a4595 Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期三, 14 一月 2026 15:37:48 +0800
Subject: [PATCH] 1.修复以下问题: 作业前置条件不足导致 PJ 验证失败:onPRJobMultiCreate 调 CMaster::setProcessJobs,CProcessJob::validate 要求“当前没有其它 PJ”(issue 1000),且 carrierPresent/slotUsable 必须为真。只要本地还有未结批的 PJ/CJ 或载具/槽位状态未就绪(ID 未绑、Slot 未使能),Host 发送的 CreateMultiPJ 会直接被丢弃(返回 size=0),但当前代码没有向 Host 回 ACK/NAK,Host 会误以为创建成功。

---
 SourceCode/Bond/Servo/CAttributeVector.cpp |   19 +++++++++++++++++--
 1 files changed, 17 insertions(+), 2 deletions(-)

diff --git a/SourceCode/Bond/Servo/CAttributeVector.cpp b/SourceCode/Bond/Servo/CAttributeVector.cpp
index 733c629..d7c52b7 100644
--- a/SourceCode/Bond/Servo/CAttributeVector.cpp
+++ b/SourceCode/Bond/Servo/CAttributeVector.cpp
@@ -17,11 +17,20 @@
 		m_attributes.clear();
 	}
 
-	void CAttributeVector::addAttribute(CAttribute* pAttribute, BOOL bReplace/* = FALSE*/)
+	BOOL CAttributeVector::addAttribute(CAttribute* pAttribute, BOOL bReplace/* = FALSE*/)
 	{
+		if (!pAttribute) { 
+			return FALSE;
+		}
+
+		const std::string& name = pAttribute->getName();
+		if (name.empty()) { 
+			return FALSE;
+		}
+
 		if (bReplace) {
 			for (auto it = m_attributes.begin(); it != m_attributes.end(); ) {
-				if ((*it)->getName().compare(pAttribute->getName()) == 0) {
+				if (name.compare((*it)->getName()) == 0) {
 					delete (*it);
 					it = m_attributes.erase(it);
 				}
@@ -32,6 +41,7 @@
 		}
 
 		m_attributes.push_back(pAttribute);
+		return TRUE;
 	}
 
 	void CAttributeVector::addAttributeVector(CAttributeVector& av)
@@ -71,4 +81,9 @@
 		ASSERT(index < m_attributes.size());
 		return m_attributes[index];
 	}
+
+	std::vector<CAttribute*>& CAttributeVector::getAttributes()
+	{
+		return m_attributes;
+	}
 }

--
Gitblit v1.9.3