|
|
//____________________________________________________________________________
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1995 - 1996.
//
// File: dlg.cxx
//
// Contents:
//
// Classes:
//
// Functions:
//
// History: 3/4/1996 RaviR Created
//
//____________________________________________________________________________
#include "..\pch\headers.hxx"
#pragma hdrstop
#include "..\inc\dll.hxx"
#include "dlg.hxx"
#include "..\inc\misc.hxx"
#include "..\inc\sadat.hxx"
#include "..\folderui\dbg.h"
#include "..\folderui\util.hxx"
//
// extern EXTERN_C
//
extern HINSTANCE g_hInstance; extern HANDLE g_hActCtx;
CPropPage::CPropPage( LPCTSTR szTmplt, LPTSTR ptszTaskPath): m_hPage(NULL), m_fTaskInTasksFolder(FALSE), m_fSupportsSystemRequired(FALSE), m_bPlatformId(0), m_fDirty(FALSE), m_fInInit(FALSE) { Win4Assert(ptszTaskPath != NULL && *ptszTaskPath);
lstrcpyn(m_ptszTaskPath, ptszTaskPath, ARRAY_LEN(m_ptszTaskPath));
SecureZeroMemory(&m_psp, sizeof(m_psp));
m_psp.dwSize = sizeof(PROPSHEETPAGE); m_psp.dwFlags = PSP_USECALLBACK | PSP_USEFUSIONCONTEXT; m_psp.hInstance = g_hInstance; m_psp.pszTemplate = szTmplt; m_psp.pfnDlgProc = StaticDlgProc; m_psp.pfnCallback = PageRelease; m_psp.pcRefParent = NULL; // do not set PSP_USEREFPARENT
m_psp.lParam = (LPARAM) this; m_psp.hActCtx = g_hActCtx; }
CPropPage::~CPropPage() { }
INT_PTR CALLBACK CPropPage::StaticDlgProc( HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) { CPropPage *pThis = (CPropPage *)GetWindowLongPtr(hDlg, DWLP_USER);
if (uMsg == WM_INITDIALOG) { LPPROPSHEETPAGE ppsp = (LPPROPSHEETPAGE)lParam;
pThis = (CPropPage *) ppsp->lParam;
pThis->m_hPage = hDlg;
SetWindowLongPtr(hDlg, DWLP_USER, (LONG_PTR)pThis); }
if (pThis != NULL) { return pThis->DlgProc(uMsg, wParam, lParam); } else { return DefWindowProc(hDlg, uMsg, wParam, lParam); } }
LRESULT CPropPage::DlgProc( UINT uMsg, WPARAM wParam, LPARAM lParam) { LRESULT lr;
switch (uMsg) { case WM_INITDIALOG: m_fInInit = TRUE; _BaseInit(); lr = _OnInitDialog(lParam); m_fInInit = FALSE; return lr;
case PSM_QUERYSIBLINGS: return _OnPSMQuerySibling(wParam, lParam);
case WM_NOTIFY: return _OnNotify(uMsg, (UINT)wParam, lParam);
case WM_WININICHANGE: return _OnWinIniChange(wParam, lParam);
case WM_SETFOCUS: return _OnSetFocus((HWND)wParam);
case WM_TIMER: return _OnTimer((UINT)wParam);
case WM_HELP: return _OnHelp(((LPHELPINFO) lParam)->hItemHandle, HELP_WM_HELP);
case WM_CONTEXTMENU: return _OnHelp((HANDLE) wParam, HELP_CONTEXTMENU);
case WM_COMMAND: if (m_fInInit) { return TRUE; } return(_OnCommand(GET_WM_COMMAND_ID(wParam, lParam), GET_WM_COMMAND_HWND(wParam, lParam), GET_WM_COMMAND_CMD(wParam, lParam))); case WM_DESTROY: return _OnDestroy();
default: return(FALSE); }
return(TRUE); }
LRESULT CPropPage::_OnNotify( UINT uMessage, UINT uParam, LPARAM lParam) { switch (((LPNMHDR)lParam)->code) { case PSN_APPLY: return _OnApply();
case PSN_RESET: _OnCancel(); return FALSE; // allow the property sheet to be destroyed.
case PSN_SETACTIVE: return _OnPSNSetActive(lParam);
case PSN_KILLACTIVE: return _OnPSNKillActive(lParam);
case DTN_DATETIMECHANGE: return _OnDateTimeChange(lParam);
case UDN_DELTAPOS: return _OnSpinDeltaPos((NM_UPDOWN *)lParam);
default: return _ProcessListViewNotifications(uMessage, uParam, lParam); }
return TRUE; }
LRESULT CPropPage::_OnPSMQuerySibling( WPARAM wParam, LPARAM lParam) { SetWindowLongPtr(Hwnd(), DWLP_MSGRESULT, 0); return 0; }
LRESULT CPropPage::_OnSpinDeltaPos( NM_UPDOWN * pnmud) { _EnableApplyButton();
// Return FALSE to allow the change in the control's position.
return FALSE; }
LRESULT CPropPage::_OnCommand( int id, HWND hwndCtl, UINT codeNotify) { return FALSE; }
LRESULT CPropPage::_OnWinIniChange( WPARAM wParam, LPARAM lParam) { return FALSE; }
LRESULT CPropPage::_OnApply(void) { return FALSE; }
LRESULT CPropPage::_OnCancel(void) { return FALSE; }
LRESULT CPropPage::_OnSetFocus( HWND hwndLoseFocus) { // An application should return zero if it processes this message.
return 1; }
LRESULT CPropPage::_OnPSNSetActive( LPARAM lParam) { SetWindowLongPtr(m_hPage, DWLP_MSGRESULT, 0); return TRUE; }
LRESULT CPropPage::_OnPSNKillActive( LPARAM lParam) { SetWindowLongPtr(m_hPage, DWLP_MSGRESULT, 0); return TRUE; }
LRESULT CPropPage::_OnDateTimeChange( LPARAM lParam) { SetWindowLongPtr(m_hPage, DWLP_MSGRESULT, 0); return TRUE; }
LRESULT CPropPage::_OnDestroy(void) { // If an application processes this message, it should return zero.
return 1; }
LRESULT CPropPage::_OnTimer( UINT idTimer) { // If an application processes this message, it should return zero.
return 1; }
BOOL CPropPage::_ProcessListViewNotifications( UINT uMsg, WPARAM wParam, LPARAM lParam) { return FALSE; }
UINT CALLBACK CPropPage::PageRelease( HWND hwnd, UINT uMsg, LPPROPSHEETPAGE ppsp) { if (uMsg == PSPCB_RELEASE) { //
// Determine instance that invoked this static function
//
CPropPage *pThis = (CPropPage *) ppsp->lParam;
//
// If page was created using an indirect dialog template, delete
// that.
//
if (pThis->m_psp.dwFlags & PSP_DLGINDIRECT) { delete [] (BYTE *)pThis->m_psp.pResource; }
delete pThis; }
return TRUE; }
//+---------------------------------------------------------------------------
//
// Member: CPropPage::_BaseInit, private
//
// Synopsis: Initialize scheduling-agent specific private data members,
// m_fTaskInTasksFolder & m_bPlatformId. Do so by reading SA.DAT
// in the folder containing the task.
//
// Arguments: None.
//
// Returns: None.
//
// Notes: None.
//
//----------------------------------------------------------------------------
void CPropPage::_BaseInit(void) { TCHAR tszFolder[MAX_PATH + 1];
::GetParentDirectory(m_ptszTaskPath, tszFolder, MAX_PATH + 1);
//
// If running on the local system, we can determine whether resume
// timers are supported directly instead of by checking sa.dat, which
// might be stale.
//
BOOL fLocal = IsLocalFilename(m_ptszTaskPath);
if (fLocal) { CheckSaDat(tszFolder); }
//
// Read sa.dat on target machine
//
HRESULT hr; DWORD dwVersion; BYTE bSvcFlags;
hr = SADatGetData(tszFolder, &dwVersion, &m_bPlatformId, &bSvcFlags);
if (SUCCEEDED(hr)) { m_fTaskInTasksFolder = TRUE;
if (fLocal) { m_fSupportsSystemRequired = ResumeTimersSupported(); } else { m_fSupportsSystemRequired = bSvcFlags & SA_DAT_SVCFLAG_RESUME_TIMERS; } } else { //
// Default on error (the file doesn't exist or the read failed).
// Assume the task is external to the task folder and it exists
// on a non-NT machine that doesn't support the system required
// flag.
//
m_fTaskInTasksFolder = FALSE; m_bPlatformId = VER_PLATFORM_WIN32_WINDOWS; m_fSupportsSystemRequired = FALSE; } }
//____________________________________________________________________________
//____________________________________________________________________________
//________________ _________________________________________
//________________ class CDlg _________________________________________
//________________ _________________________________________
//____________________________________________________________________________
//____________________________________________________________________________
INT_PTR CDlg::RealDlgProc( UINT uMsg, WPARAM wParam, LPARAM lParam) { return(FALSE); }
INT_PTR CALLBACK CDlg::DlgProc( HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) { CDlg *pThis = (CDlg *)GetWindowLongPtr(hDlg, DWLP_USER);
if (uMsg == WM_INITDIALOG) { pThis = (CDlg *)lParam; pThis->m_hDlg = hDlg; SetWindowLongPtr(hDlg, DWLP_USER, lParam); }
if (pThis != NULL) { return pThis->RealDlgProc(uMsg, wParam, lParam); } else { return DefWindowProc(hDlg, uMsg, wParam, lParam); } }
INT_PTR CDlg::DoModal( UINT idRes, HWND hParent) { return(DialogBoxParam(g_hInstance, MAKEINTRESOURCE(idRes), hParent, DlgProc, (LPARAM)this)); }
HWND CDlg::DoModeless( UINT idRes, HWND hParent) { return(CreateDialogParam(g_hInstance, MAKEINTRESOURCE(idRes), hParent, DlgProc, (LPARAM)this)); }
|