From cacea2da59a3acd73f3161d819a10e0060762616 Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期二, 06 五月 2025 14:54:13 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang

---
 SourceCode/Bond/Servo/CRecipesManager.h |   42 ++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 42 insertions(+), 0 deletions(-)

diff --git a/SourceCode/Bond/Servo/CRecipesManager.h b/SourceCode/Bond/Servo/CRecipesManager.h
new file mode 100644
index 0000000..d8e01dc
--- /dev/null
+++ b/SourceCode/Bond/Servo/CRecipesManager.h
@@ -0,0 +1,42 @@
+#pragma once
+#include <map>
+#include "CRecipeList.h"
+
+
+#define SS_NONE					0
+#define SS_SYNCING				1
+#define SS_COMPLETE				2
+#define SS_TIMEOUT				3
+#define SS_FAILED				4
+
+namespace SERVO {
+	class CRecipesManager
+	{
+	public:
+		CRecipesManager();
+		virtual ~CRecipesManager();
+
+	public:
+		unsigned TimeoutCheckWorkingProc();
+		int syncing();
+		void syncFailed();
+		short decodeRecipeListReport(const char* pszData, size_t size);
+		CRecipeList* getRecipeListFromTemp(int unitNo);
+
+	public:
+		inline void lock() { ::EnterCriticalSection(&m_cs); };
+		inline void unlock() { ::LeaveCriticalSection(&m_cs); };
+
+	private:
+		HANDLE m_hWorkThreadHandle;
+		unsigned m_nWordThreadAddr;
+		HANDLE m_hWorkStop;
+		int m_nTimeoutCount;
+		CRITICAL_SECTION m_cs;		// 同步锁
+		int m_nSyncStatus;
+		int m_nTotalMasterRecipeCount;
+		std::map<int, CRecipeList*> m_mapRecipes;
+		std::map<int, CRecipeList*> m_mapRecipesTemp;
+	};
+}
+

--
Gitblit v1.9.3