From 2ece96546ec80bf26013d005967cbfdc06156ee7 Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期二, 17 六月 2025 16:32:41 +0800
Subject: [PATCH] 1. 添加配方管理类(数据库) 2. 修改用户管理和系统日志管理类的路径和名称 3. 修复合并代码导致系统日志管理窗口的资源异常的问题

---
 SourceCode/Bond/Servo/Servo.cpp |   88 +++++++++++++++++++++++++++++++++----------
 1 files changed, 67 insertions(+), 21 deletions(-)

diff --git a/SourceCode/Bond/Servo/Servo.cpp b/SourceCode/Bond/Servo/Servo.cpp
index 3b5e1c5..71f2ed2 100644
--- a/SourceCode/Bond/Servo/Servo.cpp
+++ b/SourceCode/Bond/Servo/Servo.cpp
@@ -8,8 +8,12 @@
 #include "ServoGraph.h"
 #include "AlarmManager.h"
 #include "SECSRuntimeManager.h"
-#include "ProductionLogManager.h"
+#include "TransferManager.h"
+#include "SystemLogManager.h"
+#include "UserManager.h"
+#include "RecipeManager.h"
 #include "VerticalLine.h"
+#include "HorizontalLine.h"
 #include "EqsGraphWnd.h"
 #include "MapPosWnd.h"
 #include "HmTab.h"
@@ -99,6 +103,7 @@
 	// 注册控件
 	CServoGraph::RegisterWndClass();
 	CVerticalLine::RegisterWndClass();
+	CHorizontalLine::RegisterWndClass();
 	CEqsGraphWnd::RegisterWndClass();
 	CMapPosWnd::RegisterWndClass();
 	CHmTab::RegisterWndClass();
@@ -130,23 +135,6 @@
 		AfxMessageBox(errorMsg, MB_ICONERROR);
 		return FALSE;
 	}
-	AlarmManager::getInstance().insertMockData();
-
-
-	// 初始化生产履历管理器
-	//try {
-	//	if (!ProductionLogManager::getInstance().initProductionTable()) {
-	//		AfxMessageBox("初始化生产履历管理器失败!");
-	//		return FALSE;
-	//	}
-	//}
-	//catch (const std::exception& ex) {
-	//	CString errorMsg;
-	//	errorMsg.Format(_T("初始化生产履历管理器失败:%s"), CString(ex.what()));
-	//	AfxMessageBox(errorMsg, MB_ICONERROR);
-	//	return FALSE;
-	//}
-
 
 	// 初始化SECS运行设置管理库
 	try {
@@ -158,6 +146,64 @@
 	catch (const std::exception& ex) {
 		CString errorMsg;
 		errorMsg.Format(_T("初始化SECS运行设置失败:%s"), CString(ex.what()));
+		AfxMessageBox(errorMsg, MB_ICONERROR);
+		return FALSE;
+	}
+
+	// 初始化搬运记录管理库
+	try {
+		if (!TransferManager::getInstance().initTransferTable()) {
+			AfxMessageBox("初始化搬运记录管理库设置失败!");
+			return FALSE;
+		}
+	}
+	catch (const std::exception& ex) {
+		CString errorMsg;
+		errorMsg.Format(_T("初始化搬运记录管理库设置失败:%s"), CString(ex.what()));
+		AfxMessageBox(errorMsg, MB_ICONERROR);
+		return FALSE;
+	}
+
+	// 初始化运行日志管理库
+	try {
+		if (!SystemLogManager::getInstance().initializeLogTable()) {
+			AfxMessageBox("初始化运行日志管理库失败!");
+			return FALSE;
+		}
+	}
+	catch (const std::exception& ex) {
+		CString errorMsg;
+		errorMsg.Format(_T("初始化运行日志管理库失败:%s"), CString(ex.what()));
+		AfxMessageBox(errorMsg, MB_ICONERROR);
+		return FALSE;
+	}
+
+	// 初始化用户管理库
+	try {
+		UserManager& userManager = UserManager::getInstance();
+#if !defined(_DEBUG)
+		userManager.initializeIdleDetection(AfxGetMainWnd()->m_hWnd);
+		SetTimer(1, 60000, nullptr);
+#endif
+		userManager.loadSession();
+	}
+	catch (const std::exception& ex) {
+		CString errorMsg;
+		errorMsg.Format(_T("初始化用户管理库失败:%s"), CString(ex.what()));
+		AfxMessageBox(errorMsg, MB_ICONERROR);
+		return FALSE;
+	}
+
+	// 初始化配方管理库
+	try {
+		if (!RecipeManager::getInstance().initRecipeTable()) {
+			AfxMessageBox("初始化配方管理库失败!");
+			return FALSE;
+		}
+	}
+	catch (const std::exception& ex) {
+		CString errorMsg;
+		errorMsg.Format(_T("初始化配方管理库失败:%s"), CString(ex.what()));
 		AfxMessageBox(errorMsg, MB_ICONERROR);
 		return FALSE;
 	}
@@ -205,12 +251,12 @@
 	// 销毁报警表
 	AlarmManager::getInstance().termAlarmTable();
 
-	// 销毁生产表
-	ProductionLogManager::getInstance().termProductionTable();
-
 	// 销毁SECS运行设置管理库
 	SECSRuntimeManager::getInstance().termRuntimeSetting();
 
+	// 销毁搬运记录管理库
+	TransferManager::getInstance().termTransferTable();
+
 	return CWinApp::ExitInstance();
 }
 

--
Gitblit v1.9.3