Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
//******************************************************************
// source.cpp
//
// This is file contains the implementation of the CSource class.
//
// The CSource class acts as a container class for the message source,
// which is composed of the source tree control and the message list.
//
// Author: Larry A. French
//
// History:
// 20-Febuary-1996 Larry A. French
// Wrote it.
//
//
// Copyright (C) 1995, 1996 Microsoft Corporation. All rights reserved.
//******************************************************************
#include "stdafx.h"
#include "regkey.h"
#include "source.h"
#include "utils.h"
#include "globals.h"
#include "tcsource.h"
#include "lcsource.h"
#include "evntfind.h"
#include "trapdlg.h"
CSource::CSource() { m_pEventSource = NULL; m_ptcSource = NULL; m_plcSource = NULL; m_pdlgEventTrap = NULL; m_pdlgFind = NULL; }
CSource::~CSource() { delete m_pdlgFind; }
SCODE CSource::Create(CEventTrapDlg* pdlgEventTrap) { m_ptcSource = &pdlgEventTrap->m_tcSource; m_ptcSource->m_pSource = this;
m_plcSource = &pdlgEventTrap->m_lcSource; m_plcSource->m_pSource = this;
m_pdlgEventTrap = pdlgEventTrap;
return S_OK; }
//***************************************************************************
// CSource::NotifyTcSelChanged
//
// This method returns an array of pointers to the messages currently selected
// in the CLcEvents list control. These pointers are owned by g_aEventLogs and
// the caller should not delete them.
//
// Parameters:
// None.
//
// Returns:
// Nothing.
//
//***************************************************************************
void CSource::GetSelectedMessages(CXMessageArray& aMessages) { m_plcSource->GetSelectedMessages(aMessages); }
//***************************************************************************
// CSource::NotifyTcSelChanged
//
// This method is called when the selection changes in the event-source tree
// control (CTcSource). When the selection changes, the message list must
// be updated.
//
// Parameters:
// None.
//
// Returns:
// Nothing.
//
//***************************************************************************
void CSource::NotifyTcSelChanged() { m_pEventSource = m_ptcSource->GetSelectedEventSource(); m_plcSource->SetEventSource(m_pEventSource); m_pdlgEventTrap->NotifySourceSelChanged(); }
//***************************************************************************
//
// CSource::CreateWindowEpilogue()
//
// This method is called after a window has been created for this list
// control. Final initialization is done here.
//
// Parameters:
// None.
//
// Returns:
// SCODE
// S_OK if the initialization was successful, otherwise E_FAIL.
//
// Status:
//
//***************************************************************************
SCODE CSource::CreateWindowEpilogue() { SCODE scTc = m_ptcSource->CreateWindowEpilogue(); SCODE scLc = m_plcSource->CreateWindowEpilogue();
if (FAILED(scTc) || FAILED(scLc)) { return E_FAIL; } return S_OK; }
//******************************************************************
// CSource::Find
//
// Find the specified event source. This is done by searching either
// the tree or the list control depending on the bSearchTree parameter.
//
// Parameters:
// BOOL bSearchTree
// TRUE if the tree should be searched, otherwise the list control
// is searched.
//
// CString& sText
// A string containing the text to search for.
//
// BOOL bWholeWord
// TRUE if this is a "whole word" search. False if it
// is OK to match a partial word.
//
// BOOL bMatchCase
// TRUE if a case-sensitive comparison should be used.
//
// Returns:
// BOOL
// TRUE if the string was found, FALSE otherwise. If the specified
// text is found, then the selection is set on the corresponding
// item, the item is scrolled into view and the focus
// is set on the item.
//
//******************************************************************
BOOL CSource::Find(BOOL bSearchTree, CString sText, BOOL bWholeWord, BOOL bMatchCase) { if (bSearchTree) return m_ptcSource->Find(sText, bWholeWord, bMatchCase); else return m_plcSource->Find(sText, bWholeWord, bMatchCase); }
//************************************************************************
// CSource::OnFind
//
// This method is called when the "Find" button in the CEventTrap dialog
// is clicked.
//
// Parameters:
// CWnd* pwndParent
// Pointer to the parent window of the "find" dialog. This happens
// to be the CEventTrapDialog.
//
// Returns:
// Nothing.
//
//*************************************************************************
void CSource::OnFind(CWnd* pwndParent) { if (m_pdlgFind == NULL) { m_pdlgFind = new CEventFindDlg(pwndParent); m_pdlgFind->Create(this, IDD_EVENTFINDDLG, pwndParent); }
m_pdlgFind->BringWindowToTop(); }
//*************************************************************************
// CSource::NotifyTrappingChange
//
// This method is called when an event is added or removed from the
// event list. This CSource message source container must be notified
// so that the corresponding method can be marked as trapped or not
// trapped in the CLcSource list control.
//
// Parameters:
// CXEventSource* pEventSource
// Pointer to the event's event-source
//
// DWORD dwId
// The event's ID
//
// BOOL bIsTrapping
// TRUE if the event is being trapped, FALSE if not.,
//
// Returns:
// Nothing.
//*************************************************************************
void CSource::NotifyTrappingChange(CXEventSource* pEventSource, DWORD dwId, BOOL bIsTrapping) { if (pEventSource == m_pEventSource) { m_plcSource->NotifyTrappingChange(dwId, bIsTrapping); } }
|