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/SGMeasurement/SGMeasurement.cpp |   86 ++++++++++++++++++++++++++++++++++++++----
 1 files changed, 77 insertions(+), 9 deletions(-)

diff --git a/SourceCode/Bond/SGMeasurement/SGMeasurement.cpp b/SourceCode/Bond/SGMeasurement/SGMeasurement.cpp
index 475924d..eeeead9 100644
--- a/SourceCode/Bond/SGMeasurement/SGMeasurement.cpp
+++ b/SourceCode/Bond/SGMeasurement/SGMeasurement.cpp
@@ -1,4 +1,4 @@
-
+锘�
 // SGMeasurement.cpp: 瀹氫箟搴旂敤绋嬪簭鐨勭被琛屼负銆�
 //
 
@@ -7,10 +7,61 @@
 #include "SGMeasurement.h"
 #include "SGMeasurementDlg.h"
 
+#include <DbgHelp.h>
+#pragma comment(lib, "DbgHelp.lib")
+
 #ifdef _DEBUG
 #define new DEBUG_NEW
 #endif
 
+LONG WINAPI MyUnhandledExceptionFilter(EXCEPTION_POINTERS* pExceptionInfo)
+{
+	// 鑾峰彇褰撳墠绋嬪簭鐩綍
+	TCHAR szAppPath[MAX_PATH] = { 0 };
+	::GetModuleFileName(NULL, szAppPath, MAX_PATH);
+	PathRemoveFileSpec(szAppPath);
+
+	// 鏋勯�� Temp 鏂囦欢澶硅矾寰�
+	CString strTempPath;
+	strTempPath.Format(_T("%s\\Temp"), szAppPath);
+	CreateDirectory(strTempPath, NULL);
+
+	// 鐢熸垚甯︽椂闂存埑鐨� Dump 鏂囦欢鍚�
+	SYSTEMTIME st;
+	GetLocalTime(&st);
+
+	CString strDumpFile;
+	strDumpFile.Format(
+		_T("%s\\SG_%04d%02d%02d_%02d%02d%02d.dmp"),
+		strTempPath,
+		st.wYear, st.wMonth, st.wDay,
+		st.wHour, st.wMinute, st.wSecond
+	);
+
+	// 鎵撳紑 dump 鏂囦欢
+	HANDLE hFile = CreateFile(strDumpFile, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
+	if (hFile != INVALID_HANDLE_VALUE) {
+		MINIDUMP_EXCEPTION_INFORMATION dumpInfo;
+		dumpInfo.ExceptionPointers = pExceptionInfo;
+		dumpInfo.ThreadId = GetCurrentThreadId();
+		dumpInfo.ClientPointers = TRUE;
+
+		// 鍐欏畬鏁村唴瀛� dump
+		BOOL success = MiniDumpWriteDump(
+			GetCurrentProcess(),
+			GetCurrentProcessId(),
+			hFile,
+			MiniDumpWithFullMemory,
+			&dumpInfo,
+			NULL,
+			NULL
+		);
+
+		CloseHandle(hFile);
+	}
+
+	return EXCEPTION_EXECUTE_HANDLER;
+}
 
 // CSGMeasurementApp
 
@@ -51,6 +102,18 @@
 
 	CWinApp::InitInstance();
 
+	// 鍞竴瀹炰緥杩愯妫�娴�
+	m_hMutex = ::CreateMutex(NULL, FALSE, _T("MutexEdgeInspector_App"));
+	if (m_hMutex != NULL) {
+		if (::GetLastError() == ERROR_ALREADY_EXISTS) {
+			AfxMessageBox(_T("The Program is already running. Exit this Program."), MB_OK | MB_ICONERROR);
+			return FALSE;
+		}
+	}
+
+	// 璁剧疆鏈鐞嗗紓甯歌繃婊ゅ櫒锛屾崟鑾峰穿婧冨苟鐢熸垚 Dump 鏂囦欢
+	SetUnhandledExceptionFilter(MyUnhandledExceptionFilter);
+
 	// 鍒濆鍖� MFC RichEdit 鎺т欢
 	AfxInitRichEdit2();
 
@@ -75,23 +138,19 @@
 	CSGMeasurementDlg dlg;
 	m_pMainWnd = &dlg;
 	INT_PTR nResponse = dlg.DoModal();
-	if (nResponse == IDOK)
-	{
+	if (nResponse == IDOK) {
 		// TODO:鈥滅‘瀹氣�濇潵鍏抽棴瀵硅瘽妗嗙殑浠g爜
 	}
-	else if (nResponse == IDCANCEL)
-	{
+	else if (nResponse == IDCANCEL) {
 		// TODO:鈥滃彇娑堚�濇潵鍏抽棴瀵硅瘽妗嗙殑浠g爜 
 	}
-	else if (nResponse == -1)
-	{
+	else if (nResponse == -1) {
 		TRACE(traceAppMsg, 0, "璀﹀憡: 瀵硅瘽妗嗗垱寤哄け璐ワ紝搴旂敤绋嬪簭灏嗘剰澶栫粓姝€�俓n");
 		TRACE(traceAppMsg, 0, "璀﹀憡: 濡傛灉鎮ㄥ湪瀵硅瘽妗嗕笂浣跨敤 MFC 鎺т欢锛屽垯鏃犳硶 #define _AFX_NO_MFC_CONTROLS_IN_DIALOGS銆俓n");
 	}
 
 	// 鍒犻櫎涓婇潰鍒涘缓鐨� shell 绠$悊鍣ㄣ��
-	if (pShellManager != nullptr)
-	{
+	if (pShellManager != nullptr) {
 		delete pShellManager;
 	}
 
@@ -101,4 +160,13 @@
 
 	// 鐢变簬瀵硅瘽妗嗗凡鍏抽棴锛屾墍浠ュ皢杩斿洖 FALSE 浠ヤ究閫�鍑哄簲鐢ㄧ▼搴忥紝鑰屼笉鏄惎鍔ㄥ簲鐢ㄧ▼搴忕殑娑堟伅娉点��
 	return FALSE;
+}
+
+int CSGMeasurementApp::ExitInstance()
+{
+	if (m_hMutex) {
+		CloseHandle(m_hMutex);
+		m_hMutex = nullptr;
+	}
+	return CWinApp::ExitInstance();
 }
\ No newline at end of file

--
Gitblit v1.9.3