2020-09-30 16:53:55 +02:00

372 lines
10 KiB
C++

//+---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation 1996-2001.
//
// File: perfanal.cpp
//
// Contents: implementation of CPerformAnalysis
//
//----------------------------------------------------------------------------
#include "stdafx.h"
#include "wsecmgr.h"
#include "snapmgr.h"
#include "PerfAnal.h"
#include "wrapper.h"
#include "util.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CPerformAnalysis dialog
CPerformAnalysis::CPerformAnalysis(CWnd * pParent, UINT nTemplateID)
: CHelpDialog(a215HelpIDs, nTemplateID ? nTemplateID : IDD, pParent)
{
//{{AFX_DATA_INIT(CPerformAnalysis)
m_strLogFile = _T("");
//}}AFX_DATA_INIT
}
void CPerformAnalysis::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CPerformAnalysis)
DDX_Control(pDX, IDOK, m_ctlOK);
DDX_Text(pDX, IDC_ERROR, m_strError);
DDX_Text(pDX, IDC_LOG_FILE, m_strLogFile);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CPerformAnalysis, CHelpDialog)
//{{AFX_MSG_MAP(CPerformAnalysis)
ON_BN_CLICKED(IDOK, OnOK)
ON_BN_CLICKED(IDC_BROWSE, OnBrowse)
ON_EN_CHANGE(IDC_LOG_FILE, OnChangeLogFile)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CPerformAnalysis message handlers
void CPerformAnalysis::OnBrowse()
{
CString strLogFileExt;
CString strLogFileFilter;
CString strTitle;
OPENFILENAME ofn;
::ZeroMemory (&ofn, sizeof (OPENFILENAME));
ofn.lStructSize = sizeof(OPENFILENAME);
UpdateData(TRUE);
m_strLogFile.Remove(L'<'); //Raid #463367, '<' is a invalid filename char.
strLogFileExt.LoadString(IDS_LOGFILE_DEF_EXT);
strLogFileFilter.LoadString(IDS_LOGFILE_FILTER);
strTitle.LoadString(IDS_LOGFILE_PICKER_TITLE);
// Translate filter into commdlg format (lots of \0)
LPTSTR szFilter = strLogFileFilter.GetBuffer(0); // modify the buffer in place
// MFC delimits with '|' not '\0'
LPTSTR pch = szFilter;
while ((pch = _tcschr(pch, '|')) != NULL)
*pch++ = '\0';
// do not call ReleaseBuffer() since the string contains '\0' characters
ofn.lpstrFilter = szFilter;
ofn.lpstrFile = m_strLogFile.GetBuffer(MAX_PATH),
ofn.nMaxFile = MAX_PATH;
ofn.lpstrDefExt = strLogFileExt,
ofn.hwndOwner = m_hWnd;
ofn.Flags = OFN_HIDEREADONLY |
OFN_EXPLORER |
OFN_DONTADDTORECENT|
OFN_NOREADONLYRETURN,
ofn.lpstrTitle = strTitle;
//
// Default to the currently picked log file
//
if (GetOpenFileName(&ofn)) {
m_strLogFile.ReleaseBuffer();
UpdateData(FALSE);
if (m_strLogFile.IsEmpty()) //Raid #669231, yanggao, 8/9/2002
m_ctlOK.EnableWindow(FALSE);
else
m_ctlOK.EnableWindow(TRUE);
} else {
m_strLogFile.ReleaseBuffer();
}
}
//+--------------------------------------------------------------------------
//
// Method: DoIt
//
// Synopsis: Actually Analyzes the system (separated from OnOK so it can
// be overridden to Configure the system, etc. while still using
// the same OnOK shell code
//
//---------------------------------------------------------------------------
DWORD CPerformAnalysis::DoIt() {
//
// Store the log file we're using for next time
//
LPTSTR szLogFile = m_strLogFile.GetBuffer(0);
m_pComponentData->GetWorkingDir(GWD_ANALYSIS_LOG,&szLogFile,TRUE,TRUE);
m_strLogFile.ReleaseBuffer();
//
// InspectSystem will handle multi-threading and progress UI so
// SCE doesn't get wierd on the user
//
return InspectSystem(
NULL, // Always use the configuration assigned to the DB
m_strDataBase.IsEmpty() ? NULL: (LPCTSTR)m_strDataBase,
(LPCTSTR)m_strLogFile,
AREA_ALL
);
}
//+--------------------------------------------------------------------------
//
// Method: OnOK
//
// Synopsis: Analyzes the system
//
//---------------------------------------------------------------------------
afx_msg void CPerformAnalysis::OnOK()
{
CWnd *cwnd;
HANDLE hLogFile;
UpdateData(TRUE);
//
// We require a log file that we can write to
//
CString strLogFileExt;
strLogFileExt.LoadString(IDS_LOGFILE_DEF_EXT); //Raid #553110, yanggao
strLogFileExt = TEXT(".") + strLogFileExt;
if (m_strLogFile.IsEmpty()) {
return;
}
else {
m_strLogFile = ExpandEnvironmentStringWrapper(m_strLogFile);
if( !IsValidFileName(m_strLogFile) || IsNameReserved(m_strLogFile, strLogFileExt)) //Raid #463367, Yang Gao, 9/5/2001.
{
CWnd* pwnd = GetDlgItem(IDC_LOG_FILE); //Raid #501877, yanggao, 12/03/2001
if( pwnd )
{
pwnd->SendMessage(EM_SETSEL, (WPARAM)0, (LPARAM)-1);
pwnd->SetFocus();
}
return;
}
}
int i = m_strLogFile.ReverseFind(L'.'); //Raid #553110, yanggao
if( i < 0 || strLogFileExt != m_strLogFile.Right(m_strLogFile.GetLength()-i) )
{
m_strLogFile = m_strLogFile + strLogFileExt;
}
LONG dwPosLow = 0, dwPosHigh = 0;
//This is a safe usage. m_strLogFile is full path.
hLogFile = CreateFile(m_strLogFile, // pointer to name of the file
GENERIC_WRITE, // access (read-write) mode
0, // share mode
NULL, // pointer to security attributes
OPEN_ALWAYS, // how to create
FILE_ATTRIBUTE_NORMAL, // file attributes
NULL // handle to file with attributes to copy
);
if (INVALID_HANDLE_VALUE == hLogFile) {
LPTSTR pszErr;
CString strMsg;
////Raid #501886, yanggao, 12/03/2001, Get the error description from system.
FormatMessage(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_SYSTEM,
NULL,
GetLastError(),
0,
(LPTSTR)&pszErr,
0,
NULL
);
strMsg = pszErr + m_strLogFile;
if( m_strLogFile.GetLength() >= MAX_PATH )
{
CString strTemp;
strTemp.LoadString(IDS_PATH_TOO_LONG);
strMsg = strMsg + L"\n" + strTemp;
}
CString strTitle;
strTitle.LoadString(IDS_ANALYSIS_VIEWER_NAME);
MessageBox(strMsg,strTitle,MB_OK);
CWnd* pwnd = GetDlgItem(IDC_LOG_FILE);
if( pwnd )
{
pwnd->SendMessage(EM_SETSEL, (WPARAM)0, (LPARAM)-1);
pwnd->SetFocus();
}
return;
}
dwPosLow = SetFilePointer(hLogFile, 0, &dwPosHigh, FILE_END );
CloseHandle(hLogFile);
CWaitCursor wc;
DWORD smstatus = ERROR_SUCCESS;
LPNOTIFY pNotify = m_pComponentData->GetNotifier();
ASSERT(pNotify);
//
// Lock the analysis pane since its data is invalid while we're inspecting
//
if (pNotify) {
pNotify->LockAnalysisPane(TRUE);
}
CFolder *pFolder = m_pComponentData->GetAnalFolder();
//
// Force the Analysis root node to be selected so that we display
// the generating information message. If we forse this repaint to happen
// now then we don't seem to have that AV problem.
//
if(pFolder && pNotify){
pNotify->SelectScopeItem(pFolder->GetScopeItem()->ID);
}
//
// Make sure we don't have the database open. That'll prevent us
// from being able to configure.
//
m_pComponentData->UnloadSadInfo();
//
// Disable the child windows so they don't respond to input while we're
// performing the inspection
//
cwnd = GetWindow(GW_CHILD);
while(cwnd) {
cwnd->EnableWindow(FALSE);
cwnd = cwnd->GetNextWindow();
}
smstatus = DoIt();
//Raid #358503, 4/17/2001
if( m_hPWnd )
{
::EnableWindow(m_hPWnd, TRUE);
}
//
// The inspection data is valid now, so let people back at it
//
if (pNotify) {
pNotify->LockAnalysisPane(false, false);
}
m_pComponentData->SetErroredLogFile(m_strLogFile, dwPosLow );
//
// There was an error so display the log file (if any)
//
if (ERROR_SUCCESS != smstatus) {
m_pComponentData->SetFlags( CComponentDataImpl::flag_showLogFile );
}
//
// We're done inspecting so reenable input to the child windows
//
cwnd = GetWindow(GW_CHILD);
while(cwnd) {
cwnd->EnableWindow(TRUE);
cwnd = cwnd->GetNextWindow();
}
//CDialog::OnOK();
UpdateData();
DestroyWindow();
}
BOOL CPerformAnalysis::OnInitDialog()
{
//Raid #669945, yanggao, 8/9/2002
HWND framehwnd = NULL;
LPCONSOLE pconsole = m_pComponentData->GetConsole();
if( pconsole )
{
pconsole->GetMainWindow(&framehwnd);
if( framehwnd )
{
m_hPWnd = framehwnd;
::EnableWindow(framehwnd, FALSE);
}
}
CDialog::OnInitDialog();
CWnd* pwnd = GetDlgItem(IDC_LOG_FILE); //Raid #501886, yanggao, 12/03/2001
if( pwnd )
{
pwnd->SendMessage(EM_LIMITTEXT, MAX_PATH, 0);
}
UpdateData(FALSE);
if (m_strLogFile.IsEmpty()) {
m_ctlOK.EnableWindow(FALSE);
}
m_strOriginalLogFile = m_strLogFile;
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CPerformAnalysis::OnChangeLogFile()
{
UpdateData(TRUE);
if (m_strLogFile.IsEmpty())
m_ctlOK.EnableWindow(FALSE);
else
m_ctlOK.EnableWindow(TRUE);
m_strError.Empty();
}
void CPerformAnalysis::OnCancel() {
// CDialog::OnCancel();
if( m_hPWnd ) //Raid #669945, yanggao, 8/9/2002
{
::EnableWindow(m_hPWnd, TRUE);
}
m_strLogFile = m_strOriginalLogFile;
DestroyWindow();
}