diff -r 000000000000 -r 4e1aa6a622a0 sysstatemgmt/systemstatemgr/test/testapps/src/ssmtestprocwritetime.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sysstatemgmt/systemstatemgr/test/testapps/src/ssmtestprocwritetime.cpp Tue Feb 02 00:53:00 2010 +0200 @@ -0,0 +1,102 @@ +// Copyright (c) 2007-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: +// usage: ssmtestprocwritetime.exe [] * +// +// + +/** + @file + @test + @internalComponent - Internal Symbian test code +*/ + +#include +#include +#include +#include +#include +#include "ssmtestapps.h" +#include "ssmdebug.h" + +static void RunL() + { + TBuf commandLine; + if(User::CommandLineLength() > commandLine.MaxLength()) + { + User::Leave(KErrTooBig); + } + User::CommandLine(commandLine); + + commandLine.TrimAll(); + + DEBUGPRINT2A("Argument string: %S", &commandLine); + DEBUGPRINT2A("Logfile location: %S", &KTestAppLogFileLoc); + + TLex cmdLnLex(commandLine); + + TBuf logFileName; + if (cmdLnLex.Eos()) // If there aren't any arguments, that is an error + { + User::Leave(KErrArgument); + } + else + { + TPtrC token(cmdLnLex.NextToken()); + logFileName.Format(_L("%S%S"), &KTestAppLogFileLoc, &token); + DEBUGPRINT3A("Log file name (length: %d): %S", logFileName.Length(), &logFileName); + } + + TInt timeout = 0; + if(!cmdLnLex.Eos()) // If there was only one argument, we are finished and there was no timeout requested. + { + TPtrC token(cmdLnLex.NextToken()); + TLex timeoutLex(token); + User::LeaveIfError(timeoutLex.Val(timeout)); // If Val() returns an error the second argument wasn't an integer + } + + TTime now; + now.UniversalTime(); + TBuf<20> nowStr; // 64-bit integers have a maximum of 19 digits, plus the possibility of a - (though a current time shouldn't be negative) + nowStr.AppendNum( now.Int64() ); + + RFs fs; + User::LeaveIfError(fs.Connect()); + CleanupClosePushL(fs); + RFileWriteStream ws; + User::LeaveIfError(ws.Replace(fs, logFileName, EFileShareExclusive|EFileWrite)); + ws.PushL(); + ws.WriteL(nowStr); + ws.CommitL(); + CleanupStack::PopAndDestroy(2); // fs, ws + + User::After(timeout * 1000000); // Microseconds = 1s + + RProcess::Rendezvous(KErrNone); + } + +TInt E32Main() + { + __UHEAP_MARK; + + CTrapCleanup* cleanup=CTrapCleanup::New(); + TInt r=KErrNoMemory; + if (cleanup) + { + TRAP(r,RunL()); + delete cleanup; + } + + __UHEAP_MARKEND; + return r; + }