imgtools/imgcheck/src/cmdlinewriter.cpp
author William Roberts <williamr@symbian.org>
Wed, 07 Jul 2010 14:23:35 +0100
changeset 610 3b0f18c0b8e3
parent 590 360bd6b35136
permissions -rw-r--r--
Add support for --asm option when using elf2e32 in the "expgen" recipe - see bug 2979 and bug 1405

/*
* 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 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: 
* Generates commandline report.
*
*/


/**
@file
@internalComponent
@released
*/

#include "cmdlinewriter.h"
#include <stdio.h>
/**
Constructor: CmdLineWriter class

@internalComponent
@released
*/
CmdLineWriter::CmdLineWriter(unsigned int aInputOptions)
: iForDepAlign(0), iFormatSize(0),  iRptType(KCmdLine), iCmdOptions(aInputOptions) {
	//iFormatMessage.flush();
}


/**
Destructor:	CmdLineWriter class

Clear the Buffer.

@internalComponent
@released
*/
CmdLineWriter::~CmdLineWriter(void) {

}


/**
Writes report header to the cmd line..
Allocates the memory for formatting purpose.

@internalComponent
@released
*/
void CmdLineWriter::StartReport(void) { 
}


/**
Writes the end report info..
Transfer the stream data to stdout.

@internalComponent
@released
*/
void CmdLineWriter::EndReport(void) {
	iFormatMessage.flush();
	string str ;
	while(!iFormatMessage.eof()){
		getline(iFormatMessage,str);
		cout << str.c_str()<<endl ;
	}
}


/**
Writes the executable element footer.

@internalComponent
@released
*/
void CmdLineWriter::EndExecutable(void) {
	iFormatMessage << endl;
	iForDepAlign = false;

}


/**
Writes the Delimiter to cmd line.

@internalComponent
@released
*/
void CmdLineWriter::WriteDelimiter(void) {
	if(iCmdOptions & KNoCheck) {
		iFormatMessage << KCmdLineDelimiterNoStatus << endl;
	}
	else {
		iFormatMessage << KCmdLineDelimiter << endl;
	}

}


/**
Formats the given element based on set size and places to outstream.

@internalComponent
@released

@param aElement - Reference element to be formated
*/
void CmdLineWriter::FormatAndWriteElement(const string& aElement) {
	if(aElement.length() < iFormatSize)
		iFormatMessage << setw(iFormatSize) << aElement.c_str(); 
	else 
		iFormatMessage << aElement.c_str() << ' '; 
}

/**
Writes the note about unknown dependency.

@internalComponent
@released
*/
void CmdLineWriter::WriteNote(void){
	iFormatMessage << KNote << ": " << KUnknownDependency << KNoteMesg << endl;
}


/**
Writes the image element footer.

@internalComponent
@released
*/
void CmdLineWriter::EndImage(void){
	WriteDelimiter();	

}


/**
Writes the executable name element.

@internalComponent
@released

@param aExeName  - Reference to executable name.
*/
void CmdLineWriter::StartExecutable(const unsigned int /* aSerNo */, const string& aExeName) {
	iFormatSize = KCmdFormatTwentyEightWidth; 
	FormatAndWriteElement(aExeName);
	iForDepAlign = true;
}	


/**
Writes the image name element.

@internalComponent
@released

@param aImageName  - Reference to image name.
*/
void CmdLineWriter::StartImage(const string& aImageName) {
	WriteDelimiter();
	iFormatMessage << KCmdImageName << aImageName.c_str() << endl;
	WriteDelimiter();
	iFormatMessage << setw(KCmdFormatTwentyEightWidth) << left <<setfill(' ')<< "Executable" ;
	iFormatMessage << setw(KCmdFormatTwelveWidth)  << "Attribute" ;
	iFormatMessage << setw(KCmdFormatTwelveWidth) << "Value" ;
	if(0 == (iCmdOptions & KNoCheck)) {
		iFormatMessage << setw(KCmdFormatTwelveWidth) << "Status" ;
	}
	iFormatMessage<<endl;
	WriteDelimiter();
}


/**
Writes the attribute, their values and the status along with formating the output.

@internalComponent
@released

@param aOneSetExeAtt - Reference to the attributes, their value and status
*/	
void CmdLineWriter::WriteExeAttribute(ExeAttribute& aOneSetExeAtt) {
	if(!iForDepAlign) {		
		iFormatSize = KCmdFormatTwentyEightWidth;
		FormatAndWriteElement("");
	}
	iFormatSize = KCmdFormatTwelveWidth; 
	if(KCmdDbgName != aOneSetExeAtt.iAttName) { 
		FormatAndWriteElement(aOneSetExeAtt.iAttName);
	}
	else {
		FormatAndWriteElement(KCmdDbgDisplayName);
	}

	if (KCmdDepName != aOneSetExeAtt.iAttName && KCmdDbgName != aOneSetExeAtt.iAttName) {
		unsigned int val = Common::StringToInt(aOneSetExeAtt.iAttValue);
		char str[20];
		sprintf(str,"0x%08X",val);
		// to display the hex value in the format of 0x00000000 if the value is 0
		iFormatMessage << setw(KCmdFormatTwelveWidth)  << str ; 
	}
	else {
		iFormatSize = KCmdFormatTwentyEightWidth;
		FormatAndWriteElement(aOneSetExeAtt.iAttValue);
	}
	iFormatSize = KCmdFormatTwelveWidth;
	FormatAndWriteElement(aOneSetExeAtt.iAttStatus);  
	iFormatMessage << endl;
	iForDepAlign = false;
}


/**
Returns the report type.

@internalComponent
@released
*/
const string& CmdLineWriter::ReportType(void) {
	return iRptType;
}