From bdf0dc4cb183d3fec40e1d51b3bb94b7e53d0a55 Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期日, 04 一月 2026 10:45:07 +0800
Subject: [PATCH] 1.修复报文字段差异风险: S1F3:项目用 getSubItemU4(0) 取 SVID;日志里有 U2 的情况,可能导致解析失败后回退成 SV=0。 S6F11:项目发送 DATAID(U4) + CEID(U4);日志样例里第一个字段是 U2,可能存在类型/字段定义不一致。

---
 SourceCode/Bond/Servo/CPath.cpp |   12 ++++++++++--
 1 files changed, 10 insertions(+), 2 deletions(-)

diff --git a/SourceCode/Bond/Servo/CPath.cpp b/SourceCode/Bond/Servo/CPath.cpp
index 1731ee9..5898b5b 100644
--- a/SourceCode/Bond/Servo/CPath.cpp
+++ b/SourceCode/Bond/Servo/CPath.cpp
@@ -16,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;
@@ -49,7 +50,7 @@
 
 	void CPath::getSimpleDescription(std::string& strOut)
 	{
-		strOut = CServoUtilsTool::getEqUnitName(m_nEqID, m_nUnit);
+		strOut = CServoUtilsTool::getEqUnitName(m_nEqID, m_nUnit, m_nSlot);
 	}
 
 	void CPath::serialize(CArchive& ar)
@@ -57,6 +58,7 @@
 		if (ar.IsStoring()) {
 			ar << m_nEqID;
 			ar << m_nUnit;
+			ar << m_nSlot;
 			ar << m_timeIn;
 			ar << m_timeOut;
 			ar << m_bProcessed;
@@ -71,6 +73,7 @@
 
 			ar >> m_nEqID;
 			ar >> m_nUnit;
+			ar >> m_nSlot;
 			ar >> m_timeIn;
 			ar >> m_timeOut;
 			ar >> m_bProcessed;
@@ -96,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