/* $Revision$ $Author$ $Date$
*
* Copyright (C) 2004-2007 Egon Willighagen <egonw@users.sf.net>
*
* 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.isomorphism.matchers.smarts;
import org.openscience.cdk.interfaces.IAtom;
import org.openscience.cdk.interfaces.IAtomContainer;
import java.util.List;
/**
* This matches Hydrogen atoms.
*
* @cdk.module smarts
* @cdk.githash
* @cdk.keyword SMARTS
*/
public class HydrogenAtom extends SMARTSAtom {
/**
* Local copy of IAtomContainer.
*/
private IAtomContainer atomContainer;
/**
* Creates a new instance.
*
*/
public HydrogenAtom() {
super();
}
/* (non-Javadoc)
* @see org.openscience.cdk.isomorphism.matchers.smarts.SMARTSAtom#matches(org.openscience.cdk.interfaces.IAtom)
*/
public boolean matches(IAtom atom) {
if (!atom.getSymbol().equals("H")) {
return false;
}
if (atom.getFormalCharge() == 1) { // proton matches
return true;
}
// hydrogens connected to other hydrogens, e.g., molecular hydrogen
List<IAtom> list = atomContainer.getConnectedAtomsList(atom);
for (IAtom connAtom: list) {
if (connAtom.getSymbol().equals("H")) {
return true;
}
}
// hydrogens connected to other than one other atom, e.g., bridging hydrogens
if (atom.getFormalNeighbourCount() > 1) {
return true;
}
//isotopic hydrogen specifications, e.g. deuterium [2H] or tritium etc
if (atom.getMassNumber() != null) {
if (getMassNumber().intValue() == atom.getMassNumber().intValue()) return true;
} else {
// target atom is [H], so make sure query atom has mass number = 1
if (getMassNumber() == 1) return true;
}
return false;
}
/**
* Returns local copy of IAtomContainer.
*/
public IAtomContainer getAtomContainer() {
return atomContainer;
}
/**
* Sets IAtomContainer.
*/
public void setAtomContainer(IAtomContainer atomContainer) {
this.atomContainer = atomContainer;
}
}