|
|
//+---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1996.
//
// File: runobj.hxx
//
// Contents: CRun class definition.
//
// Classes: CRun
//
// Functions: None.
//
// History: 08-Sep-95 EricB Created.
// 01-Dec-95 MarkBl Split from util.hxx.
//
//----------------------------------------------------------------------------
#ifndef __RUNOBJ_HXX__
#define __RUNOBJ_HXX__
//#include "time.hxx"
#undef SetFlag
#undef ClearFlag
#undef IsFlagSet
//
// Run processing flags: values 0x00010000 through 0x80000000 for run state:
//
#define RUN_STATUS_RUNNING 0x00010000
#define RUN_STATUS_FINISHED 0x00020000
#define RUN_STATUS_ABORTED 0x00040000
#define RUN_STATUS_TIMED_OUT 0x00080000
#define RUN_STATUS_CLOSE_PENDING 0x00100000
#define RUN_STATUS_CLOSED 0x00200000 // (This is set, but not used yet)
#define RUN_STATUS_RESTART_ON_IDLE_RESUME 0x00400000
//+----------------------------------------------------------------------------
//
// Class: CRun
//
// Synopsis: Lightweight job object. A moniker of sorts to the real thing.
// Represents one run instance of a job.
//
// CODEWORK: (AnirudhS 11/7/96) The inheritance relationship should be:
// class CRun : protected CDLink (instead of public CDLink)
// class CRunList : private CRun (instead of having a private CRun member)
// This would assure us that only CRunList could call CRun's CDLink methods.
//
//-----------------------------------------------------------------------------
class CRun : public CDLink { public: CRun(LPFILETIME pft, LPFILETIME pftDeadline, FILETIME ftKill, DWORD MaxRunTime, DWORD rgFlags, WORD wIdleWait, BOOL fKeepAfterRunning); CRun(DWORD MaxRunTime, DWORD rgFlags, FILETIME ftDeadline, BOOL fKeepAfterRunning); CRun(DWORD MaxRunTime, DWORD rgFlags, WORD wIdleWait, FILETIME ftDeadline, BOOL fKeepAfterRunning); CRun(CRun * pRun); CRun(void); ~CRun();
HRESULT Initialize(LPCTSTR ptszName) { return(this->SetName(ptszName)); }
void GetSysTime(LPSYSTEMTIME pst) {FileTimeToSystemTime(&m_ft, pst);} void GetTime(LPFILETIME pft) {*pft = m_ft;} LPFILETIME GetTime(void) {return &m_ft;} LPFILETIME GetDeadline(void) {return &m_ftDeadline;} void RelaxDeadline(FILETIME ftDeadline) { if (CompareFileTime(&ftDeadline, &m_ftDeadline) > 0) m_ftDeadline = ftDeadline; } WORD GetWait(void) {return m_wIdleWait;} void ReduceWaitTo(WORD wIdleWait) { m_wIdleWait = min(m_wIdleWait, wIdleWait);}
FILETIME GetKillTime() { return m_ftKill; } void AdvanceKillTime(FILETIME ftKill) { if (CompareFileTime(&ftKill, &m_ftKill) < 0) m_ftKill = ftKill; } void AdjustKillTimeByMaxRunTime(FILETIME ftNow);
void SetMaxRunTime(DWORD dwMaxRunTime) {m_dwMaxRunTime = dwMaxRunTime;} DWORD GetMaxRunTime(void) {return(m_dwMaxRunTime);}
CRun * Next(void) { return (CRun *)CDLink::Next(); } CRun * Prev(void) { return (CRun *)CDLink::Prev(); }
BOOL IsNull(void) {return(m_ft.dwLowDateTime == 0 && m_ft.dwHighDateTime == 0);};
HRESULT SetName(LPCTSTR ptszName); LPTSTR GetName(void) { return m_ptszJobName; }
void SetHandle(HANDLE hJob) { m_hJob = hJob; this->SetFlag(RUN_STATUS_RUNNING); } HANDLE GetHandle(void) const { return(m_hJob); }
// this function takes ownership of the handles
// will release / close them on destruction
// bCloseUserHandle == FALSE will prevent dtor from closing handle
void SetProfileHandles(HANDLE hUser, HANDLE hProfile, BOOL bCloseUserHandle) { m_hUserToken = hUser; m_hProfile = hProfile;
m_bCloseUserHandle = bCloseUserHandle; }
HRESULT SetDesktop( LPCTSTR ptszDesktop ); LPTSTR GetDesktop( void ) { return m_ptszDesktop; }
HRESULT SetStation( LPCTSTR ptszStation );
LPTSTR GetStation( void ) { return m_ptszStation; }
void SetFlag(DWORD rgFlag) { m_rgFlags |= rgFlag; } void ClearFlag(DWORD rgFlag) { m_rgFlags &= ~rgFlag; } DWORD GetFlags(void) { return(m_rgFlags); } BOOL IsFlagSet(DWORD rgFlag) {return (m_rgFlags & rgFlag);}
BOOL IsIdleTriggered() { return m_fKeepInList; }
void SetProcessId(DWORD dwProcessId) { m_dwProcessId = dwProcessId; } DWORD GetProcessId(void) { return(m_dwProcessId); }
private: FILETIME m_ft; // When this instance is to run
FILETIME m_ftDeadline; // Latest time when this instance may be started
FILETIME m_ftKill; // Time by which this instance must terminate
// (see the detailed comment on this field in
// procssr.cxx)
LPTSTR m_ptszJobName; // Job name.
HANDLE m_hJob; // The process handle when run
DWORD m_dwProcessId; // The process ID when run
HANDLE m_hUserToken; // User token
HANDLE m_hProfile; // User profile
LPTSTR m_ptszDesktop; //Windows Desktop
LPTSTR m_ptszStation; //WindowsStation
DWORD m_rgFlags; // Job Flags
DWORD m_dwMaxRunTime; // The remaining time to wait for the job to
// terminate (see the detailed comment on this
// field in procssr.cxx)
WORD m_wIdleWait; // The idle wait to determine when to run
// idle tasks.
BOOL m_fKeepInList; // Whether to keep this run in the idle list
// after starting it (set for jobs with idle
// triggers)
BOOL m_bCloseUserHandle; // if TRUE, m_hUserToken is ClosedHandle'd in dtor
public: BOOL m_fStarted; // Whether the run was started since the last
// idle period began
};
//+----------------------------------------------------------------------------
//
// Run object list class
//
//-----------------------------------------------------------------------------
class CRunList { public: CRunList(); ~CRunList();
void FreeList(void); CRun * GetFirstJob(void) {return m_RunHead.Next();} BOOL IsEmpty() {return m_RunHead.Next() == &m_RunHead;} //
// The following members allow the list to be used as a simple, unsorted,
// (doubly) linked list.
//
void Add(CRun * pRun); HRESULT AddCopy(CRun * pRun);
protected: CRun m_RunHead; };
class CTimeRunList : private CRunList { public: void FreeList(void) {CRunList::FreeList();} CRun * GetFirstJob(void) {return CRunList::GetFirstJob();} BOOL IsEmpty() {return CRunList::IsEmpty();} //
// The following members allow the list to be used as a sorted queue:
//
HRESULT AddSorted(FILETIME ftRun, FILETIME ftDeadline, FILETIME ftKillTime, LPTSTR ptszJobName, DWORD dwJobFlags, DWORD dwMaxRunTime, WORD wIdleWait, WORD * pCount, WORD cLimit); CRun * Pop(void); HRESULT PeekHeadTime(LPFILETIME pft); HRESULT MakeSysTimeArray(LPSYSTEMTIME *, WORD *); };
class CIdleRunList : private CRunList { public: void FreeList(void); CRun * GetFirstJob(void) {return CRunList::GetFirstJob();} //
// The following members allow the list to be used as a sorted queue,
// sorted on idle wait times. The member at the head of the queue has
// the least idle wait time.
//
void AddSortedByIdleWait(CRun * pRun); WORD GetFirstWait(void); void MarkNoneStarted(void); void FreeExpiredOrRegenerated(); };
//+----------------------------------------------------------------------------
//
// Method: CRunList::CRunList
//
// Synopsis: Constructor
//
//-----------------------------------------------------------------------------
inline CRunList::CRunList(void) { //
// Set the head node to point to itself. Note that the head node uses
// the default ctor which sets the FILETIME member to {0, 0}. This null
// FILETIME will be used as a marker for the head of the doubly linked
// list.
//
m_RunHead.SetNext(&m_RunHead); m_RunHead.SetPrev(&m_RunHead); }
//+----------------------------------------------------------------------------
//
// Method: CRunList::CRunList
//
// Synopsis: Destructor
//
//-----------------------------------------------------------------------------
inline CRunList::~CRunList(void) { FreeList(); }
//+----------------------------------------------------------------------------
//
// Member: CRunList::Add
//
// Synopsis: Add an element to the unsorted list.
//
//-----------------------------------------------------------------------------
inline void CRunList::Add(CRun * pAdd) { pAdd->LinkAfter(&m_RunHead); }
#endif // __RUNOBJ_HXX__
|