diff -r 000000000000 -r 72b543305e3a email/imap4mtm/imapsession/src/cimapclose.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/email/imap4mtm/imapsession/src/cimapclose.cpp Thu Dec 17 08:44:11 2009 +0200 @@ -0,0 +1,64 @@ +// Copyright (c) 2006-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: +// + +#include "cimapclose.h" +#include "moutputstream.h" +#include "cimapsessionconsts.h" +#include "imappaniccodes.h" + +// IMAP Close command +_LIT8(KCommandClose, "%d CLOSE\r\n"); + +CImapClose* CImapClose::NewL(CImapFolderInfo* aSelectedFolderData, TInt aLogId) +// static method first phase construction + { + CImapClose* self = new (ELeave) CImapClose(aSelectedFolderData, aLogId); + CleanupStack::PushL(self); + self->ConstructL(); + CleanupStack::Pop(); + return self; + } + +CImapClose::CImapClose(CImapFolderInfo* aSelectedFolderData, TInt aLogId) + : CImapCommandEx(aSelectedFolderData, aLogId) + { + } + +void CImapClose::ConstructL() + { + } + +CImapClose::~CImapClose() + { + } + +/** +Formats and sends the IMAP CLOSE command. +@param aTagId Command sequence id which will be sent along with the IMAP command. +@param aStream A wrapper for the outbound stream of a connected socket, using which +the command will be send to the server +*/ +void CImapClose::SendMessageL(TInt aTagId, MOutputStream& aStream) + { + iTagId = aTagId; + + __ASSERT_DEBUG(iOutputBuffer==NULL, TImapServerPanic::ImapPanic(TImapServerPanic::ECommandOutputBufferNotNull)); + iOutputBuffer = HBufC8::NewL(KCommandClose().Length() + TagLength(aTagId)); + iOutputBuffer->Des().Format(KCommandClose, aTagId); + + //send the command to the server + aStream.SendDataReq(*iOutputBuffer); + } +