--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/email/mail/PluginSrc/MailPlainView/CLoadAttachments.cpp	Wed Sep 01 12:31:54 2010 +0100
@@ -0,0 +1,137 @@
+/*
+* Copyright (c) 2002-2004 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:  Loads message attachments 
+*
+*/
+
+
+
+// INCLUDE FILES
+#include "CLoadAttachments.h"
+#include "MailLog.h"
+#include "MailUtils.h"
+#include "MailLoadStateMachine.h"
+#include <MailPlainView.rsg>
+#include <MMailAppUiInterface.h>
+#include <CMailMessage.h>
+#include <mmsvattachmentmanager.h>
+#include <StringLoader.h>
+
+// ============================ MEMBER FUNCTIONS ===============================
+
+/// messages
+// -----------------------------------------------------------------------------
+// CLoadAttachments::MessageLoadingL
+// -----------------------------------------------------------------------------
+//	
+void CLoadAttachments::MessageLoadingL(TInt aStatus, CMailMessage& aMessage)
+	{
+	if( aStatus == CMailMessage::EAttachmentsReady ) 
+		{
+		//Tell that loading of attachments has started
+		iAppUI->StartWaitNoteL();
+
+	    MMsvAttachmentManager& manager = aMessage.AttachmentManager();		
+        TRAPD( err, AddAttachmentsToAppUiL( manager ) );
+        LOG1("CLoadAttachments::MessageLoadingL AddAttachmentsToAppUiL: err=%d", err );
+        
+		//Tell that loading of attachments has ended
+		iAppUI->StopWaitNote();
+		
+		// Complete observer regardless of result
+		TRequestStatus* observer = iLoadStatus;
+		User::RequestComplete( observer, err );
+		
+		// Then leave this method if error occurred
+		User::LeaveIfError( err );
+		}
+	}
+
+// -----------------------------------------------------------------------------
+// CLoadAttachments::CLoadAttachments
+// -----------------------------------------------------------------------------
+//	
+CLoadAttachments::CLoadAttachments( MMailAppUiInterface* aAppUI )
+	{
+	iAppUI = aAppUI;
+	}
+
+// -----------------------------------------------------------------------------
+// CLoadAttachments::~CLoadAttachments
+// -----------------------------------------------------------------------------
+//	
+CLoadAttachments::~CLoadAttachments()
+	{
+	
+	}
+
+// -----------------------------------------------------------------------------
+// CLoadAttachments::NextStateL
+// -----------------------------------------------------------------------------
+//	
+MLoadState* CLoadAttachments::NextStateL()
+	{
+	return NULL;
+	}
+
+// -----------------------------------------------------------------------------
+// CLoadAttachments::MakeRequestL
+// -----------------------------------------------------------------------------
+//		
+void CLoadAttachments::MakeRequestL( 
+	TRequestStatus& aStatus,
+	CMailMessage& aMessage )
+	{
+	iLoadStatus = &aStatus;
+	aMessage.LoadAttachmentsL( *this );
+	aStatus = KRequestPending;
+	}
+
+// -----------------------------------------------------------------------------
+// CLoadAttachments::AddAttachmentsToAppUiL
+// -----------------------------------------------------------------------------
+//		
+void CLoadAttachments::AddAttachmentsToAppUiL( MMsvAttachmentManager& aManager )
+    {
+	LOG1("CLoadAttachments::AddAttachmentsToAppUiL attachmentCount:%d", 
+	     aManager.AttachmentCount());
+
+	//It is possible that aManager.AttachmentCount() changes while we are in 
+	//this loop. That is why latest count is checked every round.
+	for ( TInt index(0); index < aManager.AttachmentCount(); ++index ) 
+		{ 
+		LOG1("CLoadAttachments::AddAttachmentsToAppUiL iteration: %d", index);
+		CMsvAttachment* info = aManager.GetAttachmentInfoL( index );
+		CleanupStack::PushL( info );
+#ifdef MAIL_ENABLE_LOGGING
+        LOG("CLoadAttachments::AddAttachmentsToAppUiL Attachment info:");
+		LOG1("CLoadAttachments::AddAttachmentsToAppUiL ID  : 0x%x", info->Id() );
+        TPtrC name( info->AttachmentName() );
+		LOG1("CLoadAttachments::AddAttachmentsToAppUiL Name: '%S'", &name );
+        TPtrC path( info->FilePath() );
+        LOG1("CLoadAttachments::AddAttachmentsToAppUiL Path: '%S'", &path );
+        HBufC* mime = HBufC::NewLC( info->MimeType().Length() );
+        mime->Des().Copy( info->MimeType() );
+        LOG1("CLoadAttachments::AddAttachmentsToAppUiL Mime: '%S'", mime );
+        CleanupStack::PopAndDestroy( mime );
+#endif
+		LOG("CLoadAttachments::AddAttachmentsToAppUiL adding atta");
+		iAppUI->AddAttachmentL( *info, ETrue );
+		LOG("CLoadAttachments::AddAttachmentsToAppUiL atta added");
+		
+		CleanupStack::PopAndDestroy( info );
+		}    
+    }
+
+//  End of File