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/CPath.cpp |   16 +++++++++++++++-
 1 files changed, 15 insertions(+), 1 deletions(-)

diff --git a/SourceCode/Bond/Servo/CPath.cpp b/SourceCode/Bond/Servo/CPath.cpp
index ae140c6..5898b5b 100644
--- a/SourceCode/Bond/Servo/CPath.cpp
+++ b/SourceCode/Bond/Servo/CPath.cpp
@@ -1,6 +1,7 @@
 #include "stdafx.h"
 #include "CPath.h"
 #include "ToolUnits.h"
+#include "CServoUtilsTool.h"
 
 
 namespace SERVO {
@@ -15,10 +16,11 @@
 		m_pNext = nullptr;
 	}
 
-	CPath::CPath(unsigned int nEqId, unsigned int nUnit)
+	CPath::CPath(unsigned int nEqId, unsigned int nUnit, unsigned int nSlot)
 	{
 		m_nEqID = nEqId;
 		m_nUnit = nUnit;
+		m_nSlot = nSlot;
 		m_timeOut = 0;
 		m_timeIn = CToolUnits::getTimestamp();
 		m_bProcessed = FALSE;
@@ -46,11 +48,17 @@
 		strOut = strOut + ">";
 	}
 
+	void CPath::getSimpleDescription(std::string& strOut)
+	{
+		strOut = CServoUtilsTool::getEqUnitName(m_nEqID, m_nUnit, m_nSlot);
+	}
+
 	void CPath::serialize(CArchive& ar)
 	{
 		if (ar.IsStoring()) {
 			ar << m_nEqID;
 			ar << m_nUnit;
+			ar << m_nSlot;
 			ar << m_timeIn;
 			ar << m_timeOut;
 			ar << m_bProcessed;
@@ -65,6 +73,7 @@
 
 			ar >> m_nEqID;
 			ar >> m_nUnit;
+			ar >> m_nSlot;
 			ar >> m_timeIn;
 			ar >> m_timeOut;
 			ar >> m_bProcessed;
@@ -90,6 +99,11 @@
 		return m_nUnit;
 	}
 
+	unsigned int CPath::getSlot()
+	{
+		return m_nSlot;
+	}
+
 	void CPath::setInTime(ULONGLONG time)
 	{
 		m_timeIn = time;

--
Gitblit v1.9.3