Revert last code drop.
// Copyright (c) 1999-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of "Eclipse Public License v1.0"
// which accompanies this distribution, and is available
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
//
#ifndef __MSVSENDERRORACTION_H__
#define __MSVSENDERRORACTION_H__
//
//
// Includes
//
//
#include <schsend.hrh>
#include <barsread.h>
#include <msvstore.h>
//
//
// Constants
//
//
//
//
// TMsvSendErrorAction Declaration
//
//
/**
Encapsulates the action to take for a particular error.
An error may occur when the Server MTM is attempting to send a message or
messages. If the Server MTM supports scheduling, then, depending on the error
or conditions, the Server MTM may want to re-schedule the message on the Task
Scheduler to send at a later time. CMsvScheduleSend::ReScheduleL()
(in combination with CMsvSendErrorActions) uses the TMsvSendErrorAction
to determine whether to re-schedule the message.
@publishedAll
@released
*/
class TMsvSendErrorAction
{
public:
IMPORT_C TMsvSendErrorAction();
IMPORT_C void Reset();
IMPORT_C void SetMaxRetries(const TInt16 aMaxRetries);
IMPORT_C TInt16 MaxRetries() const;
/** The error. */
TInt iError;
/** The action to take if this error occurs. */
TMsvSendAction iAction;
/** The number of attempts to make at sending a message if this error occurs.
If iRetries equals ESendRetriesInfinite, then sending will be attempted until
successful (or the user intervenes). This member is ignored if iAction equals
ESendActionFail. */
TMsvSendRetries iRetries;
/** Retry behaviour.
This member is used by CMsvSendErrorActions to determine when to resend the
message. This member is ignored if iAction equals ESendActionFail. */
TMsvSendRetrySpacing iRetrySpacing;
private:
TInt16 iMaxRetries;
};
//
//
// CMsvSendErrorActions
//
//
/**
This class determines what action to take if an error occurs while the Server
MTM is sending a message (or messages).
It encapsulates an array of TMsvSendErrorAction objects, which it uses to
determine the action to take for a particular error. If the error is not
found in the array, then CMsvSendErrorActions uses its default
TMsvSendErrorAction object.
@publishedAll
@released
*/
class CMsvSendErrorActions : public CBase
{
public:
IMPORT_C static CMsvSendErrorActions* NewL();
IMPORT_C static CMsvSendErrorActions* NewLC();
IMPORT_C ~CMsvSendErrorActions();
IMPORT_C void AddSendErrorActionL(const TMsvSendErrorAction& aErrorAction);
IMPORT_C TInt RemoveSendErrorAction(const TInt aError);
IMPORT_C TInt GetSendErrorAction(const TInt aError, TMsvSendErrorAction& aErrorAction) const;
IMPORT_C void Reset();
IMPORT_C void RestoreFromResourceL(TResourceReader& aReader);
IMPORT_C void SetErrorsL(const CArrayFixFlat<TMsvSendErrorAction>& aErrors);
IMPORT_C const CArrayFixFlat<TMsvSendErrorAction>& Errors() const;
IMPORT_C const TMsvSendErrorAction& Default() const;
IMPORT_C void SetDefault(const TMsvSendErrorAction& aAction);
private:
CMsvSendErrorActions();
void ConstructL();
void RestoreErrorActionL(TResourceReader& aReader, TInt aActionCount, const TBool aDefault);
TInt Find(const TInt aError, TInt& aIndex) const;
CArrayFixFlat<TMsvSendErrorAction>* iErrors;
TMsvSendErrorAction iDefault;
};
#endif // __MSVSENDERRORACTION_H__