imgtools/imgcheck/src/imgcheckmanager.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) 2008-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: 
* ImgCheckManager controller class Controls the instantiation and 
* operations of ImageReader, Checker, Reporter and ReportWriter.
*
*/


/**
 @file
 @internalComponent
 @released
*/

#include "imgcheckmanager.h"
#include "romreader.h"
#include "rofsreader.h"
#include "dirreader.h"
#include "depchecker.h"
#include "sidchecker.h"
#include "vidchecker.h"
#include "dbgflagchecker.h"

/**
Constructor initializes command line handler pointer.
Which can be used by any tool which is derived from this class.

@internalComponent
@released

@param aCmdPtr - command line handler pointer
*/
ImgCheckManager::ImgCheckManager(CmdLineHandler* aCmdPtr)
:iCmdLine(aCmdPtr) {
	iReporter = Reporter::Instance(iCmdLine->ReportFlag());
	iNoRomImage = true; 
}

/**
Destructor traverses through the imagereader list and delets the same

@internalComponent
@released
*/
ImgCheckManager::~ImgCheckManager() {
	int i ;	 
	for(i = iImageReaderList.size() - 1 ; i >= 0 ; i--) {		
		ImageReader* reader = iImageReaderList.at(i); 
		if(NULL != reader)
			delete reader ;
	}
	iImageReaderList.clear(); 
	for(i = iCheckerList.size() - 1 ; i >= 0 ; i--) { 
		Checker* checker = iCheckerList.at(i); 
		if(NULL != checker)
			delete checker ;
	}
	iCheckerList.clear(); 
	for(i = iWriterList.size() - 1 ; i >= 0 ; i--) { 
		ReportWriter* writer = iWriterList.at(i); 
		if(NULL != writer)
			delete writer ;
	}
	iWriterList.clear();  
	Reporter::DeleteInstance();
	iCmdLine = 0;
}

/**
Function responsible to read the header and directory section.

@internalComponent
@released

@param aImageName - image name
@param aImageType - image type
*/
void ImgCheckManager::Process(ImageReader* aImageReader) {
	ExceptionReporter(READINGIMAGE,aImageReader->ImageName()).Log();
	aImageReader->ReadImage();
	aImageReader->ProcessImage();
	if(!aImageReader->ExecutableAvailable()) {
		throw ExceptionReporter(NOEXEPRESENT);
	}
}

/**
Function responsible to 
1. get the image names one by one. 
2. Identify the image type and Create respective Reader objects.
3. Identify the required validations and create respective Instances.
4. Identify the required Writers and create respective instances.

@internalComponent
@released
*/
void ImgCheckManager::CreateObjects(void) { 

	const char* imgName = iCmdLine->NextImageName();	
	while(imgName) {		 
		HandleImage(imgName);
		imgName = iCmdLine->NextImageName();
	}

	Checker* checkerPtr = KNull;
	unsigned int checks = iCmdLine->EnabledValidations();
	unsigned short int bitPos = 1;
	while(bitPos) {
		if(bitPos & checks) {
			switch(bitPos) {
			case EDep:
				checkerPtr = new DepChecker(iCmdLine, iImageReaderList,iNoRomImage);
				break;
			case ESid:
				checkerPtr = new SidChecker(iCmdLine, iImageReaderList);
				break;
			case EVid:
				checkerPtr = new VidChecker(iCmdLine, iImageReaderList);
				break;
			case EDbg:
				checkerPtr = new DbgFlagChecker(iCmdLine, iImageReaderList);
				break;
			}
			if(checkerPtr == KNull) {
				throw ExceptionReporter(NOMEMORY, __FILE__, __LINE__);
			}
			iCheckerList.push_back(checkerPtr);
		}
		bitPos <<= 1; //Shift one bit left
	}

	unsigned int rptFlag = iCmdLine->ReportFlag();
	ReportWriter* rptWriter = KNull;
	if(!( rptFlag & QuietMode)) {
		rptWriter = new CmdLineWriter(rptFlag);
		InsertWriter(rptWriter);
	}
	
	if(iCmdLine->ReportFlag() & KXmlReport) { 
		rptWriter = new XmlWriter(iCmdLine->XmlReportName(), iCmdLine->Command());
		if(!rptWriter){
			cerr << "Failed at file :"<< iCmdLine->XmlReportName() <<" With args "<< iCmdLine->Command()<< endl;
			throw ExceptionReporter(FILEOPENFAIL, __FILE__, __LINE__);
		}
		InsertWriter(rptWriter);		
	}
}

/**
Function responsible to insert the ReprtWriter into iWriterList

@internalComponent
@released
*/
void ImgCheckManager::InsertWriter(ReportWriter* aWriter) {
	if(aWriter == KNull) {
		throw ExceptionReporter(NOMEMORY, __FILE__, __LINE__);
	}
	iWriterList.push_back(aWriter);
}

/**
Function responsible to initiate the enabled validations

@internalComponent
@released
*/
void ImgCheckManager::Execute(void) {	
	ImgVsExeStatus& imgVsExeStatus = iReporter->GetContainerReference();
	unsigned int cnt = 0;
	while(cnt < iCheckerList.size()) {		
		iCheckerList[cnt++]->Check(imgVsExeStatus);
	}
}

/**
Function responsible to write the validated data into Reporter.

@internalComponent
@released
*/
void ImgCheckManager::FillReporterData(void) {	
	ImgVsExeStatus& imgVsExeStatus = iReporter->GetContainerReference(); 	
	for(ImgVsExeStatus::iterator it = imgVsExeStatus.begin();
		it != imgVsExeStatus.end(); it++) {
		ExeVsMetaData* exeVsMetaData = it->second;
		
		for(ExeVsMetaData::iterator i = exeVsMetaData->begin();
			i != exeVsMetaData->end() ; i++ ) {  
			for(unsigned int cnt = 0 ; cnt < iCheckerList.size() ; cnt++) {
				iCheckerList[cnt]->PrepareAndWriteData(i->second);
			} 
		} 
	}
}

/**
Function responsible to start report generation. This function invokes the Reporter's
CreateReport function by passing iWriterList as argument.

@internalComponent
@released

@return - returns the return value of Reporter::CreateReport function.
*/
void ImgCheckManager::GenerateReport(void) {
	iReporter->CreateReport(iWriterList); 
}

/** 
Function to identify the image type and read the header and file and/or directory entries.

@internalComponent
@released

@param aImageName - image name received as part of command line
@param EImageType - type of the input image
*/
void ImgCheckManager::HandleImage(const char* aImageName, EImageType aImageType) {
	unsigned int rptFlag = iCmdLine->ReportFlag();
	string name(aImageName);
	if(rptFlag & KE32Input) {
		aImageType = DirReader::EntryType(name);
	}
	else if(aImageType == EUnknownImage) {
		aImageType = ImageReader::ReadImageType(name);
	}
	ImageReader* imgReader = KNull;
	
	switch(aImageType) {
	case ERomImage:
		iNoRomImage = false;
	case ERomExImage:
		imgReader = new RomReader(aImageName, aImageType);
		break;

	case ERofsImage:
	case ERofsExImage:
		imgReader = new RofsReader(aImageName, aImageType);
		break;

	case EE32Directoy:
		imgReader = new DirReader(aImageName);
		break;
	
	case EE32File:
		imgReader = new E32Reader(aImageName);
		break;

	case EUnknownImage:
		throw ExceptionReporter(UNKNOWNIMAGETYPE, aImageName);
		break;

	case EE32InputNotExist:
		throw ExceptionReporter(E32INPUTNOTEXIST, aImageName);
		break;
	}
	if(imgReader == KNull) {
		throw ExceptionReporter(NOMEMORY, __FILE__, __LINE__);
	}
	Process(imgReader);
	iImageReaderList.push_back(imgReader);
}