diff -r 000000000000 -r 638b9c697799 apicompatanamdw/compatanalysercmd/headeranalyser/src/EnumNodeAnalysis.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/apicompatanamdw/compatanalysercmd/headeranalyser/src/EnumNodeAnalysis.h Tue Jan 12 14:52:39 2010 +0530 @@ -0,0 +1,80 @@ +/* +* 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 "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: +* +*/ + + +#ifndef ENUMNODEANALYSIS_H_ +#define ENUMNODEANALYSIS_H_ + +#ifdef __WIN__ +#pragma warning(disable:4786) +#endif +#include +#include "HANodeIterator.h" +#include "NodeAnalysis.h" + +using namespace std; + +XERCES_CPP_NAMESPACE_USE + + +/** +* The enumerations for changes in initialization values and order are analyzed. Any change in the +* accessible enumerations is considered to be a binary break. Removed or changed enumerations, +* and a removal or a change in accessible enumerations inside a class are reported. +*/ +class EnumNodeAnalysis: public NodeAnalysis +{ +public: + + /** + * Constructor + * @return pointer NodeAnalysis object + */ + static NodeAnalysis* Construct(); +public: + /** + * Finds node to analyse it + * @param baseline baseline node + * @param current current node + * @return 0, if there was no issues + */ + int FindNodeAndAnalyse(HANodeIterator baseline,HANodeIterator current); + + /** + * Analyse enums + * @param baseline baseline node + * @param current current node + * @param report report or not (default= true) + * @return 0, if there was no issues + */ + int Analyse(HANodeIterator baseline,HANodeIterator current, bool report = true); + + /** + * Check enum value + * @param baseline baseline node + * @param current current node + * @return true if enums match + */ + bool CheckEnumValue(HANodeIterator baseline,HANodeIterator current); + + /** + * Destructor + */ + ~EnumNodeAnalysis(){} +}; + +#endif