📄 validatorengine.java
字号:
/* $RCSfile$ * $Author: egonw $ * $Date: 2007-01-04 18:46:10 +0100 (Thu, 04 Jan 2007) $ * $Revision: 7636 $ * * Copyright (C) 2003-2007 The Chemistry Development Kit (CDK) project * * Contact: cdk-devel@lists.sourceforge.net * * This program 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 2.1 * of the License, or (at your option) any later version. * * This program 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * */package org.openscience.cdk.validate;import org.openscience.cdk.interfaces.*;import org.openscience.cdk.tools.LoggingTool;import java.util.Enumeration;import java.util.Hashtable;import java.util.Iterator;/** * Engine that performs the validation by traversing the IChemObject * hierarchy. Basic use of the ValidatorEngine is: * <pre> * ValidatorEngine engine = new ValidatorEngine(); * engine.addValidator(new BasicValidator()); * ValidationReport report = engine.validateMolecule(new Molecule()); * </pre> * * @author Egon Willighagen <egonw@sci.kun.nl> * @cdk.created 2003-08-22 */ public class ValidatorEngine implements IValidator { private Hashtable validators; private LoggingTool logger; public ValidatorEngine() { validators = new Hashtable(); logger = new LoggingTool(this); } public void addValidator(IValidator validator) { logger.info("Registering validator: " + validator.getClass().getName()); String validatorName = validator.getClass().getName(); if (validators.containsKey(validatorName)) { logger.warn(" already registered."); } else { validators.put(validatorName, validator); } } public void removeValidator(IValidator validator) { logger.info("Removing validator: " + validator.getClass().getName()); String validatorName = validator.getClass().getName(); if (!validators.containsKey(validatorName)) { logger.warn(" not in list."); } else { validators.remove(validatorName); } } public ValidationReport validateAtom(org.openscience.cdk.interfaces.IAtom subject) { logger.info("Validating org.openscience.cdk.Atom"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateAtom(subject)); } // traverse into super class report.addReport(validateAtomType(subject)); // traverse into hierarchy return report; } public ValidationReport validateAtomContainer(IAtomContainer subject) { logger.info("Validating org.openscience.cdk.AtomContainer"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateAtomContainer(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy java.util.Iterator atoms = subject.atoms(); while (atoms.hasNext()) { report.addReport(validateAtom((IAtom)atoms.next())); } Iterator bonds = subject.bonds(); while (bonds.hasNext()) { IBond bond = (IBond) bonds.next(); report.addReport(validateBond(bond)); } return report; } public ValidationReport validateAtomType(IAtomType subject) { logger.info("Validating org.openscience.cdk.AtomType"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateAtomType(subject)); } // traverse into super class report.addReport(validateIsotope(subject)); // traverse into hierarchy return report; } public ValidationReport validateBond(IBond subject) { logger.info("Validating org.openscience.cdk.Bond"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateBond(subject)); } // traverse into super class report.addReport(validateElectronContainer(subject)); // traverse into hierarchy java.util.Iterator atoms = subject.atoms(); while (atoms.hasNext()) { report.addReport(validateAtom((IAtom)atoms.next())); } return report; } public ValidationReport validateChemFile(IChemFile subject) { logger.info("Validating org.openscience.cdk.ChemFile"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateChemFile(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy for (int i=0; i< subject.getChemSequenceCount(); i++) { report.addReport(validateChemSequence(subject.getChemSequence(i))); } return report; } public ValidationReport validateChemModel(IChemModel subject) { logger.info("Validating org.openscience.cdk.ChemModel"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateChemModel(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy ICrystal crystal = subject.getCrystal(); if (crystal != null) { report.addReport(validateCrystal(crystal)); } IReactionSet reactionSet = subject.getReactionSet(); if (reactionSet != null) { report.addReport(validateReactionSet(reactionSet)); } IMoleculeSet moleculeSet = subject.getMoleculeSet(); if (moleculeSet != null) { report.addReport(validateMoleculeSet(moleculeSet)); } return report; } public ValidationReport validateChemObject(IChemObject subject) { logger.info("Validating org.openscience.cdk.ChemObject"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateChemObject(subject)); } // traverse into super class // traverse into hierarchy return report; } public ValidationReport validateChemSequence(IChemSequence subject) { logger.info("Validating org.openscience.cdk.ChemSequence"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateChemSequence(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy java.util.Iterator models = subject.chemModels(); while (models.hasNext()) { report.addReport(validateChemModel((IChemModel)models.next())); } return report; } public ValidationReport validateCrystal(ICrystal subject) { logger.info("Validating org.openscience.cdk.Crystal"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateCrystal(subject)); } // traverse into super class report.addReport(validateAtomContainer(subject)); // traverse into hierarchy return report; } public ValidationReport validateElectronContainer(IElectronContainer subject) { logger.info("Validating org.openscience.cdk.ElectronContainer"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateElectronContainer(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy return report; } public ValidationReport validateElement(IElement subject) { logger.info("Validating org.openscience.cdk.Element"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateElement(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy return report; } public ValidationReport validateIsotope(IIsotope subject) { logger.info("Validating org.openscience.cdk.Isotope"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateIsotope(subject)); } // traverse into super class report.addReport(validateElement(subject)); // traverse into hierarchy return report; } public ValidationReport validateMolecule(IMolecule subject) { logger.info("Validating org.openscience.cdk.Molecule"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateMolecule(subject)); } // traverse into super class report.addReport(validateAtomContainer(subject)); // traverse into hierarchy return report; } public ValidationReport validateReaction(IReaction subject) { logger.info("Validating org.openscience.cdk.Reaction"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateReaction(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy IMoleculeSet reactants = subject.getReactants(); for (int i=0; i<reactants.getAtomContainerCount(); i++) { report.addReport(validateMolecule(reactants.getMolecule(i))); } IMoleculeSet products = subject.getProducts(); for (int i=0; i<products.getAtomContainerCount(); i++) { report.addReport(validateMolecule(products.getMolecule(i))); } return report; } public ValidationReport validateMoleculeSet(IMoleculeSet subject) { logger.info("Validating org.openscience.cdk.MoleculeSet"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateMoleculeSet(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy for (int i=0; i<subject.getAtomContainerCount(); i++) { report.addReport(validateMolecule(subject.getMolecule(i))); } return report; } public ValidationReport validateReactionSet(IReactionSet subject) { logger.info("Validating org.openscience.cdk.ReactionSet"); ValidationReport report = new ValidationReport(); // apply validators Enumeration tests = validators.elements(); while (tests.hasMoreElements()) { IValidator test = (IValidator)tests.nextElement(); report.addReport(test.validateReactionSet(subject)); } // traverse into super class report.addReport(validateChemObject(subject)); // traverse into hierarchy for (java.util.Iterator iter = subject.reactions(); iter.hasNext();) { report.addReport(validateReaction((IReaction)iter.next())); } return report; } }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -