diff -r 000000000000 -r 818e61de6cd1 crashanalysercmd/Libraries/Engine/CrashItemLib/Engine/ProblemDetectors/CIProblemDetectorManager.cs --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/crashanalysercmd/Libraries/Engine/CrashItemLib/Engine/ProblemDetectors/CIProblemDetectorManager.cs Thu Feb 11 15:50:58 2010 +0200 @@ -0,0 +1,74 @@ +/* +* Copyright (c) 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: +* +*/ +using System; +using System.Text; +using System.IO; +using System.Collections.Generic; +using SymbianUtils.Threading; +using SymbianUtils; +using SymbianUtils.PluginManager; +using CrashItemLib.Crash.Container; +using CrashItemLib.Crash.Messages; + +namespace CrashItemLib.Engine.ProblemDetectors +{ + internal class CIProblemDetectorManager : MultiThreadedProcessor + { + #region Constructors + public CIProblemDetectorManager( CIEngine aEngine ) + : base( KDetectors ) + { + iEngine = aEngine; + } + + static CIProblemDetectorManager() + { + KDetectors.LoadFromCallingAssembly(); + } + #endregion + + #region API + #endregion + + #region From MultiThreadedProcessor + public override void Start( TSynchronicity aSynchronicity ) + { + // Make sure we always start with a fully populated list of detectors + base.PopulateQueue( KDetectors ); + base.Start( aSynchronicity ); + } + + protected override bool Process( CIProblemDetector aItem ) + { + iEngine.Trace( "[CIProblemDetectorManager] Process() - START - detector: \'{0}\'", aItem.GetType().Name ); + // + foreach ( CIContainer container in iEngine ) + { + aItem.Check( container ); + } + // + iEngine.Trace( "[CIProblemDetectorManager] Process() - END - detector: \'{0}\'", aItem.GetType().Name ); + return true; + } + #endregion + + #region Data members + private readonly CIEngine iEngine; + private static PluginManager KDetectors = new PluginManager(); + #endregion + } +}