Update contrib.
1 // Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
2 // All rights reserved.
3 // This component and the accompanying materials are made available
4 // under the terms of "Eclipse Public License v1.0"
5 // which accompanies this distribution, and is available
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
14 // Definition of the CDiscoverer class
23 #ifndef __DISCOVERER_H__
24 #define __DISCOVERER_H__
28 #include <e32property.h> // for RProperty
29 #include <domaindefs.h> // for TDmDomainState
31 #include "DiscovererObserver.h" // The MDiscovererObserver class
32 #include "EComEntry.h"
33 #include "EComEntryBase.h"
36 // Platsec path to binaries
37 _LIT(KSysBin,"\\sys\\bin\\");
38 // Platsec path to resources
39 _LIT(KResourcePlugins,"\\resource\\plugins\\");
40 _LIT(KDllExtension,".dll");
42 _LIT(KRscExtension,".rsc");
44 // Length of extension of file name.
45 //The language extension length including the "." is assumed to be 4
46 const TInt KExtensionLength=4;
48 //Max lenth for plugin resource path
49 const TInt32 KEComPlugRSCPathMaxLen = 50;
51 //class forward declare
52 class CEnvironmentChangeNotifier;
56 Responsible for Interface Implementation Collections,
57 installed in the Interface Implementation Collection directories.
60 class CDiscoverer : public CBase
64 /** Transition flag for Notification*/
65 enum TNotificationFlag
67 /** A new plugin added or removed*/
70 /**should do a rediscovery */
74 /** State declaration for CDiscoverer */
78 /** Undefined state */
81 /** Initialize state */
84 /** Discover plugins on Ro Internal drive units */
85 EDisc_CriticalPluginsDisc,
87 /** All plugins are discovered.*/
90 /** Plugins added or removed, going to rediscover all plugins */
96 @fn NewL(MDiscovererObserver& aDiscovererObserver, RFs& aFs)
97 Intended Usage : Standardised safe construction which leaves nothing
99 Error Condition : Not enough memory available.
102 @param aDiscovererObserver A reference to the owning client
104 @param aFs A reference to a connected file server instance.
105 @return CDiscoverer* a pointer to the new class
107 @post CDiscoverer is fully constructed, and initialised.
110 static CDiscoverer* NewL(MDiscovererObserver& aDiscovererObserver, RFs& aFs);
114 Intended Usage : Standard default d'tor
115 Error Condition : None
117 @pre CDiscoverer is fully constructed.
118 @post CDiscoverer is totally destroyed.
125 Intended Usage : Re-enable the Discoverer to continue checking for new
126 interface implementations.
127 Error Condition : Where resume of the discoverer fails. KErrResumeFailed.
129 @return TInt The status of the operation. KErrNone or KErrResumeFailed.
130 @pre CDiscoverer is fully constructed.
131 @post The operation of the discoverer has been resumed. Or where
132 resumption failed, no change.
139 Intended Usage : Temporarily stop looking for new interface implementations.
140 Error Condition : Where suspension of the discoverer fails. KErrSuspendFailed.
142 @return TInt The status of the operation. KErrNone or KErrSuspendFailed.
143 @pre CDiscoverer is fully constructed.
144 @post The operation of the discoverer has been suspended. Or where
145 suspend failed, no change.
152 @fn ProcessSSAEventL()
153 Intended Usage : It discovers the plugins on different Drive Units according to
154 the passing state. It will be used by CRegistrar to notify the
155 object of the system start-up state changes.
156 @param aKnownState the start-up state passing in to CDiscoverer
157 @pre CDiscoverer is fully constructed
158 @post CDiscoverer is notified of the start-up state change
160 void ProcessSSAEventL(TStartupStateIdentifier aKnownState);
163 @fn ProcessDNEventL()
164 Intended Usage :It will be used by one iRscDirNotifier in iRscDirNotifierList
165 to indicate that plugins have been removed or added(state is
166 EDisc_PluginsDirty) and to start a
167 re-discovery(when done, state is EDisc_AllPluginsDisc).
169 @param :aFlag the notification transition flag.
170 @param :aDriveUnit a drive which on the plugins has been changed and need to re-discovery
171 @pre :CDiscoverer is fully constructed.
172 @post : state will be changed, and a re-discovery will happen
173 if the current state is EDisc_PluginsDirty.
175 void ProcessDNEventL(TNotificationFlag aFlag, const TDriveUnit& aDriveUnit);
179 Intended Usage :Retrieve the object's current state.
180 @return TDiscovererState the CDiscoverer's current state.
181 @pre CDiscoverer is fully constructed.
182 @post the CDiscoverer's current state has been returned.
184 TDiscovererState State() const;
186 /** Set the iSwiChangeCallBack member
187 @param aCallBack new value for iSwiChangeCallBack
189 void SetSwiChangeCallBack(const TCallBackWithArg& aCallBack);
191 /** Set the iBurChangeCallBack member
192 @param aCallBack new value for iBurChangeCallBack
194 void SetBurChangeCallBack(const TCallBackWithArg& aCallBack);
199 @fn CDiscoverer(MDiscovererObserver& aDiscovererObserver, RFs& aFs)
200 Intended Usage : Standardised default c'tor
201 Error Condition : None
203 @param aDiscovererObserver A reference to the owning client
205 @param aFs A reference to an connected file server instance.
207 @post CDiscoverer is fully constructed
210 CDiscoverer(MDiscovererObserver& aDiscovererObserver, RFs& aFs);
214 Intended Usage : Standardised 2nd, (Initialisation) phase of two phase construction.
215 Error Condition : Leaves with error code : usually KErrNoMemory.
219 @pre CDiscoverer is fully constructed.
220 @post CDiscoverer is fully initialised.
226 @fn NotificationL(TInt aStatus)
227 Intended Usage : Called by the one object of iRscDirNotifierList when the
228 contents of the Interface Implementation directories
229 has changed on a specified drive.
230 Error Condition : None
233 @param aDriveUnit a drive which has changes.
234 @return ETrue to indicate the notifier should re-activate.
235 @pre CDiscoverer is fully constructed.
236 @post CDiscoverer has been notified that a re-scan of the
237 plugin directories is required.
240 TBool NotificationL(TInt aStatus, const TDriveUnit& aDriveUnit);
243 @fn SwiChangeNotificationL(TInt aSwiOperation)
244 Intended Usage : Called by iSwiChangeNotifier when it is notified of a
246 Error Condition : None
248 @param aSwiOperation the SWI operation that is currently taking place
249 @pre CDiscoverer is fully constructed.
250 @post CDiscoverer has been notified that a re-scan of the
251 removable plugin directories is required and has stored current
255 void SwiChangeNotificationL(TInt aSwiOperation);
258 @fn LanguageChangeNotificationL()
259 Intended Usage : Called by iLanguageChangeNotifier when it is notified of language
260 downgrade path changed.
261 Error Condition : None
263 @pre CDiscoverer is fully constructed.
264 @post CDiscoverer has been notified that a rescan may be required
267 void LanguageChangeNotificationL();
269 // Methods used by the Incremental Directory Scanning mechanism
272 @fn void RediscoveryScanDirectoryL()
273 Intended Usage : Perform a scan on the Interface Implementation
274 Collection directories on a specified drive.
275 Error Condition : Not enough memory available
278 @param :A drive on which the directory is scanned.
280 @pre CDiscoverer is fully constructed.
281 @post The scan of the Interface Implementation Collection
282 directories has processed on a specified drive.
285 void RediscoveryScanDirectoryL(const TDriveUnit& aDriveUnit);
288 @fn void ScanDirectoryCancel()
289 Intended Usage : Cancel any scan of the Interface Implementation Collection
290 directories in progress.
291 Error Condition : None
294 @pre CDiscoverer is fully constructed.
295 @post The re-scan of the Interface Implementation
296 Collection directories has beed aborted.
299 void ScanDirectoryCancel();
302 @fn CompleteNotificationProcessing()
303 Intended Usage : Signal that the directory change notification has
304 been fully processed on all drives.
305 Error Condition : None
307 @pre CDiscoverer is fully constructed.
308 @post An asynchronous re-scan of the Interface Implementation
309 Collection directories is complete.
312 void CompleteNotificationProcessing();
315 @fn ValidateEntryL(const TEntry& aEntry, const TDriveName& aDriveName, CPluginBase*& aEntryToFill,TBool aIsRO)
316 Intended Usage : Verify that a Interface Implementation Collection directories entry is valid
318 Error Condition : No memory
321 @param aEntry A directory entry for an Interface Implementation Collection.
322 @param aDriveName The drive containing this entry
323 @param aEntryToFill A newly created directory entry with the
324 filename updated to include the full path.
325 @param aIsRO Indicates whether current drive is Read Only
326 @pre CDiscoverer is fully constructed,
327 aEntry, aPath and aEntryToFill are all valid references.
328 @post aEntryToFill is created and valid, with the full path and filename as its name entry.
331 void ValidateEntryL(const TEntry& aEntry, const TDriveName& aDriveName, CPluginBase*& aEntryToFill, TBool aIsRO);
334 @fn ValidateEntryL(RResourceArchive& aRscArchive,CPluginBase*& aEntryToFill);
335 Intended Usage : Verify that a Interface Implementation Collection directories entry is valid
337 Error Condition : No memory
340 @param aRscArchive A referernce to the resource archive
341 @param aEntryToFill A newly created directory entry with the
342 filename updated to include the full path.
343 @pre CDiscoverer is fully constructed,
344 @post aEntryToFill is created and valid, with the full path and filename as its name entry.
347 void ValidateEntryL(RResourceArchive& aRscArchive, CPluginBase*& aEntryToFill);
349 @fn ProcessEntryL(const TDriveName& aDrive,CPluginBase*& aEntry, TBool aAnyDllDiscovered)
350 Intended Usage : Verify that a Interface Implementation Collection directories entry is valid
352 Error Condition : Depends on the observer implementation.
353 @leave Depends on the observer implementation. (@see CRegistrar).
355 @param aDrive the drive name containing this entry
356 @param aEntry A directory entry for an Interface Implementation Collection.
357 @param aAnyDllDiscovered a flag to tell if any Dll is discovered in the drive.
358 @pre CDiscoverer is fully constructed.
359 @post The directory entry has been processed by the observer.
362 void ProcessEntryL(const TDriveName& aDrive, CPluginBase*& aEntry, TBool aAnyDllDiscovered);
365 @fn DriveMountedL(TDriveUnit aDrive)
366 Intended Usage : Signal a drive is available.
367 Error Condition : Depends on the observer implementation.
368 @leave Depends on the observer implementation. @see CRegistrar.
370 @param aDrive The drive to be noted as available.
372 @pre CDiscoverer is fully constructed.
373 @post The drive mount has been signalled to the observer.
376 void DriveMountedL(TDriveUnit aDrive);
379 @fn DriveUnmountedL(TDriveUnit aDrive)
380 Intended Usage : Signal a drive is unavailable.
381 Error Condition : Leaves with an error code
384 @param aDrive The drive to be noted as unavailable.
385 @pre CDiscoverer is fully constructed.
386 @post The drive dismount has been signalled to the observer.
389 void DriveUnmountedL(TDriveUnit aDrive);
395 Intended Usage : start the iRscDirNotifierList and iSwiChangeNotifier when EDisc_AllPlugins
397 @pre : CDiscoverer is fully constructed. and iRscDirNotifierList and iSwiChangeNotifier
398 are fully constructed.
399 @post : iRscDirNotifierList Activate and iSwiChangeNotifier Subscribe methods are called.
401 void StartNotifiers();
405 @fn InitialiseEvent()
406 Intended Usage : called during the CDiscoverer's construction
409 @post : State is changed from EDisc_Undefined to EDisc_NoPluginsDisc.
411 void InitialiseEvent();
414 @fn IsAnyDllRegisteredWithDriveL(const TDriveUnit aDrive)
415 Intended Usage : Find if any Dll is registered in the drive.
416 @param : aDrive the identifier of the drive to find if any Dll is registered.
417 @return : ETrue if any Dll is registered in the drive unit, otherwise EFalse.
418 @pre : CDiscoverer is fully constructed.
419 @post : If any Dll registered info will be returned.
421 TBool IsAnyDllRegisteredWithDriveL(const TDriveUnit aDrive)const ;
424 @fn SwiOperationInProgress()
425 Intended Usage : Determine if any SWI operation is currently in progress
426 @return : ETrue if any SWI operation is in progress otherwise EFalse.
427 @pre : CDiscoverer is fully constructed.
430 TBool SwiOperationInProgress() ;
433 @fn LocaleChangedL(TAny*)
434 Intended Usage : Callback function to be attached to an instance of CEnvironmentChangeNotifier to
435 rebuild registry data. Note that this has to be a static member function.
436 @param : A parameter to be passed usually with a "this" pointer so that while the function
437 remaining a static function it can access all the member data anyway.
438 @return : ETrue if language downgrade path is changed, otherwise EFalse.
439 @pre : CDiscoverer is fully constructed.
440 @post : Call LanguageChangeNotificationL method to rescan resource files.
442 static TInt LocaleChangedL(TAny*) ;
447 // Define the helper classes which handle the
448 // notification processing.
449 class CDirChangeNotifier;
452 typedef RPointerArray<CDirChangeNotifier> RDirChangeNotifierPointerArray;
453 // Handles notifications of changes to plugin resources directory on list of drives.
454 RDirChangeNotifierPointerArray iRscDirNotifierList;
456 class CSwiChangeNotifier;
458 // Handles notifications of changes to SWI
459 CSwiChangeNotifier* iSwiChangeNotifier;
461 // Indicates whether a discovery due to SWI changes is pending
462 TBool iSwiChangeDiscoveryPending;
464 //Handle notifications of changes to environment (including language switch)
465 CEnvironmentChangeNotifier* iLanguageChangeNotifier ;
467 // Stores the current SWI operation
470 // Indicates whether a discovery due to language changes is pending
471 TBool iLanguageChangeDiscoveryPending;
473 // the current state of CDiscoverer
474 TDiscovererState iState;
476 class CIdleScanningTimer;
478 // A single timer, processes all pending notifications.
479 CIdleScanningTimer* iScanningTimer;
484 The internal Interface Implementation Collection
485 identifier and registration handler
488 CDirScanner* iDirScanner;
490 /** A reference to the owning client of the CDiscoverer */
492 MDiscovererObserver& iDiscovererObserver;
494 /** A reference to the connected file server instance */
498 /** The list of existing drives */
500 RArray<TUint> iDrivesDiscovered;
502 /** cached info of drives A to Z */
503 CEComCachedDriveInfo* iCachedDriveInfo;
505 TCallBackWithArg iSwiChangeCallBack;
506 TCallBackWithArg iBurChangeCallBack;
508 // List the internal classes as friends
509 friend class CSwiChangeNotifier;
510 friend class CDirChangeNotifier;
511 friend class CIdleScanningTimer;
512 friend class CDirScanner;
513 // And the Test bed state accessor
514 friend class TDiscoverer_StateAccessor;
518 // __________________________________________________________________________
521 The notification object which uses P&S to monitor SWI KSAUidSoftwareInstallKey
522 for changes. When SWI is present in the device/ROM this attribute publishes the
523 current state of a software install or uninstall.
524 When its RunL method is called and depending on the install/uninstall state it
525 notifies its owning CDiscoverer class object to re-scan removable drives.
529 class CDiscoverer::CSwiChangeNotifier : public CActive
534 @fn NewL(CDiscoverer& aDiscoverer)
535 Intended Usage : Standardised safe construction which leaves nothing
536 on the cleanup stack.
537 Error Condition : Not enough memory available.
540 @param aDiscoverer A reference to the owning CDiscoverer
541 @return CSwiChangeNotifier* a pointer to the new class
543 @post CSwiChangeNotifier is fully constructed, and initialised.
545 static CSwiChangeNotifier* NewL(CDiscoverer& aDiscoverer);
548 @fn virtual ~CSwiChangeNotifier()
549 Intended Usage : Standard default d'tor
550 Error Condition : None
552 @pre CSwiChangeNotifier is fully constructed.
553 @post CSwiChangeNotifier is totally destroyed
555 virtual ~CSwiChangeNotifier();
559 Intended Usage : Subscribes with P&S for change notifications for the
560 SWI KSAUidSoftwareInstallKey property
561 Error Condition : None
563 @pre CSwiChangeNotifier is fully constructed.
564 @post CSwiChangeNotifier is active on the current scheduler.
570 @fn CSwiChangeNotifier(CDiscoverer& aDiscoverer)
571 Intended Usage : Standardised default c'tor
572 Error Condition : None
574 @param aDiscoverer A reference to its owning class instance.
576 @post CSwiChangeNotifier is fully constructed
578 CSwiChangeNotifier(CDiscoverer& aDiscoverer);
582 Intended Usage : When the object activates, this is method is called
583 and notifies the CDiscoverer to re-scan the
585 Error Condition : Not enough memory available to complete the scan.
588 @pre CSwiChangeNotifier is fully constructed.
589 @post CSwiChangeNotifier notifications are subscribed and plugins on
590 removable drives have been rediscovered..
595 @fn void ConstructL()
596 Intended Usage : Standardised 2nd, (Initialisation) phase of two phase construction.
597 Error Condition : Leaves with error code : usually KErrNoMemory.
601 @pre CSwiChangeNotifier is fully constructed.
602 @post CSwiChangeNotifier is fully initialised.
608 Intended Usage : The cancel action called by CActive::Cancel().
609 Error Condition : None
611 @pre CSwiChangeNotifier is fully constructed.
612 @post CSwiChangeNotifier notifications are cancelled and
613 it is no longer active on the current scheduler.
618 @fn RunError(TInt aError)
619 Intended Usage : Called by the notifier RunL leaving.
621 @param aError The error code that the RunL left with.
622 @return TInt KErrNone.
623 @pre CSwiChangeNotifier is fully constructed.
624 @post CSwiChangeNotifier is returned to a
625 sensible active state.
627 TInt RunError(TInt aError);
630 /** A reference to its owning class instance */
631 CDiscoverer& iDiscoverer;
632 /** Handle allowing access to P&S properties */
634 /** Friend class to enable access to private members for testing. */
635 friend class TDiscoverer_StateAccessor;
638 // __________________________________________________________________________
643 The notification object which watches the Interface Implementation Collection directories for
645 When its RunL method is called, it notifies its owning CDiscoverer class
646 object to re-scan the Interface Implementation Collection directories.
648 class CDiscoverer::CDirChangeNotifier : public CActive
652 @fn CDirChangeNotifier(CDiscoverer& aDiscoverer, RFs& aFs, const TDesC& aNotificationFilePath)
653 Intended Usage : Standardised default c'tor
654 Error Condition : None
656 @param aDiscoverer A reference to its owning class instance.
657 @param aFs A reference to a connected file server instance.
658 @param aNotificationFilePath A reference to the file path that is to be watched.
659 @param aDriveUnit A drive which the notification object watches for.
661 @post CDirChangeNotifier is fully constructed
663 CDirChangeNotifier(CDiscoverer& aDiscoverer, RFs& aFs,const TDriveUnit& aDriveUnit);
665 @fn virtual ~CDirChangeNotifier()
666 Intended Usage : Standard default d'tor
667 Error Condition : None
669 @pre CDirChangeNotifier is fully constructed.
670 @post CDirChangeNotifier is totally destroyed
672 virtual ~CDirChangeNotifier();
675 Intended Usage : Activate the notifier and attach it to the File
676 session to watch the appropriate Interface Implementation Collection directories.
677 Error Condition : None
679 @pre CDirChangeNotifier is fully constructed.
680 @post CDirChangeNotifier is active on the current scheduler.
687 Intended Usage : When the object activates, this is method is called
688 and notifies the CDiscoverer to re-scan the
689 Interface Implementation Collection directories.
690 Error Condition : Not enough memory available to complete the scan.
693 @pre CDirChangeNotifier is fully constructed.
694 @post CDirChangeNotifier notifications are cancelled and
695 it is no longer active on the current scheduler.
700 Intended Usage : The cancel action called by CActive::Cancel().
701 Error Condition : None
703 @pre CDirChangeNotifier is fully constructed.
704 @post CDirChangeNotifier notifications are cancelled and
705 it is no longer active on the current scheduler.
710 @fn RunError(TInt aError)
711 Intended Usage : Called by the notifier RunL leaving.
713 @param aError The error code that the RunL left with.
714 @return TInt KErrNone.
715 @pre CDirChangeNotifier is fully constructed.
716 @post CDirChangeNotifier is returned to a
717 sensible active state.
719 TInt RunError(TInt aError);
722 /** A reference to its owning class instance */
723 CDiscoverer& iDiscoverer;
724 /** A reference to a connected file server instance */
726 /** The file path for a specific drivethat we are interested in.*/
727 //const TDesC& iNotificationFilePath;
728 typedef TBuf<KEComPlugRSCPathMaxLen> TResourcePathName;
729 TResourcePathName iNotificationFilePath;
731 /** A drive which the notification object watches for.*/
732 TDriveUnit iDriveUnit;
733 /** Friend class to enable access to private members for testing. */
734 friend class TDiscoverer_StateAccessor;
739 The timer Active object for providing incremental plugin directory scanning.
740 Note that task execution is dependant upon the task priority
741 The default priority is idle time execution only.
742 This object controls the yielding of time to other processes by having a low priority
743 but requesting immediate reactivation, after each incremental part of the directory scan.
744 It is launched by the CDirChangeNotifier's notification call.
746 class CDiscoverer::CIdleScanningTimer : public CTimer
750 @fn NewL(CDiscoverer& aDiscoverer)
751 Intended Usage : Standardised safe construction which leaves nothing
752 on the cleanup stack.
753 Error Condition : Not enough memory available.
756 @param aDiscoverer A reference to the owning CDiscoverer
757 @return CIdleScanningTimer* a pointer to the new class
759 @post CIdleScanningTimer is fully constructed, and initialised.
761 static CIdleScanningTimer* NewL(CDiscoverer& aDiscoverer);
763 @fn virtual ~CIdleScanningTimer()
764 Intended Usage : Standard default d'tor
765 Error Condition : None
767 @pre CIdleScanningTimer is fully constructed.
768 @post CIdleScanningTimer is totally destroyed
770 virtual ~CIdleScanningTimer();
773 @fn AddDriveL(TDriveUnit aDrive)
774 Intended Usage : Add a drive for processing notification
775 Error Condition : None
776 @leave System wide error codes.
777 @param aDrive The drive to be added.
778 @post The drive number added into pending list only if it has not been added before
780 inline void AddDriveL(const TDriveUnit aDrive)
782 if(iPendingDriveList.Find(aDrive) == KErrNotFound)
784 iPendingDriveList.AppendL(aDrive);
789 @fn IsAnyNotificationProcessingPending()
790 Intended Usage : To check if there is any notification waiting to be processed.
791 @return TBool A flag indicating if there is any pending notification to be processed
793 inline TBool IsAnyNotificationProcessingPending()
795 if(iPendingDriveList.Count())
801 @fn RestartScanPeriod()
802 Intended Usage : Called to restart the scanning period.
803 Error Condition : None
804 @pre CIdleScanningTimer is fully constructed.
805 @post CIdleScanningTimer is activated and will process pending drives list, if the timer has not been suspended
807 void RestartScanPeriod();
811 Intended Usage : Called to suspend the scanning timer, disabling the scanning from being restarted.
812 Error Condition : None
813 @pre CIdleScanningTimer is fully constructed.
814 @post CIdleScanningTimer is set as suspended. No re-discovery will take place.
820 Intended Usage : Called to resume the scanning timer, and enable scanning to be restarted.
821 Error Condition : None
822 @pre CIdleScanningTimer is fully constructed.
823 @post CIdleScanningTimer is set as resumed. Re-discovery will take place.
829 @fn CIdleScanningTimer(CDiscoverer& aDiscoverer)
830 Intended Usage : Standardised default c'tor made explicit to avoid unintentional
831 conversion construction by the compiler.
832 Error Condition : None
834 @param aDiscoverer A reference to its owning class instance.
836 @post CIdleScanningTimer is fully constructed
838 explicit CIdleScanningTimer(CDiscoverer& aDiscoverer);
840 @fn void ConstructL()
841 Intended Usage : Standardised 2nd, (Initialisation) phase of two phase construction.
842 Error Condition : Leaves with error code : usually KErrNoMemory.
846 @pre CIdleScanningTimer is fully constructed.
847 @post CIdleScanningTimer is fully initialised.
853 Intended Usage : The cancel action called by CActive::Cancel().
854 Error Condition : None
856 @pre CIdleScanningTimer is fully constructed.
857 @post CIdleScanningTimer is no longer active on the current scheduler.
863 Intended Usage : When the object activates, this method calls
864 the CDiscoverer to continue the incremental scan
865 of the Interface Implementation Collection directories.
866 Error Condition : Not enough memory available to add to complete the scan.
869 @pre CIdleScanningTimer is fully constructed.
870 @post The Interface Implementation Collection directories Scan has completed another step and the
871 CIdleScanningTimer has been re-activated for the next step
872 OR The Interface Implementation Collection directories Scan is complete and the
873 CDirChangeNotifier has been re-activated.
878 @fn RunError(TInt aError)
879 Intended Usage : Called when the directory change
880 notification processing failed by leaving.
882 @param aError The error code that the RunL left with.
883 @return TInt KErrNone.
884 @pre CIdleScanningTimer is fully constructed.
885 @post CIdleScanningTimer is non-active.
887 TInt RunError(TInt aError);
890 /** A reference to its owning class instance */
891 CDiscoverer& iDiscoverer;
894 An array of drives to be processed.
896 RArray<TUint> iPendingDriveList;
899 A flag to indicate if the timer is suspended or not.
903 // List the internal classes as friends
904 // the Test bed state accessor
905 friend class TDiscoverer_StateAccessor;
911 CDirScanner implements incremental scanning of the Interface Implementation
912 Collection directories on behalf of the CDiscoverer.
913 Its methods are called in response to the timer task execution,
914 thereby requiring the incremental scheduling.
916 class CDiscoverer::CDirScanner : public CBase
921 @fn CDirScanner(CDiscoverer& aDiscoverer, RFs& aFs)
922 Intended Usage : Standardised safe construction which leaves nothing
923 on the cleanup stack.
924 Error Condition : Not enough memory available.
927 @param aDiscoverer A reference to its owning class instance.
928 @param aFs A reference to a connected file server instance.
929 @return CDirScanner* a pointer to the new class
931 @post CDirScanner is fully constructed, and initialised.
933 static CDirScanner* NewL(CDiscoverer& aDiscoverer, RFs& aFs);
936 @fn virtual ~CDirScanner()
937 Intended Usage : Standard default d'tor
938 Error Condition : None
940 @pre CDirScanner is fully constructed.
941 @post CDirScanner is totally destroyed
943 virtual ~CDirScanner();
947 @fn DiscoverPluginsL()
948 Intended Usage : Discover the plugins the specific drive units.
949 @param : aIsRO a flag to show if the Drive Units list is RO Internal or not.
950 @pre : CDiscoverer is fully constructed.iDirScanner is fully constructed.
951 @pre : CDirScanner is fully constructed.
952 @post : the plugins on the specific Drive Units have been discovered.
954 void DiscoverPluginsL(TBool aDiscoverReadOnlyDrives);
957 @fn ScanDriveL(TDriveUnit aDrive)
958 Intended Usage : Helper method for StartScanL.
959 Scan a drive for the Interface Implementation Collection directories
960 and identify any Interface Implementation
961 Collections within that directory
962 for addition to the registry.
963 Error Condition : None
966 @param aDrive The drive to scan.
967 @param aIsRO A flag to tell if the drive unit is RO or Non-RO
968 @pre CDirScanner is fully constructed.
969 @post Another drive's Interface Implementation Collection directories has been scanned,
971 void ScanDriveL(const TDriveUnit& aDrive, TBool aIsRO);
975 @fn CDirScanner(CDiscoverer& aDiscoverer, RFs& aFs)
976 Intended Usage : Standardised default c'tor.
977 Error Condition : None
979 @param aDiscoverer A reference to its owning class instance.
980 @param aFs A reference to a connected file server instance.
982 @post CDirScanner is fully constructed
984 CDirScanner(CDiscoverer& aDiscoverer, RFs& aFs);
987 @fn void ConstructL()
988 Intended Usage : Standardised 2nd, (Initialisation) phase of two phase construction.
989 Error Condition : Leaves with error code : usually KErrNoMemory.
993 @pre CDirScanner is fully constructed.
994 @post CDirScanner is fully initialised.
1001 @fn DoScanDriveL(const TDriveUnit aDrive, const TUidType aUidType)
1002 Intended Usage : Helper method for StartScanL.
1003 Scan a drive for the Interface Implementation Collection directories
1004 and identify any Interface Implementation
1005 Collections within that directory
1006 for addition to the registry.
1007 Error Condition : None
1010 @param aDrive The drive to scan.
1011 @param aUidType The uid type to be searched for.
1012 @param aIsRO Indicates whether the current drive is read Only.
1013 @pre CDirScanner is fully constructed.
1014 @post Another drive's Interface Implementation Collection directories has been scanned,
1016 TBool DoScanDriveL(const TDriveUnit& aDrive, const TUidType& aUidType, TBool aIsRO);
1019 @fn DoScanSpiFileL(const TParse aSpiPath)
1020 Intended Usage : Helper method for StartScanL.
1021 Scan a SPI file for the Interface Implementation Collection directories
1022 and identify any Interface Implementation Collections within that directory
1023 for addition to the registry.
1024 Error Condition : None
1027 @param aSpiPath The SPI file to scan.
1028 @pre CDirScanner is fully constructed.
1029 @post Another drive's Interface Implementation Collection has been scanned from an SPI file.
1031 TBool DoScanSpiFileL(const TParse& aSpiPath);
1034 // Attributes / Properties
1036 /** A reference to its owning class instance */
1037 CDiscoverer& iDiscoverer;
1038 /** A reference to a connected file server instance */
1040 /** The Full Interface Implementation Collection Directory path */
1042 // List the internal classes as friends
1043 // the Test bed state accessor
1044 friend class TDiscoverer_StateAccessor;
1049 #endif // __DISCOVERER_H__