From bea6407b376a4e426f0b120bae569fba6ab867db Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期六, 08 十一月 2025 17:55:47 +0800
Subject: [PATCH] 1.CMaster.cpp 第 1644/1667/1691 行在记录 SV 曲线时通过 getGlassFromSlot(0) 取玻璃,而各设备的 initSlots() 都是从 1 开始编号(例如 CBonder.cpp (line 408)、CVacuumBake.cpp (line 415) 等)。槽位 0 永远不存在,所以 pGlass 始终是 nullptr,pGlass->addSVData(...) 的分支从未执行。结果 SERVO::CGlass::m_svDatas 里没有任何曲线数据,GlassJson::ToPrettyString 生成的 pretty 字符串也就没有 sv_datas,导出 CSV 时自然读不到曲线。 同一段代码还有一个潜在 Bug:虽然判断了 channel - 1 < bonderTypes.size(),但真正索引却用的是 bonderTypes[channel]。索引偏移会导致数据类型错位,最后一个通道甚至可能越界。即使修正了槽位,这里也需要同步改成 bonderTypes[channel - 1](另外两处 vacuumbakeTypes、coolingTypes 也一样)。
---
SourceCode/Bond/BondEq/DBManager/SystemLogManager.h | 62 +++++++++++++++++++++----------
1 files changed, 42 insertions(+), 20 deletions(-)
diff --git a/SourceCode/Bond/BondEq/DBManager/SystemLogManager.h b/SourceCode/Bond/BondEq/DBManager/SystemLogManager.h
index 290e046..764450c 100644
--- a/SourceCode/Bond/BondEq/DBManager/SystemLogManager.h
+++ b/SourceCode/Bond/BondEq/DBManager/SystemLogManager.h
@@ -2,50 +2,72 @@
#define SYSTEM_LOG_MANAGER_H
#include <string>
-#include <memory>
+#include <vector>
#include <mutex>
-#include <chrono>
#include "Database.h"
+// 系统日志管理类
class SystemLogManager {
public:
+ // 日志类型定义
enum class LogType {
- Info, // 信息日志
- Error, // 错误日志
- Operation // 操作日志
+ Info,
+ Error,
+ Operation,
+ Unknown
};
// 获取单例实例
static SystemLogManager& getInstance();
// 设置数据库连接
- void setDatabase(std::unique_ptr<BL::Database>& db);
-
- // 添加日志
- bool log(LogType logType, const std::string& event, const std::string& username = "SYSTEM");
-
- // 获取日志
- std::vector<std::vector<std::string>> SystemLogManager::getLogs(int startPosition = -1, int count = -1);
+ void setDatabase(BL::Database* db);
// 初始化日志表
bool initializeLogTable();
+ // 添加日志
+ bool log(LogType logType, const std::string& event);
+ bool log(LogType logType, const std::string& event, const std::string& username);
+
+ // 获取日志内容
+ std::vector<std::vector<std::string>> getLogs(int startPosition = -1, int count = -1);
+
+ // 获取筛选后的日志数据
+ std::vector<std::vector<std::string>> getFilteredLogs(
+ const std::string& logType,
+ const std::string& username,
+ const std::string& description,
+ const std::string& startTime,
+ const std::string& endTime,
+ int pageNumber,
+ int pageSize);
+
+ // 获取符合条件的日志总数
+ int getTotalLogCount(
+ const std::string& logType,
+ const std::string& username,
+ const std::string& description,
+ const std::string& startTime,
+ const std::string& endTime);
+
+ // 清理超过指定天数的旧日志
+ void cleanOldLogs(int daysToKeep = 30);
+
+ // 转换日志类型为字符串
+ static std::string logTypeToString(LogType logType);
+
private:
- // 构造函数(私有化)
+ // 构造函数和析构函数
SystemLogManager();
+ ~SystemLogManager();
// 禁止拷贝和赋值
SystemLogManager(const SystemLogManager&) = delete;
SystemLogManager& operator=(const SystemLogManager&) = delete;
- // 转换日志类型为字符串
- std::string logTypeToString(LogType logType) const;
-
// 数据库连接
- std::unique_ptr<BL::Database>* m_pDB;
-
- // 单例实例
- static std::unique_ptr<SystemLogManager> m_instance;
+ BL::Database* m_pDB = nullptr;
// 线程安全锁
static std::mutex m_mutex;
--
Gitblit v1.9.3