433 lines
13 KiB
C
433 lines
13 KiB
C
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
//
|
||
|
// Copyright (c) 2000 Microsoft Corporation
|
||
|
//
|
||
|
// Module Name:
|
||
|
// Exceptions.h
|
||
|
//
|
||
|
// Description:
|
||
|
// This file contains the declarations of many exception classes.
|
||
|
//
|
||
|
// Implementation File:
|
||
|
// None.
|
||
|
//
|
||
|
// Maintained By:
|
||
|
// Vij Vasu (Vvasu) 03-MAR-2000
|
||
|
//
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
|
||
|
// Make sure that this file is included only once per compile path.
|
||
|
#pragma once
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
// Include Files
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// For HRESULT, WCHAR, etc.
|
||
|
#include <windef.h>
|
||
|
|
||
|
// For the base class of all exceptions
|
||
|
#include "CException.h"
|
||
|
|
||
|
// For the CStr class
|
||
|
#include "CStr.h"
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////
|
||
|
// Macro Definitions
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
//
|
||
|
// Shorthand for throwing different exceptions.
|
||
|
//
|
||
|
|
||
|
#define THROW_ASSERT( _hrErrorCode, _pszMessage ) \
|
||
|
throw CAssert( _hrErrorCode, TEXT( __FILE__ ), __LINE__, TEXT( _pszMessage ) )
|
||
|
|
||
|
#define THROW_RUNTIME_ERROR( _hrErrorCode, _stringId ) \
|
||
|
throw CRuntimeError( _hrErrorCode, TEXT( __FILE__ ), __LINE__, _stringId )
|
||
|
|
||
|
#define THROW_CONFIG_ERROR( _hrErrorCode, _stringId ) \
|
||
|
throw CConfigError( _hrErrorCode, TEXT( __FILE__ ), __LINE__, _stringId )
|
||
|
|
||
|
#define THROW_ABORT( _hrErrorCode, _stringId ) \
|
||
|
throw CAbortException( _hrErrorCode, TEXT( __FILE__ ), __LINE__, _stringId )
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////
|
||
|
// External variable declarations
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// Handle to the instance of this DLL
|
||
|
extern HINSTANCE g_hInstance;
|
||
|
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
//++
|
||
|
//
|
||
|
// class CExceptionWithString
|
||
|
//
|
||
|
// Description:
|
||
|
// The class is a CException with an additional message string.
|
||
|
//
|
||
|
//--
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
class CExceptionWithString : public CException
|
||
|
{
|
||
|
public:
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public type definitions
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
typedef CException BaseClass;
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public constructors and destructors
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// Constructor ( string id overload )
|
||
|
CExceptionWithString(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, UINT uiErrorStringIdIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn )
|
||
|
, m_fHasUserBeenNotified( false )
|
||
|
{
|
||
|
AssignString( uiErrorStringIdIn );
|
||
|
}
|
||
|
|
||
|
// Constructor ( character string overload )
|
||
|
CExceptionWithString(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, const WCHAR * pcszErrorStringIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn )
|
||
|
, m_fHasUserBeenNotified( false )
|
||
|
{
|
||
|
AssignString( pcszErrorStringIn );
|
||
|
}
|
||
|
|
||
|
// Copy constructor.
|
||
|
CExceptionWithString( const CExceptionWithString & cesuSrcIn ) throw()
|
||
|
: BaseClass( cesuSrcIn )
|
||
|
, m_fHasUserBeenNotified( cesuSrcIn.m_fHasUserBeenNotified )
|
||
|
{
|
||
|
AssignString( cesuSrcIn.m_strErrorString );
|
||
|
}
|
||
|
|
||
|
// Default destructor.
|
||
|
~CExceptionWithString() throw() {}
|
||
|
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public methods
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// Assignment operator.
|
||
|
const CExceptionWithString &
|
||
|
operator =( const CExceptionWithString & cesuSrcIn ) throw()
|
||
|
{
|
||
|
*( static_cast< BaseClass * >( this ) ) = cesuSrcIn;
|
||
|
AssignString( cesuSrcIn.m_strErrorString );
|
||
|
m_fHasUserBeenNotified = cesuSrcIn.m_fHasUserBeenNotified;
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Accessor methods.
|
||
|
//
|
||
|
const CStr &
|
||
|
StrGetErrorString() const throw() { return m_strErrorString; }
|
||
|
|
||
|
void
|
||
|
SetErrorString( const WCHAR * pcszSrcIn ) throw()
|
||
|
{
|
||
|
AssignString( pcszSrcIn );
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
FHasUserBeenNotified() const throw() { return m_fHasUserBeenNotified; }
|
||
|
|
||
|
void
|
||
|
SetUserNotified( bool fNotifiedIn = true ) throw() { m_fHasUserBeenNotified = fNotifiedIn; }
|
||
|
|
||
|
private:
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Private member functions
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// Function to set the member string ( string id overload ).
|
||
|
void AssignString( UINT uiStringIdIn ) throw()
|
||
|
{
|
||
|
try
|
||
|
{
|
||
|
m_strErrorString.Empty();
|
||
|
m_strErrorString.LoadString( g_hInstance, uiStringIdIn );
|
||
|
}
|
||
|
catch( ... )
|
||
|
{
|
||
|
// If an error has occurred, nothing can be done - we are most probably in a stack unwind anyway.
|
||
|
THR( E_UNEXPECTED );
|
||
|
} // catch all: cannot let an exception propagate out of any of the methods of this class
|
||
|
}
|
||
|
|
||
|
// Function to set the member string ( character string overload ).
|
||
|
void AssignString( const WCHAR * pcszSrcIn ) throw()
|
||
|
{
|
||
|
try
|
||
|
{
|
||
|
m_strErrorString.Empty();
|
||
|
m_strErrorString.Assign( pcszSrcIn );
|
||
|
}
|
||
|
catch( ... )
|
||
|
{
|
||
|
// If an error has occurred, nothing can be done - we are most probably in a stack unwind anyway.
|
||
|
THR( E_UNEXPECTED );
|
||
|
} // catch all: cannot let an exception propagate out of any of the methods of this class
|
||
|
}
|
||
|
|
||
|
|
||
|
// Function to set the member string ( CStr overload ).
|
||
|
void AssignString( const CStr & rcstrSrcIn ) throw()
|
||
|
{
|
||
|
try
|
||
|
{
|
||
|
m_strErrorString.Empty();
|
||
|
m_strErrorString.Assign( rcstrSrcIn );
|
||
|
}
|
||
|
catch( ... )
|
||
|
{
|
||
|
// If an error has occurred, nothing can be done - we are most probably in a stack unwind anyway.
|
||
|
THR( E_UNEXPECTED );
|
||
|
} // catch all: cannot let an exception propagate out of any of the methods of this class
|
||
|
}
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Private data
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
CStr m_strErrorString;
|
||
|
|
||
|
// Indicates if the user has been notified about this exception or not.
|
||
|
bool m_fHasUserBeenNotified;
|
||
|
|
||
|
}; //*** class CExceptionWithString
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
//++
|
||
|
//
|
||
|
// class CAssert
|
||
|
//
|
||
|
// Description:
|
||
|
// This class of exceptions is used to represent programming errors or
|
||
|
// invalid assumptions.
|
||
|
//
|
||
|
// The accompanying message is not expected to be localized.
|
||
|
//
|
||
|
//--
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
class CAssert : public CExceptionWithString
|
||
|
{
|
||
|
public:
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public type definitions
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
typedef CExceptionWithString BaseClass;
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public constructors and destructors
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// CAssert ( string id overload ).
|
||
|
CAssert(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, UINT uiErrorStringIdIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn, uiErrorStringIdIn )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
// Constructor ( character string overload )
|
||
|
CAssert(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, const WCHAR * pcszErrorStringIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn, pcszErrorStringIn )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
|
||
|
}; //*** class CAssert
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
//++
|
||
|
//
|
||
|
// class CRuntimeError
|
||
|
//
|
||
|
// Description:
|
||
|
// This class of exceptions is used to signal runtime errors such as memory
|
||
|
// exhaustion, failure of Win32 API calls, etc.
|
||
|
//
|
||
|
// The accompanying message may be shown to the user and should therefore
|
||
|
// be localized.
|
||
|
//
|
||
|
//--
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
class CRuntimeError : public CExceptionWithString
|
||
|
{
|
||
|
public:
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public type definitions
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
typedef CExceptionWithString BaseClass;
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public constructors and destructors
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// Constructor ( string id overload ).
|
||
|
CRuntimeError(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, UINT uiErrorStringIdIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn, uiErrorStringIdIn )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
// Constructor ( character string overload )
|
||
|
CRuntimeError(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, const WCHAR * pcszErrorStringIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn, pcszErrorStringIn )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
}; //*** class CRuntimeError
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
//++
|
||
|
//
|
||
|
// class CAbortException
|
||
|
//
|
||
|
// Description:
|
||
|
// This exception is thrown to indicate that the configuration operation
|
||
|
// was aborted.
|
||
|
//
|
||
|
// The accompanying message may be shown to the user and should therefore
|
||
|
// be localized.
|
||
|
//
|
||
|
//--
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
class CAbortException : public CExceptionWithString
|
||
|
{
|
||
|
public:
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public type definitions
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
typedef CExceptionWithString BaseClass;
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public constructors and destructors
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// Constructor ( string id overload ).
|
||
|
CAbortException(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, UINT uiErrorStringIdIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn, uiErrorStringIdIn )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
// Constructor ( character string overload )
|
||
|
CAbortException(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, const WCHAR * pcszErrorStringIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn, pcszErrorStringIn )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
}; //*** class CAbortException
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
//++
|
||
|
//
|
||
|
// class CConfigError
|
||
|
//
|
||
|
// Description:
|
||
|
// This class of exceptions is used to signal errors related to cluster
|
||
|
// configuration. For example, an object of this class is thrown if the
|
||
|
// OS version of the computer cannot support the requested configuration
|
||
|
// step.
|
||
|
//
|
||
|
// The accompanying message may be shown to the user and should therefore
|
||
|
// be localized.
|
||
|
//
|
||
|
//--
|
||
|
//////////////////////////////////////////////////////////////////////////////
|
||
|
class CConfigError : public CExceptionWithString
|
||
|
{
|
||
|
public:
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public type definitions
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
typedef CExceptionWithString BaseClass;
|
||
|
|
||
|
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Public constructors and destructors
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
// Constructor ( string id overload )
|
||
|
CConfigError(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, UINT uiErrorStringIdIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn, uiErrorStringIdIn )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
// Constructor ( character string overload )
|
||
|
CConfigError(
|
||
|
HRESULT hrErrorCodeIn
|
||
|
, const WCHAR * pcszFileNameIn
|
||
|
, UINT uiLineNumberIn
|
||
|
, const WCHAR * pcszErrorStringIn
|
||
|
) throw()
|
||
|
: BaseClass( hrErrorCodeIn, pcszFileNameIn, uiLineNumberIn, pcszErrorStringIn )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
}; //*** class CConfigError
|