revert the change to rofsbuild image format, but add checking codes to prevent address overflow
/*
* Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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:
* @internalComponent * @released
* Driveimage general utilities.
*
*/
#include <string.h>
#include <stdlib.h>
#include <time.h>
#include <e32err.h>
#include "h_utl.h"
#include "r_driveutl.h"
/**
Derive log file name from the given driveobey file name(it could be absolute path)
and update with .log extn.
Checks the validity of driveobey file name before creating the log file name.
@param adriveobeyFileName - Drive obey file.
@param &apadlogfile - Log file name from command line.
@return - returns 'ErrorNone' if log file created, otherwise returns Error.
*/
string Getlogfile(char *aDriveObeyFileName,const string &CmdLogFile)
{
string strLogfile(CmdLogFile);
if(strLogfile.size() > 0 && strLogfile[strLogfile.size()-1] != '\\' && strLogfile[strLogfile.size()-1] != '/')
return strLogfile;
if(!(*aDriveObeyFileName))
return string("");
// Validate the user entered driveoby file name.
char* logFile = (char*)aDriveObeyFileName;
#ifdef __LINUX__
logFile = strrchr(logFile,'/');
#else
while(*logFile)
{
if(*logFile == '/')
*logFile = '\\';
logFile++;
}
logFile = (char*)aDriveObeyFileName;
logFile = strrchr(logFile,'\\');
#endif
if(logFile)
++logFile;
else
logFile = (char*)aDriveObeyFileName;
TInt len = strlen(logFile);
if(!len)
return string("");
// Create the log file name.
strLogfile += logFile;
strLogfile += ".LOG";
return strLogfile;
}
/**
Time Stamp for Log file.
*/
TAny GetLocalTime(TAny)
{
struct tm *aNewTime = NULL;
time_t aTime = 0;
time(&aTime);
aNewTime = localtime(&aTime);
/* Print the local time as a string */
if(aNewTime)
Print(ELog,"%s\n", asctime(aNewTime));
else
Print(ELog,"Error : Getting Local Time\n");
}