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

157 lines
4.3 KiB
C++

/**********************************************************************/
/** Microsoft Windows NT **/
/** Copyright(c) Microsoft Corp., 1992 **/
/**********************************************************************/
/*
CnclTask.hxx
This file contains the class definition for the Task Cancel dialog.
FILE HISTORY:
Johnl 20-Oct-1992 Created
*/
#ifndef _CNCLTASK_HXX_
#define _CNCLTASK_HXX_
#include "applibrc.h"
#define SLT_STATUS_TEXT 200
#define CANCEL_TASK_DIALOG_NAME (MAKEINTRESOURCE( IDD_CANCEL_TASK ))
#ifndef RC_INVOKED
#include "ellipsis.hxx"
#define CANCEL_TASK_TIMER_ID (0xBEEF)
#define CANCEL_TASK_TIMER_INTERVAL (10)
/*************************************************************************
NAME: CANCEL_TASK_DIALOG
SYNOPSIS: This dialog presents a simple dialog with a status text line
and a cancel button. At regular (short) intervals, a
virtual callout will be called.
INTERFACE:
DoOneItem
Redefine this method for the intervaled callout
If an error is returned, the user will be notified using the
message passed into the constructor with the inserted error
string and the object name that was last put in the status
field.
UpdateStatus
Sets the status text of the dialog. Should be set at the
beginning of each task (i.e., callout from DoOneItem).
PARENT: DIALOG_WINDOW
USES:
CAVEATS:
NOTES: Message format for displaying errors returned by DoOneItem.
%1 should be the error message text, %2 will be the object text
(%2 is optional).
By default, the object name will be what's in the status SLT.
HISTORY:
Johnl 21-Oct-1992 Created
**************************************************************************/
DLL_CLASS CANCEL_TASK_DIALOG : public DIALOG_WINDOW
{
public:
CANCEL_TASK_DIALOG( UINT idDialog,
HWND hwndParent,
const TCHAR * pszDlgTitle,
ULONG_PTR ulContext,
MSGID msgidErrorMsg,
ELLIPSIS_STYLE style = ELLIPSIS_PATH ) ;
~CANCEL_TASK_DIALOG() ;
APIERR UpdateStatus( const TCHAR * pszStatusText )
{ return _sltStatusText.SetText( pszStatusText ) ; }
protected:
//
// The callout is called until *pfContinue is set to FALSE. Errors can
// be reported simply by returning the error and setting *pfDisplayError
// to TRUE.
//
// To display an alternate message, set *pmsgidAlternateError
// It must have %1 (object name) and %2 (error).
//
virtual APIERR DoOneItem( ULONG_PTR ulContext,
BOOL * pfContinue,
BOOL * pfDisplayError,
MSGID * pmsgidAlternateError ) ;
virtual BOOL OnTimer( const TIMER_EVENT & e ) ;
//
// If we failed to construct the timer, then we will loop here calling
// OnTimer (i.e., simulating time slices w/o relinquishing control).
// We do it here rather then the constructor because derived vtables
// aren't setup at construct time.
//
virtual BOOL MayRun( void ) ;
//
// The object name to be used for error messages returned by DoOneItem
// Defaults to the text in the status SLT
//
virtual APIERR QueryObjectName( NLS_STR *pnlsObjName ) ;
BOOL IsFinished( void ) const
{ return _fDone ; }
void SetInTimer( BOOL fInTimer )
{ _fInTimer = fInTimer ; }
BOOL IsInTimer( void ) const
{ return _fInTimer ; }
private:
//
// Where ellipsized status messages are output
//
SLT_ELLIPSIS _sltStatusText ;
//
// The client's general purpose context
//
ULONG_PTR _ulContext ;
MSGID _msgidErrorMsg ;
UINT_PTR _idTimer ;
//
// Semaphore type flag so we don't re-enter the OnTimer method when
// we are waiting for user input after an error message.
// This allows us to not kill the timer every time we do an item.
//
BOOL _fInTimer ;
//
// Set to TRUE after DoOneItem indicates we're done.
//
BOOL _fDone ;
} ;
#endif //RC_INVOKED
#endif //_CNCLTASK_HXX_