From e8a27bb203fe2aff70390a5eca002d7438da9b0f Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期三, 22 十月 2025 14:24:34 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang
---
SourceCode/Bond/Servo/CGlass.h | 144 ++++++++++++++++++++++++++++++++++++++++++++++--
1 files changed, 138 insertions(+), 6 deletions(-)
diff --git a/SourceCode/Bond/Servo/CGlass.h b/SourceCode/Bond/Servo/CGlass.h
index 86115ef..79fe83f 100644
--- a/SourceCode/Bond/Servo/CGlass.h
+++ b/SourceCode/Bond/Servo/CGlass.h
@@ -7,9 +7,31 @@
#include "CJobDataC.h"
#include "CJobDataS.h"
#include "ServoCommo.h"
+#include "ProcessJob.h"
+#include "CParam.h"
namespace SERVO {
+ /// 数据项:时间戳 + 数值
+ struct SVDataItem {
+ std::chrono::system_clock::time_point timestamp;
+ double value; // 或者根据实际情况使用其他类型
+
+ SVDataItem(std::chrono::system_clock::time_point ts, double val)
+ : timestamp(ts), value(val) {}
+ };
+
+ /// PJ 生命周期(贴近 E40 常见状态)
+ enum class GlsState : uint8_t {
+ NoState = 0,
+ Queued,
+ InProcess,
+ Paused,
+ Completed,
+ Aborted,
+ Failed
+ };
+
class CGlass : public CContext
{
public:
@@ -20,22 +42,124 @@
public:
virtual std::string& getClassName();
virtual std::string toString();
- MaterialsType getType();
+ short getCassetteSequenceNo() const { return m_jobDataS.getCassetteSequenceNo(); }
+ short getJobSequenceNo() const { return m_jobDataS.getJobSequenceNo(); }
+ MaterialsType getType() const;
void setType(MaterialsType type);
void setID(const char* pszID);
- std::string& getID();
- CPath* getPathWithEq(unsigned int nEqId, unsigned int nUnit);
+ const std::string& getID() const;
+ void setOriginPort(int port, int slot);
+ void getOrginPort(int& port, int& slot);
+ BOOL isScheduledForProcessing();
+ void setScheduledForProcessing(BOOL bProcessing);
+ CProcessJob* getProcessJob();
+ void setProcessJob(CProcessJob* pProcessJob);
+ CPath* getPathWithEq(unsigned int nEqId, unsigned int nUnit) const;
CPath* getPath();
- void addPath(unsigned int nEqId, unsigned int nUnit);
+ void addPath(unsigned int nEqId, unsigned int nUnit, unsigned int slot);
+ std::string getPathDescription() const;
+ std::string getParamsDescription() const;
void serialize(CArchive& ar);
void setJobDataS(CJobDataS* pJobDataS);
+ void updateJobDataS(CJobDataS* pJobDataS);
CJobDataS* getJobDataS();
BOOL setBuddy(CGlass* pGlass);
BOOL forceSetBuddy(CGlass* pGlass);
CGlass* getBuddy();
- std::string& getBuddyId();
- void processEnd(unsigned int nEqId, unsigned int nUnit);
+ const std::string& getBuddyId() const;
+ void setBuddyId(std::string& strId);
+ int processEnd(unsigned int nEqId, unsigned int nUnit);
BOOL isProcessed(unsigned int nEqId, unsigned int nUnit);
+ int setInspResult(unsigned int nEqId, unsigned int nUnit, InspResult result);
+ InspResult getInspResult(unsigned int nEqId, unsigned int nUnit) const;
+ InspResult getAOIInspResult() const;
+
+ public:
+ // 新增状态
+ GlsState state() const noexcept { return m_state; }
+ std::string getStateText();
+ GlsState m_state{ GlsState::NoState };
+ static void clampString(std::string& s, size_t maxLen);
+ static std::string trimCopy(std::string s);
+ std::string m_failReason;
+
+ // —— 状态机(带守卫)——
+ bool queue(); // NoState -> Queued
+ bool start(); // Queued -> InProcess
+ bool pause(); // InProcess -> Paused
+ bool resume(); // Paused -> InProcess
+ bool complete(); // InProcess -> Completed
+ bool abort(); // Any (未终态) -> Aborted
+ bool fail(std::string reason); // 任意态 -> Failed(记录失败原因)
+
+ // 时间戳
+ std::optional<std::chrono::system_clock::time_point> m_tQueued;
+ std::optional<std::chrono::system_clock::time_point> m_tStart;
+ std::optional<std::chrono::system_clock::time_point> m_tEnd;
+
+ // 时间戳(可用于报表/追溯)
+ std::optional<std::chrono::system_clock::time_point> tQueued() const { return m_tQueued; }
+ std::optional<std::chrono::system_clock::time_point> tStart() const { return m_tStart; }
+ std::optional<std::chrono::system_clock::time_point> tEnd() const { return m_tEnd; }
+ void markQueued();
+ void markStart();
+ void markEnd();
+
+ // 工艺参数
+ void addParams(std::vector<CParam>& params);
+ std::vector<CParam>& getParams();
+
+ // ========== SV数据管理接口(新设计)==========
+
+ // 添加数据到指定机器的指定数据类型
+ void addSVData(int machineId, const std::string& dataType, const SVDataItem& dataItem);
+ void addSVData(int machineId, const std::string& dataType, double value); // 自动使用当前时间
+ void addSVData(int machineId, const std::string& dataType, int64_t timestamp, double value);
+
+ // 批量添加数据到指定机器的指定数据类型
+ void addSVData(int machineId, const std::string& dataType, const std::vector<SVDataItem>& dataItems);
+
+ // 获取指定机器的指定数据类型的所有数据
+ std::vector<SVDataItem> getSVData(int machineId, const std::string& dataType) const;
+
+ // 获取指定机器的所有数据类型
+ std::vector<std::string> getSVDataTypes(int machineId) const;
+
+ // 获取指定机器的所有数据(按数据类型组织)
+ std::unordered_map<std::string, std::vector<SVDataItem>> getMachineSVData(int machineId) const;
+
+ // 获取所有机器的数据
+ const std::unordered_map<int, std::unordered_map<std::string, std::vector<SVDataItem>>>& getAllSVData() const;
+
+ // 检查指定机器是否有指定类型的数据
+ bool hasSVData(int machineId, const std::string& dataType) const;
+
+ // 检查指定机器是否有任何数据
+ bool hasMachineSVData(int machineId) const;
+
+ // 获取所有有SV数据的机器ID
+ std::vector<int> getMachineIdsWithSVData() const;
+
+ // 清空指定机器的指定数据类型的数据
+ void clearSVData(int machineId, const std::string& dataType);
+
+ // 清空指定机器的所有数据
+ void clearMachineSVData(int machineId);
+
+ // 清空所有机器的所有数据
+ void clearAllSVData();
+
+ // 获取指定机器的指定数据类型的数据数量
+ size_t getSVDataCount(int machineId, const std::string& dataType) const;
+
+ // 获取指定机器的总数据数量
+ size_t getMachineSVDataCount(int machineId) const;
+
+ // 获取所有机器的总数据数量
+ size_t getTotalSVDataCount() const;
+
+ // 获取指定数据类型在所有机器中的数据
+ std::vector<std::pair<int, SVDataItem>> findSVDataByType(const std::string& dataType) const;
private:
MaterialsType m_type;
@@ -44,6 +168,14 @@
CJobDataS m_jobDataS;
CGlass* m_pBuddy;
std::string m_strBuddyId;
+ int m_nOriginPort;
+ int m_nOriginSlot;
+ BOOL m_bScheduledForProcessing; /* 是否将加工处理 */
+ CProcessJob* m_pProcessJob;
+ std::vector<CParam> m_params; // 工艺参数
+
+ // 新的三层数据结构:机器ID -> 数据类型 -> 数据列表
+ std::unordered_map<int, std::unordered_map<std::string, std::vector<SVDataItem>>> m_svDatas;
};
}
--
Gitblit v1.9.3