crashanalysercmd/UI/Console/CACommandLineUI.cs
changeset 0 818e61de6cd1
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/crashanalysercmd/UI/Console/CACommandLineUI.cs	Thu Feb 11 15:50:58 2010 +0200
@@ -0,0 +1,210 @@
+/*
+* 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.IO;
+using System.Text;
+using System.Collections.Generic;
+using System.Data;
+using CrashAnalyserEngine.Tabs;
+using CrashAnalyserEngine.Engine;
+using CrashAnalyserEngine.Interfaces;
+using CrashAnalyserEngine.Plugins;
+using SymbianXmlInputLib.Elements;
+using SymbianXmlInputLib.Parser;
+using SymbianXmlInputLib.Parser.Nodes;
+using SymbianUtils.FileSystem;
+
+namespace CrashAnalyserConsole
+{
+	internal class CACommandLineUI : IEngineUIManager
+	{
+		#region Constructors & destructor
+        public CACommandLineUI( string[] aArguments, FSLog aLog )
+		{
+            iLog = aLog;
+
+            // Create engine
+            iEngine = new CAEngine( aArguments );
+
+            // Work out if we are in verbose mode
+            CheckArgsForVerbose();
+
+            // Associate engine and UI with one another - this causes
+            // plugins to be loaded
+            iEngine.UIManager = this;
+        }
+		#endregion
+
+        #region API
+        public int Run()
+        {
+            iLog.TraceAlways( "[CmdExe] Run() - START" );
+            int error = CAPlugin.KErrCommandLineNone;
+            //
+            CAPlugin plugin = LocatePlugin();
+            iLog.TraceAlways( "[CmdExe] Run() - plugin: " + plugin );
+            if ( plugin != null )
+            {
+                iLog.TraceAlways( "[CmdExe] Run() - executing plugin command line operations..." );
+                error = plugin.RunCommandLineOperations();
+            }
+            else
+            {
+                iLog.TraceAlways( "[CmdExe] Run() - plugin not found!" );
+                error = CAPlugin.KErrCommandLinePluginNotFound;
+            }
+            //
+            iLog.TraceAlways( "[CmdExe] Run() - END - error: " + error );
+            return error;
+        }
+        #endregion
+
+        #region Properties
+        public bool Verbose
+        {
+            get { return iLog.Verbose; }
+            private set
+            { 
+                iLog.Verbose = value;
+                iLog.TraceAlways( "[CmdExe] Verbose Mode: " + value.ToString() );
+            }
+        }
+        #endregion
+
+        #region IEngineUIManager Members
+        public void UIManagerMenuItemAdd( TEngineUIMenuPane aPane, string aCaption, UIMenuItemClickHandler aClickHandler, object aTag )
+        {
+        }
+
+        public void UIManagerMenuItemAdd( TEngineUIMenuPane aPane, string aCaption, UIMenuItemClickHandler aClickHandler, object aTag, CATab aHost )
+        {
+        }
+
+        public void UIManagerContentAdd( CATab aTab )
+        {
+        }
+
+        public void UIManagerContentClose( CATab aTab )
+        {
+        }
+
+        public Version UIVersion
+        {
+            get { return System.Reflection.Assembly.GetExecutingAssembly().GetName().Version; }
+        }
+
+        public string UICommandLineArguments
+        {
+            get { return Environment.CommandLine; }
+        }
+
+        public bool UIIsSilent
+        {
+            get { return true; }
+        }
+
+        public void UITrace( string aMessage )
+        {
+            iLog.Trace( aMessage );
+        }
+
+        public void UITrace( string aFormat, params object[] aParams )
+        {
+            string msg = string.Format( aFormat, aParams );
+            UITrace( msg );
+        }
+        #endregion
+
+        #region Internal constants
+        private const string KParamVerbose = "-V";
+        private const string KParamPlugin = "-PLUGIN";
+        #endregion
+
+        #region Internal methods
+        private void CheckArgsForVerbose()
+        {
+            string[] args = iEngine.CommandLineArguments;
+            for ( int i = 0; i < args.Length; i++ )
+            {
+                string cmd = args[ i ].Trim().ToUpper();
+                string nextArg = ( i < args.Length - 1 ? args[ i + 1 ].Trim().ToUpper() : string.Empty );
+                //
+                try
+                {
+                    if ( cmd == KParamVerbose )
+                    {
+                        Verbose = true;
+                        break;
+                    }
+                }
+                catch ( Exception )
+                {
+                }
+            }
+        }
+
+        private CAPlugin LocatePlugin()
+        {
+            // -nogui -plugin CRASH_ANALYSIS -input d:\ca_fullsummary.xml
+            CAPlugin ret = null;
+            //
+            string[] args = iEngine.CommandLineArguments;
+            for( int i=0; i<args.Length; i++ )
+            {
+                string cmd = args[ i ].Trim().ToUpper();
+                string nextArg = ( i < args.Length - 1 ? args[ i + 1 ].Trim().ToUpper() : string.Empty );
+                //
+                try
+                {
+                    if ( cmd == KParamPlugin && nextArg != string.Empty )
+                    {
+                        ret = LocatePluginByName( nextArg );
+                        break;
+                    }
+                }
+                catch ( Exception )
+                {
+                }
+            }
+            //
+            return ret;
+        }
+
+        private CAPlugin LocatePluginByName( string aName )
+        {
+            CAPlugin ret = null;
+            //
+            foreach ( CAPlugin plugin in iEngine )
+            {
+                bool isHandler = plugin.IsCommandLineHandler( aName );
+                if ( isHandler )
+                {
+                    ret = plugin;
+                    break;
+                }
+            }
+            //
+            return ret;
+        }
+        #endregion
+
+        #region Data members
+        private readonly CAEngine iEngine;
+        private readonly FSLog iLog;
+        #endregion
+    }
+}