/** * Copyright (C) 2008-2010, Squale Project - http://www.squale.org * * This file is part of Squale. * * Squale is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or any later version. * * Squale is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with Squale. If not, see <http://www.gnu.org/licenses/>. */ package org.squale.squalecommon.enterpriselayer.facade.pmd; import java.io.InputStream; import org.apache.commons.digester.Digester; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.squale.squalecommon.enterpriselayer.businessobject.rulechecking.RuleBO; import org.squale.squalecommon.enterpriselayer.businessobject.rulechecking.pmd.PmdRuleSetBO; import org.squale.squalecommon.util.xml.XmlImport; /** * Parser de la configuration Pmd */ public class PmdConfigParser extends XmlImport { /** Log */ private static Log LOG = LogFactory.getLog( PmdConfigParser.class ); /** * Constructeur par d�faut */ public PmdConfigParser() { super( LOG ); } /** * Parsing du fichier de configuration Macker * * @param pStream flux * @param pErrors erreurs rencontr�es * @return donn�es lues */ public PmdRuleSetBO parseFile( InputStream pStream, StringBuffer pErrors ) { // R�sultat PmdRuleSetBO result = new PmdRuleSetBO(); // On d'a pas de DTD � fournir Digester configDigester = preSetupDigester( null, null, pErrors ); configDigester.push( new Wrapper( result ) ); // On r�cup�re le nom du ruleSet configDigester.addSetProperties( "ruleset" ); // On cr�e une r�gle configDigester.addSetProperties( "ruleset/rule" ); // On r�cup�re les informations suppl�mentaires configDigester.addCallMethod( "ruleset/rule/properties/property", "setRuleProperty", 2, new Class[] { String.class, String.class } ); configDigester.addCallParam( "ruleset/rule/properties/property", 0, "name" ); configDigester.addCallParam( "ruleset/rule/properties/property", 1, "value" ); // On ajoute la r�gle au ruleSet configDigester.addCallMethod( "ruleset/rule", "addRule" ); parse( configDigester, pStream, pErrors ); return result; } /** * * */ public class Wrapper { /** R�gle courante */ private RuleBO mCurrentRule; /** Jeu de r�gles */ private PmdRuleSetBO mRuleSet; /** * Constructeur * * @param pRuleSet ruleset */ public Wrapper( PmdRuleSetBO pRuleSet ) { mRuleSet = pRuleSet; } /** * Traitement de la balise ref * * @param pRuleRef r�f�rence */ public void setRef( String pRuleRef ) { lazyCreateRule(); int index = pRuleRef.lastIndexOf( '/' ); if ( index != -1 ) { mCurrentRule.setCode( pRuleRef.substring( index + 1 ) ); } else { mCurrentRule.setCode( pRuleRef ); } } /** * Traitement des propri�t�s * * @param pName nom * @param pValue valeur */ public void setRuleProperty( String pName, String pValue ) { if ( pName.equals( "squaleSeverity" ) ) { lazyCreateRule(); mCurrentRule.setSeverity( pValue ); } else if ( pName.equals( "squaleCategory" ) ) { lazyCreateRule(); mCurrentRule.setCategory( pValue ); } } /** * Ajout d'une r�gle */ public void addRule() { mCurrentRule.setRuleSet( mRuleSet ); mRuleSet.addRule( mCurrentRule ); mCurrentRule = null; } /** * Cr�ation de la r�gle courante */ private void lazyCreateRule() { if ( mCurrentRule == null ) { mCurrentRule = new RuleBO(); } } /** * @param pLanguage langage */ public void setLanguage( String pLanguage ) { mRuleSet.setLanguage( pLanguage ); } /** * @param pName nom */ public void setName( String pName ) { mRuleSet.setName( pName ); } } }