// WiaLogCFGDlg.cpp : implementation file // #include "stdafx.h" #include "WiaLogCFG.h" #include "WiaLogCFGDlg.h" #include "AddRemove.h" #include "LogViewer.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////////////////////////////////////// // CWiaLogCFGDlg dialog CWiaLogCFGDlg::CWiaLogCFGDlg(CWnd* pParent /*=NULL*/) : CDialog(CWiaLogCFGDlg::IDD, pParent) { //{{AFX_DATA_INIT(CWiaLogCFGDlg) m_dwCustomLevel = 0; //}}AFX_DATA_INIT m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); m_bColorCodeLogViewerText = FALSE; } void CWiaLogCFGDlg::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); //{{AFX_DATA_MAP(CWiaLogCFGDlg) DDX_Control(pDX, IDC_COLOR_CODE_LOGVIEWER_TEXT, m_ColorCodeLogViewerTextCheckBox); DDX_Control(pDX, IDC_LOG_TO_DEBUGGER, m_LogToDebuggerCheckBox); DDX_Control(pDX, IDC_CLEARLOG_ON_BOOT, m_ClearLogOnBootCheckBox); DDX_Control(pDX, IDC_PARSE_PROGRESS, m_ProgressCtrl); DDX_Control(pDX, IDC_ADD_TIME, m_AddTimeCheckBox); DDX_Control(pDX, IDC_ADD_THREADID, m_AddThreadIDCheckBox); DDX_Control(pDX, IDC_ADD_MODULENAME, m_AddModuleCheckBox); DDX_Control(pDX, IDC_TRUNCATE_ON_BOOT, m_TruncateOnBootCheckBox); DDX_Control(pDX, IDC_SELECT_MODULE_COMBOBOX, m_ModuleComboBox); DDX_Control(pDX, IDC_LOG_LEVEL_WARNING, m_WarningCheckBox); DDX_Control(pDX, IDC_LOG_LEVEL_ERROR, m_ErrorCheckBox); DDX_Control(pDX, IDC_LOG_LEVEL_TRACE, m_TraceCheckBox); DDX_Control(pDX, IDC_FILTER_OFF, m_FilterOff); DDX_Control(pDX, IDC_FILTER_1, m_Filter1); DDX_Control(pDX, IDC_FILTER_2, m_Filter2); DDX_Control(pDX, IDC_FILTER_3, m_Filter3); DDX_Control(pDX, IDC_FILTER_CUSTOM, m_FilterCustom); DDX_Text(pDX, IDC_EDIT_CUSTOM_LEVEL, m_dwCustomLevel); DDV_MinMaxDWord(pDX, m_dwCustomLevel, 0, 9999); //}}AFX_DATA_MAP } BEGIN_MESSAGE_MAP(CWiaLogCFGDlg, CDialog) //{{AFX_MSG_MAP(CWiaLogCFGDlg) ON_WM_PAINT() ON_WM_QUERYDRAGICON() ON_BN_CLICKED(IDC_ADD_MODULE_BUTTON, OnAddModuleButton) ON_BN_CLICKED(IDC_DELETE_MODULE_BUTTON, OnDeleteModuleButton) ON_BN_CLICKED(IDC_WRITE_SETTINGS_BUTTON, OnWriteSettingsButton) ON_CBN_SELCHANGE(IDC_SELECT_MODULE_COMBOBOX, OnSelchangeSelectModuleCombobox) ON_BN_CLICKED(IDC_CLEARLOG_BUTTON, OnClearlogButton) ON_BN_CLICKED(IDC_VIEW_LOG_BUTTON, OnViewLogButton) ON_CBN_SETFOCUS(IDC_SELECT_MODULE_COMBOBOX, OnSetfocusSelectModuleCombobox) ON_CBN_DROPDOWN(IDC_SELECT_MODULE_COMBOBOX, OnDropdownSelectModuleCombobox) //}}AFX_MSG_MAP END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CWiaLogCFGDlg message handlers BOOL CWiaLogCFGDlg::OnInitDialog() { m_hInstance = NULL; m_hInstance = AfxGetInstanceHandle(); CDialog::OnInitDialog(); ShowProgress(FALSE); SetIcon(m_hIcon, TRUE); // Set big icon SetIcon(m_hIcon, FALSE); // Set small icon m_LogInfo.dwLevel = 0; m_LogInfo.dwMaxSize = 100000; m_LogInfo.dwMode = 0; m_LogInfo.dwTruncateOnBoot = 0; memset(m_LogInfo.szKeyName,0,sizeof(m_LogInfo.szKeyName)); m_CurrentSelection = 0; InitializeDialogSettings(SETTINGS_RESET_DIALOG); RegistryOperation(REG_READ); InitializeDialogSettings(SETTINGS_TO_DIALOG); CheckGlobalServiceSettings(); return TRUE; // return TRUE unless you set the focus to a control } // If you add a minimize button to your dialog, you will need the code below // to draw the icon. For MFC applications using the document/view model, // this is automatically done for you by the framework. void CWiaLogCFGDlg::OnPaint() { if (IsIconic()) { CPaintDC dc(this); // device context for painting SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0); // Center icon in client rectangle int cxIcon = GetSystemMetrics(SM_CXICON); int cyIcon = GetSystemMetrics(SM_CYICON); CRect rect; GetClientRect(&rect); int x = (rect.Width() - cxIcon + 1) / 2; int y = (rect.Height() - cyIcon + 1) / 2; // Draw the icon dc.DrawIcon(x, y, m_hIcon); } else { CDialog::OnPaint(); } } HCURSOR CWiaLogCFGDlg::OnQueryDragIcon() { return (HCURSOR) m_hIcon; } void CWiaLogCFGDlg::OnAddModuleButton() { CAddRemove AddRemoveDlg; AddRemoveDlg.SetTitle(TEXT("Add a Module")); AddRemoveDlg.SetStatusText(TEXT("Enter a Module Name:")); if(AddRemoveDlg.DoModal() == IDOK) { m_TruncateOnBootCheckBox.SetCheck(0); m_ClearLogOnBootCheckBox.SetCheck(0); AddRemoveDlg.GetNewKeyName(m_LogInfo.szKeyName); RegistryOperation(REG_ADD_KEY); RegistryOperation(REG_READ); CheckGlobalServiceSettings(); } } void CWiaLogCFGDlg::OnDeleteModuleButton() { if(MessageBox(TEXT("Are you sure you want to DELETE this module?"), TEXT("Delete Module"), MB_YESNO|MB_ICONQUESTION) == IDYES) { // // Delete this module // RegistryOperation(REG_DELETE_KEY); RegistryOperation(REG_READ); } } void CWiaLogCFGDlg::RegistryOperation(ULONG ulFlags) { TCHAR szAppRegistryKey[MAX_PATH]; TCHAR szValueName[MAX_PATH]; LoadString(m_hInstance, REGSTR_PATH_STICONTROL, szAppRegistryKey, MAX_PATH); CRegistry Registry(szAppRegistryKey,HKEY_LOCAL_MACHINE); // // move to logging // LoadString(m_hInstance,REGSTR_VAL_LOGGING , szValueName, MAX_PATH); Registry.MoveToSubKey(szValueName); if(ulFlags == REG_ADD_KEY) { // // Add a new key // Registry.CreateKey(m_LogInfo.szKeyName); // // change current selection to an invalid selection // m_CurrentSelection = -99; return; } if( ulFlags == REG_DELETE_KEY) { // // delete a Key // Registry.DeleteKey(m_LogInfo.szKeyName); return; } // // enumerate keys // DWORD dwIndex = 0; TCHAR pszKeyName[64]; m_ModuleComboBox.ResetContent(); while(Registry.EnumerateKeys(dwIndex++,pszKeyName, sizeof(pszKeyName)) != ERROR_NO_MORE_ITEMS) { m_ModuleComboBox.AddString(pszKeyName); } if(m_CurrentSelection == -99){ INT nIndex = m_ModuleComboBox.FindString(-1, m_LogInfo.szKeyName); m_CurrentSelection = nIndex; m_ModuleComboBox.SetCurSel(nIndex); } else { m_ModuleComboBox.GetLBText(m_CurrentSelection,m_LogInfo.szKeyName); } m_ModuleComboBox.SetCurSel(m_CurrentSelection); // // move to DLL specifc subkey // Registry.MoveToSubKey(m_LogInfo.szKeyName); switch(ulFlags) { case REG_WRITE: LoadString(m_hInstance,REGSTR_VAL_LOG_LEVEL , szValueName, MAX_PATH); Registry.SetValue(szValueName,m_LogInfo.dwLevel); LoadString(m_hInstance,REGSTR_VAL_MODE , szValueName, MAX_PATH); Registry.SetValue(szValueName,m_LogInfo.dwMode); LoadString(m_hInstance,REGSTR_VAL_MAXSIZE , szValueName, MAX_PATH); Registry.SetValue(szValueName,m_LogInfo.dwMaxSize); LoadString(m_hInstance,REGSTR_VAL_TRUNCATE_ON_BOOT , szValueName, MAX_PATH); Registry.SetValue(szValueName,m_LogInfo.dwTruncateOnBoot); LoadString(m_hInstance,REGSTR_VAL_CLEARLOG_ON_BOOT , szValueName, MAX_PATH); Registry.SetValue(szValueName,m_LogInfo.dwClearLogOnBoot); LoadString(m_hInstance,REGSTR_VAL_DETAIL , szValueName, MAX_PATH); Registry.SetValue(szValueName,m_LogInfo.dwDetail); LoadString(m_hInstance,REGSTR_VAL_LOG_TO_DEBUGGER, szValueName, MAX_PATH); Registry.SetValue(szValueName,m_LogInfo.dwLogToDebugger); break; case REG_READ: default: LoadString(m_hInstance,REGSTR_VAL_LOG_LEVEL , szValueName, MAX_PATH); m_LogInfo.dwLevel = Registry.GetValue(szValueName,WIALOG_NO_LEVEL); LoadString(m_hInstance,REGSTR_VAL_MODE , szValueName, MAX_PATH); m_LogInfo.dwMode = Registry.GetValue(szValueName,WIALOG_ADD_MODULE|WIALOG_ADD_THREAD); LoadString(m_hInstance,REGSTR_VAL_MAXSIZE , szValueName, MAX_PATH); m_LogInfo.dwMaxSize = Registry.GetValue(szValueName,100000); LoadString(m_hInstance,REGSTR_VAL_TRUNCATE_ON_BOOT, szValueName, MAX_PATH); m_LogInfo.dwTruncateOnBoot = Registry.GetValue(szValueName,0); LoadString(m_hInstance,REGSTR_VAL_CLEARLOG_ON_BOOT, szValueName, MAX_PATH); m_LogInfo.dwClearLogOnBoot = Registry.GetValue(szValueName,0); LoadString(m_hInstance,REGSTR_VAL_DETAIL , szValueName, MAX_PATH); m_LogInfo.dwDetail = Registry.GetValue(szValueName,0); LoadString(m_hInstance,REGSTR_VAL_LOG_TO_DEBUGGER, szValueName, MAX_PATH); m_LogInfo.dwLogToDebugger = Registry.GetValue(szValueName,0); break; } } void CWiaLogCFGDlg::InitializeDialogSettings(ULONG ulFlags) { switch (ulFlags) { case SETTINGS_TO_DIALOG: // // set level of detail // switch (m_LogInfo.dwDetail) { case WIALOG_NO_LEVEL: m_FilterOff.SetCheck(1); break; case WIALOG_LEVEL1 : m_Filter1.SetCheck(1); break; case WIALOG_LEVEL2: m_Filter2.SetCheck(1); break; case WIALOG_LEVEL3: m_Filter3.SetCheck(1); break; default: m_FilterCustom.SetCheck(1); m_dwCustomLevel = m_LogInfo.dwDetail; UpdateData(FALSE); break; } // // set truncate on boot check box // if (m_LogInfo.dwTruncateOnBoot != 0) m_TruncateOnBootCheckBox.SetCheck(1); else m_TruncateOnBootCheckBox.SetCheck(0); // // set clear log on boot check box // if (m_LogInfo.dwClearLogOnBoot != 0) m_ClearLogOnBootCheckBox.SetCheck(1); else m_ClearLogOnBootCheckBox.SetCheck(0); // // set log to debugger check box // if (m_LogInfo.dwLogToDebugger != 0) m_LogToDebuggerCheckBox.SetCheck(1); else m_LogToDebuggerCheckBox.SetCheck(0); // // set trace level check boxes // if (m_LogInfo.dwLevel & WIALOG_TRACE) m_TraceCheckBox.SetCheck(1); if (m_LogInfo.dwLevel & WIALOG_ERROR) m_ErrorCheckBox.SetCheck(1); if (m_LogInfo.dwLevel & WIALOG_WARNING) m_WarningCheckBox.SetCheck(1); // // set additional details check boxes // if (m_LogInfo.dwMode & WIALOG_ADD_TIME) m_AddTimeCheckBox.SetCheck(1); if (m_LogInfo.dwMode & WIALOG_ADD_MODULE) m_AddModuleCheckBox.SetCheck(1); if (m_LogInfo.dwMode & WIALOG_ADD_THREAD) m_AddThreadIDCheckBox.SetCheck(1); break; case SETTINGS_FROM_DIALOG: // // get level of detail // if (m_FilterOff.GetCheck() == 1) m_LogInfo.dwDetail = WIALOG_NO_LEVEL; if (m_Filter1.GetCheck() == 1) m_LogInfo.dwDetail = WIALOG_LEVEL1; if (m_Filter2.GetCheck() == 1) m_LogInfo.dwDetail = WIALOG_LEVEL2; if (m_Filter3.GetCheck() == 1) m_LogInfo.dwDetail = WIALOG_LEVEL3; if (m_FilterCustom.GetCheck() == 1) { UpdateData(TRUE); m_LogInfo.dwDetail = m_dwCustomLevel; } // // get truncate on boot check box // if (m_TruncateOnBootCheckBox.GetCheck() == 1) m_LogInfo.dwTruncateOnBoot = 1; else m_LogInfo.dwTruncateOnBoot = 0; // // get clear log on boot check box // if (m_ClearLogOnBootCheckBox.GetCheck() == 1) m_LogInfo.dwClearLogOnBoot = 1; else m_LogInfo.dwClearLogOnBoot = 0; // // get log to debugger check box // if(m_LogToDebuggerCheckBox.GetCheck() == 1) m_LogInfo.dwLogToDebugger = 1; else m_LogInfo.dwLogToDebugger = 0; // // get trace level check boxes // m_LogInfo.dwLevel = 0; if (m_TraceCheckBox.GetCheck() == 1) m_LogInfo.dwLevel = m_LogInfo.dwLevel | WIALOG_TRACE; if (m_ErrorCheckBox.GetCheck() == 1) m_LogInfo.dwLevel = m_LogInfo.dwLevel | WIALOG_ERROR; if (m_WarningCheckBox.GetCheck() == 1) m_LogInfo.dwLevel = m_LogInfo.dwLevel | WIALOG_WARNING; // // set additional details check boxes // m_LogInfo.dwMode = 0; if (m_AddTimeCheckBox.GetCheck() == 1) m_LogInfo.dwMode = m_LogInfo.dwMode | WIALOG_ADD_TIME; if (m_AddModuleCheckBox.GetCheck() == 1) m_LogInfo.dwMode = m_LogInfo.dwMode | WIALOG_ADD_MODULE; if (m_AddThreadIDCheckBox.GetCheck() == 1) m_LogInfo.dwMode = m_LogInfo.dwMode | WIALOG_ADD_THREAD; break; default: m_FilterOff.SetCheck(0); m_Filter1.SetCheck(0); m_Filter2.SetCheck(0); m_Filter3.SetCheck(0); m_FilterCustom.SetCheck(0); m_TruncateOnBootCheckBox.SetCheck(0); m_TraceCheckBox.SetCheck(0); m_ErrorCheckBox.SetCheck(0); m_WarningCheckBox.SetCheck(0); m_AddTimeCheckBox.SetCheck(0); m_AddModuleCheckBox.SetCheck(0); m_AddThreadIDCheckBox.SetCheck(0); m_dwCustomLevel = 0; UpdateData(FALSE); break; } } void CWiaLogCFGDlg::OnOK() { InitializeDialogSettings(SETTINGS_FROM_DIALOG); RegistryOperation(REG_WRITE); CDialog::OnOK(); } void CWiaLogCFGDlg::OnWriteSettingsButton() { InitializeDialogSettings(SETTINGS_FROM_DIALOG); RegistryOperation(REG_WRITE); } void CWiaLogCFGDlg::OnSelchangeSelectModuleCombobox() { m_CurrentSelection = m_ModuleComboBox.GetCurSel(); if(m_CurrentSelection < 0) return; CheckGlobalServiceSettings(); InitializeDialogSettings(SETTINGS_RESET_DIALOG); RegistryOperation(REG_READ); InitializeDialogSettings(SETTINGS_TO_DIALOG); } void CWiaLogCFGDlg::OnClearlogButton() { // // Get Windows Directory // TCHAR szLogFilePath[MAX_PATH]; DWORD dwLength = 0; dwLength = ::GetWindowsDirectory(szLogFilePath,sizeof(szLogFilePath)); if (( dwLength == 0) || !*szLogFilePath ) { OutputDebugString(TEXT("Could not GetWindowsDirectory()")); return; } // // Add log file name to Windows Directory // lstrcat(lstrcat(szLogFilePath,TEXT("\\")),TEXT("wiaservc.log")); // // Create / open Log file // HANDLE hLogFile = ::CreateFile(szLogFilePath, GENERIC_WRITE, FILE_SHARE_WRITE | FILE_SHARE_READ, NULL, // security attributes CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); // template file handle if(hLogFile != NULL) CloseHandle(hLogFile); } void CWiaLogCFGDlg::OnViewLogButton() { CLogViewer LogViewer; if (m_ColorCodeLogViewerTextCheckBox.GetCheck() == 1) m_bColorCodeLogViewerText = TRUE; else m_bColorCodeLogViewerText = FALSE; LogViewer.ColorizeText(m_bColorCodeLogViewerText); // // initialize progress // m_ProgCtrl.SetControl(&m_ProgressCtrl); LogViewer.SetProgressCtrl(&m_ProgCtrl); ShowProgress(TRUE); LogViewer.DoModal(); ShowProgress(FALSE); } void CWiaLogCFGDlg::ShowProgress(BOOL bShow) { if(bShow) { m_ProgressCtrl.ShowWindow(SW_SHOW); } else { m_ProgressCtrl.ShowWindow(SW_HIDE); } } void CWiaLogCFGDlg::OnSetfocusSelectModuleCombobox() { OnWriteSettingsButton(); } void CWiaLogCFGDlg::OnDropdownSelectModuleCombobox() { OnWriteSettingsButton(); } void CWiaLogCFGDlg::CheckGlobalServiceSettings() { TCHAR szKeyName[MAX_PATH]; m_ModuleComboBox.GetLBText(m_CurrentSelection,szKeyName); if(lstrcmp(szKeyName,TEXT("WIASERVC")) == 0) { m_TruncateOnBootCheckBox.EnableWindow(TRUE); m_ClearLogOnBootCheckBox.EnableWindow(TRUE); } else { m_TruncateOnBootCheckBox.EnableWindow(FALSE); m_ClearLogOnBootCheckBox.EnableWindow(FALSE); } }