searcher/tsrc/logplayer/src/logplayerconsole.cpp
changeset 0 671dee74050a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/searcher/tsrc/logplayer/src/logplayerconsole.cpp	Mon Apr 19 14:40:16 2010 +0300
@@ -0,0 +1,134 @@
+/*
+* Copyright (c) 2010 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: 
+*
+*/
+
+
+//  Include Files  
+
+#include "LogPlayerConsole.h"
+#include <e32base.h>
+#include <e32std.h>
+#include <e32cons.h>			// Console
+
+#include "LogPlayerManager.h"
+
+//  Constants
+
+_LIT(KTextConsoleTitle, "Console");
+_LIT(KTextFailed, " failed, leave code = %d");
+_LIT(KTextPressAnyKey, " [press any key]\n");
+
+//  Global Variables
+
+LOCAL_D CConsoleBase* console; // write all messages to this
+
+
+//  Local Functions
+
+LOCAL_C void MainL()
+    {
+    _LIT( KConfigurationFile, "c:\\data\\LPConf.txt" );
+    _LIT( KDefaultLogFile, "c:\\data\\LPDefault.txt" );
+
+	console->Printf( _L("Starting application\n") );
+    
+    // Get log file names from configuration file
+    RFs fs;
+    User::LeaveIfError( fs.Connect() );
+    CleanupClosePushL( fs );
+
+    RFile file;
+    TInt err = file.Open( fs, KConfigurationFile, EFileRead );
+    CleanupClosePushL( file );
+    
+    if ( err == KErrNone ) // Read configuration file
+    {
+    	TInt size;
+    	file.Size( size );
+    	HBufC8* data = HBufC8::NewLC( size );
+    	TPtr8 dataPtr = data->Des();
+    	
+    	User::LeaveIfError( file.Read( dataPtr ) );
+    	
+    	HBufC* data16 = HBufC::NewLC( size );
+    	data16->Des().Copy( dataPtr );
+    	
+    	TLex16 lex(*data16);
+    	
+    	while ( !lex.Eos() )
+    	{
+    		TPtrC pathName = lex.NextToken();
+    		
+    	    CLogPlayerManager* manager = CLogPlayerManager::NewLC( pathName );
+    		TRAP_IGNORE( manager->ExecuteLogL( console ) );
+    		CleanupStack::PopAndDestroy( manager );
+    		
+    		lex.SkipSpace();
+    	}
+    	CleanupStack::PopAndDestroy( data16 );
+    	CleanupStack::PopAndDestroy( data );
+    }
+    else // Use default file
+    {
+	    CLogPlayerManager* manager = CLogPlayerManager::NewLC( KDefaultLogFile()  );
+    	TRAP_IGNORE( manager->ExecuteLogL( console ) );
+		CleanupStack::PopAndDestroy( manager );
+    }
+    
+    CleanupStack::PopAndDestroy( &file );
+    CleanupStack::PopAndDestroy( &fs );
+    }
+
+LOCAL_C void DoStartL()
+    {
+    // Create active scheduler (to run active objects)
+    CActiveScheduler* scheduler = new (ELeave) CActiveScheduler();
+    CleanupStack::PushL(scheduler);
+    CActiveScheduler::Install(scheduler);
+
+    MainL();
+
+    // Delete active scheduler
+    CleanupStack::PopAndDestroy(scheduler);
+    }
+
+//  Global Functions
+
+GLDEF_C TInt E32Main()
+    {
+    // Create cleanup stack
+    __UHEAP_MARK;
+    CTrapCleanup* cleanup = CTrapCleanup::New();
+
+    // Create output console
+    TRAPD(createError, console = Console::NewL(KTextConsoleTitle, TSize(
+            KConsFullScreen, KConsFullScreen)));
+    if (createError)
+        return createError;
+
+    // Run application code inside TRAP harness, wait keypress when terminated
+    TRAPD(mainError, DoStartL());
+    if (mainError)
+        console->Printf(KTextFailed, mainError);
+    console->Printf(KTextPressAnyKey);
+    console->Getch();
+
+    delete console;
+    delete cleanup;
+    __UHEAP_MARKEND;
+    return KErrNone;
+    }
+