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/BEQLibrary/Unit.cpp |   17 +++++++++++++++++
 1 files changed, 17 insertions(+), 0 deletions(-)

diff --git a/SourceCode/Bond/BEQLibrary/Unit.cpp b/SourceCode/Bond/BEQLibrary/Unit.cpp
index df10698..a5e49e2 100644
--- a/SourceCode/Bond/BEQLibrary/Unit.cpp
+++ b/SourceCode/Bond/BEQLibrary/Unit.cpp
@@ -62,6 +62,7 @@
 		m_listener.onRemoveAlarm = listener.onRemoveAlarm;
 		m_listener.onStepChanged = listener.onStepChanged;
 		m_listener.onDataChanged = listener.onDataChanged;
+		m_listener.onReqNotReady = listener.onReqNotReady;
 		m_listener.onReqLoad = listener.onReqLoad;
 		m_listener.onReqUnload = listener.onReqUnload;
 	}
@@ -212,6 +213,22 @@
 		return m_strAlarmText;
 	}
 
+	int CUnit::reqNotReady(int layer)
+	{
+		ASSERT(m_listener.onReqNotReady);
+		if (layer <= 0) return -1;
+		if (layer > m_nLayerCount) return -2;
+
+		// 状态改变才回调到上层
+		if (m_nLayerLoadState[layer - 1] != LAYER_NOT_READY) {
+			m_nLayerLoadState[layer - 1] = LAYER_NOT_READY;
+			m_listener.onReqNotReady(this, layer);
+			return 0;
+		}
+
+		return -3;
+	}
+
 	int CUnit::reqLoad(int layer)
 	{
 		ASSERT(m_listener.onReqLoad);

--
Gitblit v1.9.3