engine/collectionframework/datasource/plugins/glxdatasourcemde2.5/src/glxdatasourcetaskmdsthumbnail.cpp
branchRCL_3
changeset 59 8e5f6eea9c9f
equal deleted inserted replaced
57:ea65f74e6de4 59:8e5f6eea9c9f
       
     1 /*
       
     2 * Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:   
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 
       
    20 #include "glxdatasourcetaskmdsthumbnail.h"
       
    21 
       
    22 #include <caf/content.h>
       
    23 #include <glxcollectionplugincamera.hrh>
       
    24 #include <glxcollectionplugindownloads.hrh>
       
    25 #include <glxcollectionpluginmonths.hrh>
       
    26 #include <glxcollectionpluginalbums.hrh>
       
    27 #include <glxcollectionpluginall.hrh>
       
    28 #include <glxcollectionplugintags.hrh>
       
    29 #include <glxerrors.h>
       
    30 #include <glxfilterfactory.h>
       
    31 #include <glxgetrequest.h>
       
    32 #include <glxidlistrequest.h>
       
    33 #include <glxlog.h>
       
    34 #include <glxmediacollectioninternaldefs.h>
       
    35 #include <glxmediageneraldefs.h>
       
    36 #include <glxrequest.h>
       
    37 #include <glxthumbnailattributeinfo.h>
       
    38 #include <glxthumbnailrequest.h>
       
    39 #include <glxtndatabase.h>
       
    40 #include <glxtnfileinfo.h>
       
    41 #include <glxtnthumbnailcreator.h>
       
    42 #include <glxtracer.h>
       
    43 #include <lbsposition.h>
       
    44 #include <mdeconstants.h>
       
    45 #include <mdelogiccondition.h>
       
    46 #include <mdeobject.h>
       
    47 #include <mdeobjectdef.h>
       
    48 #include <mdeobjectquery.h>
       
    49 #include <mdepropertydef.h>
       
    50 #include <mderelationdef.h>
       
    51 #include <mdesession.h>
       
    52 #include <mdetextproperty.h>
       
    53 #include <mpxmedia.h>
       
    54 #include <mpxmediaarray.h> 
       
    55 #include <mpxmediacollectiondetaildefs.h>
       
    56 #include <mpxmediacontainerdefs.h>
       
    57 #include <mpxmediadrmdefs.h>
       
    58 #include <mpxmediageneraldefs.h>
       
    59 
       
    60 #include "glxdatasourcemds.h"
       
    61 #include "glxdatasourcemds.hrh"
       
    62 
       
    63 // CONSTANTS
       
    64 
       
    65 _LIT(KPropertyDefNameLastModifiedDate, "LastModifiedDate");
       
    66 _LIT(KPropertyDefNameDRM, "DRM");
       
    67 _LIT(KPropertyDefNameItemType, "ItemType");
       
    68 //_LIT(KPropertyDefNameLastModifiedDate, "LastModifiedDate");
       
    69 _LIT(KPropertyDefNameSize, "Size");
       
    70 _LIT(KUnsupportedItemType,  "video/x-pn-realvideo");
       
    71 _LIT(KUnsupportedItemType1, "video/x-pn-multirate-realvideo");
       
    72 _LIT(KUnsupportedItemType2, "video/vnd.rn-realvideo");
       
    73 _LIT(KUnsupportedItemType3, "video/x-ms-wmv");
       
    74 
       
    75 // ----------------------------------------------------------------------------
       
    76 //  IsUnsupportedL
       
    77 //  Tests to see if an item type is unsupported
       
    78 // ----------------------------------------------------------------------------
       
    79 //  
       
    80 TBool IsUnsupportedL(CMdESession& aSession, TItemId aItemId)
       
    81 	{
       
    82     TRACER("IsUnsupportedL()");
       
    83 	TBool isUnsupported = EFalse;
       
    84     CMdEObject* item = aSession.GetObjectL(aItemId);
       
    85     
       
    86     if (!item)
       
    87     	{
       
    88     	User::Leave(KErrNotFound);
       
    89     	}
       
    90     
       
    91     CleanupStack::PushL(item);
       
    92     CMdEProperty* itemType = NULL;
       
    93     
       
    94     CMdEPropertyDef& itemTypeProperty = item->Def().GetPropertyDefL(KPropertyDefNameItemType);
       
    95     
       
    96     TInt itemTypeIndex = item->Property(itemTypeProperty, itemType);
       
    97     if (itemTypeIndex > KErrNotFound)
       
    98     	{
       
    99     	const TDesC& des = static_cast< CMdETextProperty *>(itemType)->Value();
       
   100     	if (des.Compare(KUnsupportedItemType) == 0 || 
       
   101     	    des.Compare(KUnsupportedItemType1) == 0 || 
       
   102     	    des.Compare(KUnsupportedItemType2) == 0 ||
       
   103     	    des.Compare(KUnsupportedItemType3) == 0)
       
   104     		{
       
   105     		// The item is unsupported
       
   106     		isUnsupported = ETrue;
       
   107     		}
       
   108     	}
       
   109     CleanupStack::PopAndDestroy(item);
       
   110 
       
   111     return isUnsupported;
       
   112 	}
       
   113 // ----------------------------------------------------------------------------
       
   114 //  Constructor
       
   115 // ----------------------------------------------------------------------------
       
   116 // 	
       
   117 CGlxDataSourceTaskMdeThumbnail:: CGlxDataSourceTaskMdeThumbnail(CGlxThumbnailRequest* aRequest, 
       
   118 		                       MGlxDataSourceRequestObserver& aObserver, CGlxDataSource* aDataSource)
       
   119     : CGlxDataSourceTaskMde(aRequest, aObserver, aDataSource)
       
   120     {
       
   121     TRACER("CGlxDataSourceTaskMdeThumbnail::CGlxDataSourceTaskMdeThumbnail()")
       
   122     iFilterProperties = TGlxFilterFactory::ExtractAttributes(iRequest->Filter());
       
   123     }
       
   124 
       
   125 // ----------------------------------------------------------------------------
       
   126 //  Destructor
       
   127 // ----------------------------------------------------------------------------
       
   128 //  	
       
   129 CGlxDataSourceTaskMdeThumbnail::~CGlxDataSourceTaskMdeThumbnail()
       
   130     {
       
   131     TRACER("CGlxDataSourceTaskMdeThumbnail::~CGlxDataSourceTaskMdeThumbnail()")    
       
   132 #ifdef USE_S60_TNM
       
   133     DataSource()->CancelFetchThumbnail();
       
   134     delete iTnFileInfo;
       
   135     iTnFileInfo = NULL;
       
   136 #else
       
   137     if( iTnRequestStatus )
       
   138         {
       
   139         CancelFetchUri(TGlxMediaId());
       
   140         }
       
   141     if( iTnRequestInProgress )
       
   142         {
       
   143         CGlxThumbnailRequest* request = static_cast<CGlxThumbnailRequest*>(iRequest);
       
   144     
       
   145         TGlxThumbnailRequest tnReq;
       
   146         request->ThumbnailRequest(tnReq);
       
   147         DataSource()->ThumbnailCreator().CancelRequest(tnReq.iId);
       
   148         }
       
   149 #endif        
       
   150     }
       
   151 
       
   152 // ----------------------------------------------------------------------------
       
   153 //  CGlxDataSourceTaskMdeThumbnail::ExecuteRequest
       
   154 // ----------------------------------------------------------------------------
       
   155 //          
       
   156 void CGlxDataSourceTaskMdeThumbnail::ExecuteRequestL()
       
   157     {
       
   158     TRACER("CGlxDataSourceTaskMdeThumbnail::ExecuteRequestL()") 
       
   159 #ifdef _DEBUG
       
   160     iStartTime.HomeTime(); 
       
   161 #endif
       
   162     CGlxThumbnailRequest* request = static_cast<CGlxThumbnailRequest*>(iRequest);
       
   163     
       
   164     TGlxThumbnailRequest tnReq;
       
   165     request->ThumbnailRequest(tnReq);
       
   166     GLX_DEBUG4("*** CGlxDataSourceTaskMdeThumbnail::ExecuteRequestL() Id=%d, TN Size w(%d) h(%d) ***", tnReq.iId.Value(),
       
   167     						tnReq.iSizeClass.iWidth, tnReq.iSizeClass.iHeight);
       
   168     GLX_DEBUG2("CGlxDataSourceTaskMdeThumbnail::ExecuteRequestL() iPriorityMode=%d", tnReq.iPriorityMode);
       
   169 	
       
   170 #ifdef USE_S60_TNM
       
   171 	if(request->ThumbnailInfo())
       
   172 		{
       
   173 		if (tnReq.iSizeClass.iWidth > 0 && tnReq.iSizeClass.iHeight > 0 )
       
   174 			{
       
   175 			DataSource()->FetchThumbnailL(iRequest, *this);
       
   176 			}
       
   177 		else
       
   178 			{
       
   179 			ThumbnailFetchComplete(KErrNone, ETrue);
       
   180 			}
       
   181 		}
       
   182 	else
       
   183 		{
       
   184 	   	FetchFileInfoL();
       
   185 		}
       
   186 #else
       
   187     iTnRequestInProgress = ETrue;
       
   188     DataSource()->ThumbnailCreator().FetchThumbnailL(tnReq, *this);
       
   189 #endif
       
   190     }
       
   191 
       
   192 // ----------------------------------------------------------------------------
       
   193 //  CGlxDataSourceTaskMdeThumbnail::HandleRequestComplete
       
   194 // ----------------------------------------------------------------------------
       
   195 //  
       
   196 void CGlxDataSourceTaskMdeThumbnail::HandleRequestComplete(TInt aError)
       
   197 	{
       
   198     TRACER("void CGlxDataSourceTaskMdeThumbnail::HandleRequestComplete()");
       
   199     CGlxThumbnailRequest* request = static_cast<CGlxThumbnailRequest*>(iRequest);
       
   200     if(request && !(aError == KErrNone || aError == KErrNoMemory))
       
   201     	{
       
   202     	// An error has occured.
       
   203     	TBool isUnsupported = EFalse;
       
   204     	// If the item type is unsupported the we want to display the default
       
   205     	// icon rather than the corrupt icon.
       
   206     	TRAPD(err, isUnsupported = IsUnsupportedL(DataSource()->Session(), 
       
   207     			                          TItemId(request->ItemId().Value())));
       
   208     	if (isUnsupported)
       
   209     		{
       
   210     		aError = KErrNotSupported;
       
   211     		}
       
   212     	else if (err != KErrNone)
       
   213     		{
       
   214     		aError = err;
       
   215     		}
       
   216     	}
       
   217 	CGlxDataSourceTask::HandleRequestComplete(aError);
       
   218 	}
       
   219 
       
   220 // ----------------------------------------------------------------------------
       
   221 // CGlxDataSourceTaskMdeThumbnail::DoHandleQueryCompletedL
       
   222 // ----------------------------------------------------------------------------
       
   223 //
       
   224 void CGlxDataSourceTaskMdeThumbnail::DoHandleQueryCompletedL(CMdEQuery& /*aQuery*/)
       
   225     {
       
   226     TRACER("CGlxDataSourceTaskMdeThumbnail::DoHandleQueryCompletedL()")
       
   227     if (EContainerFirstItemQuery == iQueryTypes[0])
       
   228         {
       
   229         TRAPD(err, DoHandleContainerFirstItemQueryCompletedL());
       
   230         
       
   231         if (err != KErrNone)
       
   232             {
       
   233             CompleteThumbnailRequest(err);
       
   234             }
       
   235         }
       
   236     }
       
   237 
       
   238 // ----------------------------------------------------------------------------
       
   239 //  CGlxDataSourceTaskMdeThumbnail::HandleThumbnailFetchCompleteL
       
   240 // ----------------------------------------------------------------------------
       
   241 //   
       
   242 void CGlxDataSourceTaskMdeThumbnail::HandleThumbnailFetchCompleteL(const TGlxMediaId& aId,
       
   243         TGlxThumbnailQuality aQuality)
       
   244     {
       
   245     TRACER("CGlxDataSourceTaskMdeThumbnail::HandleThumbnailFetchCompleteL()")
       
   246     __ASSERT_DEBUG(dynamic_cast<CGlxThumbnailRequest*>(iRequest), Panic(EGlxPanicLogicError));
       
   247     CGlxThumbnailRequest* req = static_cast<CGlxThumbnailRequest*>(iRequest);
       
   248     GLX_DEBUG2("*** CGlxDataSourceTaskMdeThumbnail::HandleThumbnailFetchCompleteL() Id=%d ***", req->ItemId().Value());
       
   249 #ifdef _DEBUG
       
   250     iStopTime.HomeTime(); 
       
   251     GLX_DEBUG2("CGlxDataSourceTaskMdeThumbnail:HandleThumbnailFetchCompleteL() took %d us",
       
   252                      (TInt)iStopTime.MicroSecondsFrom(iStartTime).Int64());
       
   253 #endif    
       
   254     delete iResponse;
       
   255     iResponse = NULL;
       
   256     iResponse = CMPXMedia::NewL();
       
   257     CGlxThumbnailAttribute* tnAttribute = new (ELeave) CGlxThumbnailAttribute;
       
   258     CleanupStack::PushL(tnAttribute);
       
   259     TGlxThumbnailRequest tnRequest;
       
   260     req->ThumbnailRequest(tnRequest); 
       
   261     TSize size(tnRequest.iSizeClass);
       
   262     tnAttribute->iDimensions = size;
       
   263     tnAttribute->iCroppingRect = tnRequest.iCroppingRect;
       
   264     tnAttribute->iThumbnailQuality = aQuality;
       
   265     GLX_DEBUG2("CGlxDataSourceTaskMdeThumbnail::HandleThumbnailFetchCompleteL() aQuality=%d", aQuality);
       
   266 
       
   267     TUint attributeId = req->AttributeId();
       
   268     if ( GlxIsFullThumbnailAttribute(attributeId) )
       
   269         {
       
   270         TBool quality = (EGlxThumbnailQualityHigh == aQuality);
       
   271         attributeId = GlxFullThumbnailAttributeId(quality,
       
   272                                                 size.iWidth, size.iHeight);
       
   273         }
       
   274 
       
   275     iResponse->SetTObjectValueL<TMPXItemId>(KMPXMediaGeneralId, aId.Value());
       
   276     iResponse->SetNoNewLCObjectL(
       
   277                 TMPXAttribute(KGlxMediaIdThumbnail, attributeId), tnAttribute);
       
   278     CleanupStack::PopAndDestroy(tnAttribute);
       
   279     }
       
   280 
       
   281 #ifdef USE_S60_TNM
       
   282 void CGlxDataSourceTaskMdeThumbnail::ThumbnailFetchComplete(TInt aError, 
       
   283                                                             TBool aQuality)
       
   284 	{
       
   285     TRACER("CGlxDataSourceTaskMdeThumbnail::ThumbnailFetchComplete(TNM)")
       
   286     CGlxThumbnailRequest* request = static_cast<CGlxThumbnailRequest*>(iRequest);
       
   287     TGlxThumbnailRequest tnRequest;
       
   288     request->ThumbnailRequest(tnRequest); 
       
   289     TInt err = aError;
       
   290     if(!err)
       
   291         {
       
   292         TGlxThumbnailQuality tnQuality = EGlxThumbnailQualityHigh;
       
   293         if (!aQuality)
       
   294             {
       
   295             tnQuality = EGlxThumbnailQualityLow;
       
   296             }
       
   297         TRAP(err, HandleThumbnailFetchCompleteL(tnRequest.iId, tnQuality));
       
   298         }
       
   299     HandleRequestComplete(err);
       
   300 	}
       
   301 #else
       
   302 // -----------------------------------------------------------------------------
       
   303 // ThumbnailFetchComplete
       
   304 // Notifies that a thumbnail for a given item is available, or that
       
   305 // thumbnail generation failed.
       
   306 // -----------------------------------------------------------------------------
       
   307 //
       
   308 void CGlxDataSourceTaskMdeThumbnail::ThumbnailFetchComplete(
       
   309     const TGlxMediaId& aItemId, TGlxThumbnailQuality aQuality, TInt aErrorCode)
       
   310     {
       
   311     TRACER("CGlxDataSourceTaskMdeThumbnail::ThumbnailFetchComplete()")
       
   312     GLX_DEBUG2("CGlxDataSourceTaskMdeThumbnail::ThumbnailFetchComplete() aErrorCode=%d", aErrorCode);
       
   313     iTnRequestInProgress = EFalse;
       
   314     TInt err = aErrorCode;
       
   315     if(!err)
       
   316         {
       
   317         TRAP(err, HandleThumbnailFetchCompleteL(aItemId, aQuality));
       
   318         }
       
   319     HandleRequestComplete(err);
       
   320     }
       
   321 
       
   322 
       
   323 // ----------------------------------------------------------------------------
       
   324 //  CGlxDataSourceTaskMdeThumbnail::ThumbnailDeletionComplete
       
   325 // ----------------------------------------------------------------------------
       
   326 //   
       
   327 void CGlxDataSourceTaskMdeThumbnail::ThumbnailDeletionComplete(
       
   328                                 const TGlxMediaId& /*aItemId*/, TInt /*aErrorCode*/)
       
   329     {
       
   330     TRACER("CGlxDataSourceTaskMdeThumbnail::ThumbnailDeletionComplete()")
       
   331     }
       
   332 
       
   333 
       
   334 // ----------------------------------------------------------------------------
       
   335 //  CGlxDataSourceTaskMdeThumbnail::FilterAvailableComplete
       
   336 // ----------------------------------------------------------------------------
       
   337 //   
       
   338 void CGlxDataSourceTaskMdeThumbnail::FilterAvailableComplete(
       
   339                                 const RArray<TGlxMediaId>& /*aIdArray*/, TInt /*aErrorCode*/)
       
   340     {
       
   341     TRACER("CGlxDataSourceTaskMdeThumbnail::FilterAvailableComplete()")
       
   342     // No implementation
       
   343     }
       
   344 
       
   345 // ----------------------------------------------------------------------------
       
   346 //  CGlxDataSourceTaskMdeThumbnail::FetchFileInfoL
       
   347 // ----------------------------------------------------------------------------
       
   348 //  
       
   349 void CGlxDataSourceTaskMdeThumbnail::FetchFileInfoL(CGlxtnFileInfo* aInfo,
       
   350                         const TGlxMediaId& aItemId, TRequestStatus* aStatus)
       
   351     {
       
   352     TRACER("CGlxDataSourceTaskMdeThumbnail::FetchFileInfoL()")
       
   353     __ASSERT_DEBUG(dynamic_cast<CGlxThumbnailRequest*>(iRequest), Panic(EGlxPanicLogicError));
       
   354     CGlxThumbnailRequest* request = static_cast<CGlxThumbnailRequest*>(iRequest);
       
   355     if(request->ThumbnailInfo())
       
   356         {
       
   357         aInfo->CopyInfoL(*request->ThumbnailInfo());
       
   358         *aStatus = KRequestPending;
       
   359         User::RequestComplete(aStatus, KErrNone);
       
   360         return;
       
   361         }
       
   362 
       
   363     CMdEObject* item = DataSource()->Session().GetObjectL((TItemId)aItemId.Value());
       
   364     if(!item)
       
   365         {
       
   366         User::Leave(KErrNotFound);
       
   367         }
       
   368         
       
   369     CleanupStack::PushL(item);
       
   370     iTnRequestStatus = aStatus;
       
   371     iTnFileInfo = aInfo;
       
   372     *iTnRequestStatus = KRequestPending;
       
   373     
       
   374     CGlxDataSource::TContainerType containerType = DataSource()->ContainerType(item);
       
   375     if( CGlxDataSource::EContainerTypeNotAContainer != containerType )
       
   376         {
       
   377         iTnFileInfo->iTemporary = ETrue;
       
   378         
       
   379         TGlxMediaId container = aItemId;
       
   380         CMdEObjectDef* objectDef = &item->Def();
       
   381         
       
   382         /// @todo: use default filter so we can ensure we always get correct first item if filters change
       
   383         iFilterProperties.iSortOrder = EGlxFilterSortOrderCaptureDate;
       
   384         iFilterProperties.iSortDirection = EGlxFilterSortDirectionOverrideToDescendingIfDate;
       
   385         iFilterProperties.iLastCaptureDate = ETrue;
       
   386 
       
   387         if( CGlxDataSource::EContainerTypeMonth == containerType )
       
   388             {
       
   389             iFilterProperties.iOrigin = EGlxFilterOriginAll;
       
   390             AddMonthFilterL(item, iFilterProperties);
       
   391             container = TGlxMediaId(KGlxCollectionRootId);
       
   392             objectDef = &DataSource()->ObjectDef();
       
   393             }
       
   394             
       
   395         DoQueryL(*objectDef, ETrue, EContainerFirstItemQuery,  
       
   396                 EQueryResultModeItem, container);        
       
   397         }
       
   398     else
       
   399         {
       
   400         CompleteFetchFileInfoL(item);
       
   401         }
       
   402 
       
   403     CleanupStack::PopAndDestroy(item);
       
   404     }
       
   405 
       
   406 // ----------------------------------------------------------------------------
       
   407 //  CGlxDataSourceTaskMdeThumbnail::CancelFetchUri
       
   408 // ----------------------------------------------------------------------------
       
   409 //  
       
   410 void CGlxDataSourceTaskMdeThumbnail::CancelFetchUri(const TGlxMediaId& /*aItemId*/)
       
   411     {
       
   412     TRACER("CGlxDataSourceTaskMdeThumbnail::CancelFetchUri()")
       
   413     CompleteThumbnailRequest(KErrCancel);
       
   414     }
       
   415 
       
   416 // ----------------------------------------------------------------------------
       
   417 //  CGlxDataSourceTaskMdeThumbnail::ThumbnailStorage
       
   418 // ----------------------------------------------------------------------------
       
   419 //  
       
   420 MGlxtnThumbnailStorage* CGlxDataSourceTaskMdeThumbnail::ThumbnailStorage()
       
   421     {
       
   422     TRACER("CGlxDataSourceTaskMdeThumbnail::ThumbnailStorage()")
       
   423     return &DataSource()->ThumbnailDatabase();
       
   424     }
       
   425 #endif
       
   426 
       
   427 // ----------------------------------------------------------------------------
       
   428 //  CGlxDataSourceTaskMdeThumbnail::CompleteFetchFileInfoL
       
   429 // ----------------------------------------------------------------------------
       
   430 //  	    
       
   431 void CGlxDataSourceTaskMdeThumbnail::CompleteFetchFileInfoL(CMdEObject* aItem)
       
   432     {
       
   433     TRACER("CGlxDataSourceTaskMdeThumbnail::CompleteFetchFileInfoL()")
       
   434     TParsePtrC parser(aItem->Uri());
       
   435     iTnFileInfo->SetFilePathL(parser.FullName());
       
   436 
       
   437     CMdEProperty* size;
       
   438     CMdEPropertyDef& sizeProperty = aItem->Def().GetPropertyDefL(KPropertyDefNameSize);
       
   439     TInt sizeIndex = aItem->Property(sizeProperty, size); 
       
   440     if( KErrNotFound == sizeIndex )
       
   441         {
       
   442         iTnFileInfo->iFileSize = 0;
       
   443         }
       
   444     else
       
   445         {
       
   446         iTnFileInfo->iFileSize = size->Uint32ValueL();
       
   447         }
       
   448 
       
   449     CMdEProperty* lastModifiedDateProperty;
       
   450     CMdEPropertyDef& lastModifiedDatePropertyDef = aItem->Def().GetPropertyDefL(
       
   451             KPropertyDefNameLastModifiedDate);
       
   452 
       
   453 #ifdef _DEBUG
       
   454     TInt index = // This variable is only required for the assert debug below. If it is not wrapped in an  
       
   455                  // #ifdef _DEBUG, it will cause a warning in non debug builds.
       
   456 #endif    
       
   457     aItem->Property(lastModifiedDatePropertyDef, lastModifiedDateProperty);
       
   458     __ASSERT_DEBUG(index > KErrNotFound, Panic(EGlxPanicRequiredPropertyNotFound));
       
   459     
       
   460     iTnFileInfo->iFileTime = static_cast<CMdETimeProperty*>(lastModifiedDateProperty)->Value();
       
   461     
       
   462     CGlxDataSource::TItemType itemType = DataSource()->ItemType(aItem);
       
   463     iTnFileInfo->iIsVideo = ( CGlxDataSource::EItemTypeVideo == itemType );
       
   464     
       
   465     CMdEProperty* drmProtected;
       
   466     CMdEPropertyDef* drmProtectedProperty = NULL;
       
   467     
       
   468     ///@todo AB test
       
   469     TRAP_IGNORE(drmProtectedProperty = &aItem->Def().GetPropertyDefL(KPropertyDefNameDRM)); 
       
   470     TInt drmProtectedIndex = KErrNotFound;
       
   471     
       
   472     if (drmProtectedProperty)
       
   473     	{
       
   474     	drmProtectedIndex= aItem->Property(*drmProtectedProperty, drmProtected);
       
   475     	}
       
   476     
       
   477     TInt err = KErrNone;
       
   478     if( KErrNotFound == drmProtectedIndex)
       
   479         {
       
   480         // should be present for all normally harvested images
       
   481         // so this should only be where we didn't pre-fetch the attributes
       
   482         // i.e. background thumbnail generation
       
   483         // so we get status from CAF to avoid forcing second stage harvest
       
   484         TRAP(err, 
       
   485             ContentAccess::CContent* content = ContentAccess::CContent::NewLC(
       
   486                     iTnFileInfo->FilePath());
       
   487             content->GetAttribute(ContentAccess::EIsProtected, iTnFileInfo->iIsProtected);
       
   488             CleanupStack::PopAndDestroy(content);
       
   489             );
       
   490         }
       
   491     else
       
   492         {
       
   493         iTnFileInfo->iIsProtected =  static_cast<CMdEBoolProperty*>(drmProtected)->Value();
       
   494         }
       
   495 
       
   496     CompleteThumbnailRequest(err);
       
   497     iTnFileInfo = NULL;
       
   498     iTnRequestStatus = NULL;
       
   499     }
       
   500 
       
   501 // ----------------------------------------------------------------------------
       
   502 // CGlxDataSourceTaskMdeThumbnail::DoHandleContainerFirstItemQueryCompletedL
       
   503 // ----------------------------------------------------------------------------
       
   504 //
       
   505 void CGlxDataSourceTaskMdeThumbnail::DoHandleContainerFirstItemQueryCompletedL()
       
   506     {
       
   507     TRACER("CGlxDataSourceTaskMdeThumbnail::DoHandleContainerFirstItemQueryCompletedL()")
       
   508     if( !iQueries[0]->Count() )
       
   509         {
       
   510         User::Leave(KErrGlxEmptyContainer); // leave with a specific Error code so UI can display empty folder icon
       
   511         }
       
   512     
       
   513     CMdEObject* item = static_cast<CMdEObject*>(iQueries[0]->TakeOwnershipOfResult(0));
       
   514     if(!item)
       
   515         {
       
   516         User::Leave(KErrNotFound);
       
   517         }
       
   518     
       
   519     CleanupStack::PushL(item);
       
   520     CompleteFetchFileInfoL(item);
       
   521     CleanupStack::PopAndDestroy(item);
       
   522     }
       
   523 
       
   524 // ----------------------------------------------------------------------------
       
   525 // CGlxDataSourceTaskMdeThumbnail::CompleteThumbnailRequest
       
   526 // ----------------------------------------------------------------------------
       
   527 //
       
   528 void CGlxDataSourceTaskMdeThumbnail::CompleteThumbnailRequest(TInt aError)
       
   529 	{
       
   530     TRACER("CGlxDataSourceTaskMdeThumbnail::CompleteThumbnailRequest(TInt aError)")
       
   531     GLX_DEBUG2("CGlxDataSourceTaskMdeThumbnail::CompleteThumbnailRequest  aError=%d", aError);
       
   532 #ifdef USE_S60_TNM
       
   533 	if (aError != KErrNone)
       
   534 		{
       
   535 		ThumbnailFetchComplete(aError, EFalse);
       
   536 		}
       
   537 	else
       
   538 		{
       
   539 	    CGlxThumbnailRequest* request = static_cast<CGlxThumbnailRequest*>(iRequest);
       
   540         TGlxThumbnailRequest tnReq;
       
   541 	   	request->ThumbnailRequest(tnReq);
       
   542 
       
   543 		if (tnReq.iSizeClass.iWidth > 0 && tnReq.iSizeClass.iHeight > 0 )
       
   544 			{
       
   545 		    request->SetThumbnailInfo(iTnFileInfo);
       
   546 		    //This function is called number of times as a callback ,
       
   547             //hence not trapping the leaving function which costs time and memory.
       
   548             //Ignoring this for code scanner warnings - Leaving functions called in non-leaving functions.
       
   549 			DataSource()->FetchThumbnailL(iRequest, *this);
       
   550 			}
       
   551 		else
       
   552 			{
       
   553 		    GLX_LOG_INFO("CGlxDataSourceTaskMdeThumbnail::CompleteThumbnailRequest KErrArgument");
       
   554 			ThumbnailFetchComplete(KErrArgument, EFalse);
       
   555 			}
       
   556 			}
       
   557 #else
       
   558     if (iTnRequestStatus)
       
   559         {
       
   560     	*iTnRequestStatus = KRequestPending;
       
   561         User::RequestComplete(iTnRequestStatus, aError);
       
   562         }
       
   563 #endif
       
   564 	}
       
   565 
       
   566 #ifdef USE_S60_TNM
       
   567 // ----------------------------------------------------------------------------
       
   568 //  CGlxDataSourceTaskMdeThumbnail::FetchFileInfoL
       
   569 // ----------------------------------------------------------------------------
       
   570 //  
       
   571 void CGlxDataSourceTaskMdeThumbnail::FetchFileInfoL()
       
   572     {
       
   573     TRACER("CGlxDataSourceTaskMdeThumbnail::FetchFileInfoL()")
       
   574     __ASSERT_DEBUG(dynamic_cast<CGlxThumbnailRequest*>(iRequest), Panic(EGlxPanicLogicError));
       
   575     CGlxThumbnailRequest* request = static_cast<CGlxThumbnailRequest*>(iRequest);
       
   576     CMdEObject* item = DataSource()->Session().GetObjectL(request->ItemId().Value());
       
   577     if(!item)
       
   578         {
       
   579         User::Leave(KErrNotFound);
       
   580         }
       
   581         
       
   582     CleanupStack::PushL(item);
       
   583     iTnFileInfo = new (ELeave) CGlxtnFileInfo;
       
   584     
       
   585     CGlxDataSource::TContainerType containerType = DataSource()->ContainerType(item);
       
   586     if( CGlxDataSource::EContainerTypeNotAContainer != containerType )
       
   587         {
       
   588         iTnFileInfo->iTemporary = ETrue;
       
   589         
       
   590         TGlxMediaId container = request->ItemId();
       
   591         CMdEObjectDef* objectDef = &item->Def();
       
   592         
       
   593         /// @todo: use default filter so we can ensure we always get correct first item if filters change
       
   594         iFilterProperties.iSortOrder = EGlxFilterSortOrderCaptureDate;
       
   595         iFilterProperties.iSortDirection = EGlxFilterSortDirectionOverrideToDescendingIfDate;
       
   596         iFilterProperties.iLastCaptureDate = ETrue;
       
   597         // for 10.1 we need first image thumbnail which is not DRM
       
   598         iFilterProperties.iNoDRM = ETrue;
       
   599         iFilterProperties.iItemType = EGlxFilterImage;
       
   600 
       
   601         if( CGlxDataSource::EContainerTypeMonth == containerType )
       
   602             {
       
   603             iFilterProperties.iOrigin = EGlxFilterOriginAll;
       
   604             AddMonthFilterL(item, iFilterProperties);
       
   605             container = TGlxMediaId(KGlxCollectionRootId);
       
   606             objectDef = &DataSource()->ObjectDef();
       
   607             }
       
   608             
       
   609         DoQueryL(*objectDef, ETrue, EContainerFirstItemQuery, 
       
   610                 EQueryResultModeItem, container);        
       
   611         }
       
   612     else
       
   613         {
       
   614         CompleteFetchFileInfoL(item);
       
   615         }
       
   616 
       
   617     CleanupStack::PopAndDestroy(item);
       
   618     }
       
   619 
       
   620 #endif