--- a/mtpfws/mtpfw/src/cmtpdataprovidercontroller.cpp Tue Feb 02 01:11:40 2010 +0200
+++ b/mtpfws/mtpfw/src/cmtpdataprovidercontroller.cpp Fri Feb 19 23:40:44 2010 +0200
@@ -236,7 +236,7 @@
iEnumeratingStorages.AppendL(params->iStorageId);
// Only schedule the operation start if there is not one currently underway.
- if (iEnumerationState == EEnumerated)
+ if (iEnumerationState == EEnumeratedFulllyCompleted)
{
iNextDpId = iDpIdDeviceDp;
iEnumerationState = EEnumeratingFrameworkObjects;
@@ -385,7 +385,7 @@
*/
EXPORT_C void CMTPDataProviderController::WaitForEnumerationComplete()
{
- if(EnumerateState() != CMTPDataProviderController::EEnumerated)
+ if(EnumerateState() < CMTPDataProviderController::EEnumeratingPhaseOneDone)
{
iOpenSessionWaiter->Start();
}
@@ -406,6 +406,7 @@
void CMTPDataProviderController::EnumerationStateChangedL(const CMTPDataProvider& aDp)
{
__FLOG(_L8("EnumerationStateChangedL - Entry"));
+ __FLOG_VA((_L8("Entry iEnumerationState: 0x%x iNextDpId: %d"), iEnumerationState, iNextDpId));
switch (iEnumerationState)
{
case EEnumeratingFrameworkStorages:
@@ -463,27 +464,42 @@
break;
case KMTPImplementationUidFileDp:
- iSingletons.ObjectMgr().RemoveNonPersistentObjectsL(aDp.DataProviderId());
- // No other data providers
- iNextDpId = 0;
- iEnumeratingStorages.Remove(0);
- if (iEnumeratingStorages.Count() == 0)
- {
- // No queued enumerations.
- iSingletons.ObjectMgr().ObjectStore().CleanDBSnapshotL();
- iEnumerationState = EEnumerated;
- Cancel();
- if(iOpenSessionWaiter->IsStarted())
- {
- iOpenSessionWaiter->AsyncStop();
- }
- }
- else
- {
- // Queued enumerations.
- iNextDpId = iDpIdDeviceDp;
- Schedule();
- }
+ // No other data providers
+ if(NeedEnumeratingPhase2())
+ {
+ iEnumerationState = EEnumeratingSubDirFiles;
+ if(iOpenSessionWaiter->IsStarted())
+ {
+ iOpenSessionWaiter->AsyncStop();
+ }
+ //Schedule FildDP to enumerate the files in sub-dir
+ iNextDpId = iDpIdFileDp;
+ Schedule();
+ }
+ else
+ {
+ iNextDpId = 0;
+ iEnumeratingStorages.Remove(0);
+ if (iEnumeratingStorages.Count() == 0)
+ {
+ iSingletons.ObjectMgr().RemoveNonPersistentObjectsL(aDp.DataProviderId());
+ iEnumerationState = EEnumeratedFulllyCompleted;
+ iSingletons.ObjectMgr().ObjectStore().CleanDBSnapshotL();
+
+ Cancel();
+ if(iOpenSessionWaiter->IsStarted())
+ {
+ iOpenSessionWaiter->AsyncStop();
+ }
+ }
+ else
+ {
+ // Queued enumerations.
+ iNextDpId = iDpIdDeviceDp;
+ Schedule();
+ }
+ }
+
}
break;
@@ -496,9 +512,23 @@
if ((iEnumeratingDps.Count() == 0) && iDpIdArrayIndex >= iDataProviderIds.Count())
{
// Enumeration complete.
- iNextDpId = 0;
iNextDpId = iDpIdFileDp;
iEnumerationState = EEnumeratingFrameworkObjects;
+
+ if ( ( iEnumeratingStorages.Count() > 1 ) &&(KErrNotFound != iEnumeratingStorages.Find(KMTPStorageAll)) )
+ {
+ const TUint storageid = iEnumeratingStorages[0];
+ iEnumeratingStorages.Remove(0);
+ if(KMTPStorageAll == storageid)
+ {
+ iEnumeratingStorages.Append(KMTPStorageAll);
+ }
+
+ if(iEnumeratingStorages[0] != KMTPStorageAll)
+ {
+ iNextDpId = iDpIdDeviceDp;
+ }
+ }
}
else
{
@@ -511,13 +541,39 @@
Schedule();
break;
+ case EEnumeratingSubDirFiles:
+ {
+ if(aDp.ImplementationUid().iUid == KMTPImplementationUidFileDp)
+ {
+ iSingletons.ObjectMgr().RemoveNonPersistentObjectsL(aDp.DataProviderId());
+ iNextDpId = 0;
+ iEnumeratingStorages.Remove(0);
+ if(iEnumeratingStorages.Count() == 0)
+ {
+ iSingletons.DpController().SetNeedEnumeratingPhase2(EFalse);
+ iEnumerationState = EEnumeratedFulllyCompleted;
+ iSingletons.ObjectMgr().ObjectStore().CleanDBSnapshotL();
+ }
+ else //removable card plug in
+ {
+ iNextDpId = iDpIdDeviceDp;
+ iEnumerationState = EEnumeratingFrameworkObjects;
+ Schedule();
+ }
+ }
+ }
+ break;
+
+ case EEnumeratedFulllyCompleted:
case EUnenumerated:
case EEnumerationStarting:
- case EEnumerated:
+ case EEnumeratingPhaseOneDone:
default:
__DEBUG_ONLY(User::Invariant());
break;
}
+
+ __FLOG_VA((_L8("Exit iEnumerationState: 0x%x, iNextDpId: %d, UID=0x%x"), iEnumerationState, iNextDpId, aDp.ImplementationUid().iUid));
__FLOG(_L8("EnumerationStateChangedL - Exit"));
}
@@ -556,8 +612,6 @@
iNextDpId = iDpIdDeviceDp;
iEnumerationState = EEnumeratingFrameworkObjects;
-
-
Schedule();
}
break;
@@ -573,7 +627,7 @@
iEnumeratingStorages.Remove(0);
if (iEnumeratingStorages.Count() == 0)
{
- iEnumerationState = EEnumerated;
+ iEnumerationState = EEnumeratedFulllyCompleted;
}
else
{
@@ -591,21 +645,22 @@
{
iSingletons.ObjectMgr().ObjectStore().EstablishDBSnapshotL(storageId);
}
- else
+ else
{
- const CMTPStorageMetaData& storage(iSingletons.StorageMgr().StorageL(storageId));
- if(storage.Uint(CMTPStorageMetaData::EStorageSystemType) == CMTPStorageMetaData::ESystemTypeDefaultFileSystem)
- {
- const RArray<TUint>& logicalIds(storage.UintArray(CMTPStorageMetaData::EStorageLogicalIds));
- const TUint KCountLogicalIds(logicalIds.Count());
- for (TUint i(0); (i < KCountLogicalIds); i++)
- {
- __FLOG_VA((_L8("Establish snapshot for storage: 0x%x"), storageId));
- iSingletons.ObjectMgr().ObjectStore().EstablishDBSnapshotL(storageId);
- }
- }
+ const CMTPStorageMetaData& storage(iSingletons.StorageMgr().StorageL(storageId));
+ if(storage.Uint(CMTPStorageMetaData::EStorageSystemType) == CMTPStorageMetaData::ESystemTypeDefaultFileSystem)
+ {
+ const RArray<TUint>& logicalIds(storage.UintArray(CMTPStorageMetaData::EStorageLogicalIds));
+ const TUint KCountLogicalIds(logicalIds.Count());
+ for (TUint i(0); (i < KCountLogicalIds); i++)
+ {
+ __FLOG_VA((_L8("Establish snapshot for storage: 0x%x"), logicalIds[i]));
+ iSingletons.ObjectMgr().ObjectStore().EstablishDBSnapshotL(logicalIds[i]);
+ }
+ }
}
}
+
EnumerateDataProviderObjectsL(iNextDpId);
}
}
@@ -624,11 +679,19 @@
iEnumeratingDps.InsertInOrderL(currentDp);
EnumerateDataProviderObjectsL(currentDp);
}
+
+ __FLOG_VA((_L8("iDpIdArrayIndex = %d, KLoadedDps = %d"), iDpIdArrayIndex, KLoadedDps));
}
break;
+ case EEnumeratingSubDirFiles:
+ {
+ EnumerateDataProviderObjectsL(iNextDpId);
+ }
+ break;
+ case EEnumeratedFulllyCompleted:
case EUnenumerated:
- case EEnumerated:
+ case EEnumeratingPhaseOneDone:
default:
__DEBUG_ONLY(User::Invariant());
break;
@@ -666,7 +729,7 @@
break;
case EUnenumerated:
- case EEnumerated:
+ case EEnumeratingPhaseOneDone:
default:
User::Invariant();
break;
@@ -709,7 +772,7 @@
iMode = (TMTPOperationalMode)tMTPMode;
CreateRegistrySessionAndEntryL();
- iFlagDb = 0;
+ SetNeedEnumeratingPhase2(EFalse);
iOpenSessionWaiter = new(ELeave) CActiveSchedulerWait();
__FLOG(_L8("ConstructL - Exit"));
@@ -1148,3 +1211,18 @@
iSisSession.Close();
}
+EXPORT_C void CMTPDataProviderController::SetNeedEnumeratingPhase2(TBool aNeed)
+ {
+ __FLOG(_L8("SetNeedEnumeratingPhase2 - Entry"));
+ __FLOG_VA((_L8("Need = %d"), aNeed));
+
+ iNeedEnumeratingPhase2 = aNeed;
+
+ __FLOG(_L8("SetNeedEnumeratingPhase2 - Exit"));
+ }
+
+EXPORT_C TBool CMTPDataProviderController::NeedEnumeratingPhase2() const
+ {
+ return iNeedEnumeratingPhase2;
+ }
+