001/*
002 *                    BioJava development code
003 *
004 * This code may be freely distributed and modified under the
005 * terms of the GNU Lesser General Public Licence.  This should
006 * be distributed with the code.  If you do not have a copy,
007 * see:
008 *
009 *      http://www.gnu.org/copyleft/lesser.html
010 *
011 * Copyright for this code is held jointly by the individual
012 * authors.  These should be listed in @author doc comments.
013 *
014 * For more information on the BioJava project and its aims,
015 * or to join the biojava-l mailing list, visit the home page
016 * at:
017 *
018 *      http://www.biojava.org/
019 *
020 */
021package org.biojava.nbio.structure;
022
023import java.io.Serializable;
024
025/**
026 * A simple bond -- it stores information about two atoms as well as information
027 * about its bond order.
028 *
029 * @author Jules Jacobsen jacobsen@ebi.ac.uk
030 * @author Ulysse Carion
031 */
032public interface Bond extends Serializable {
033
034        /**
035         * Gets atom 'A' of this bond. There is no meaning to which atom is 'A' and
036         * which is 'B'; the atoms are labeled 'A' or 'B' based on the order in
037         * which they are passed to this class's constructor.
038         *
039         * @see #getAtomB()
040         * @return one of the two atoms in this bond
041         */
042        Atom getAtomA();
043
044        /**
045         * Gets atom 'B' of this bond. There is no meaning to which atom is 'A' and
046         * which is 'B'; the atoms are labeled 'A' or 'B' based on the order in
047         * which they are passed to this class's constructor.
048         *
049         * @see #getAtomA()
050         * @return one of the two atoms in this bond
051         */
052        Atom getAtomB();
053
054        /**
055         * A utility method to get the other atom in a bond, given one of its atoms.
056         * If the atom passed is one of the atoms in this bond, then this method is
057         * essentially equivalent to saying
058         * <code>atom == bond.getAtomA() ? bond.getAtomB() : bond.getAtomA()</code>.
059         * <p>
060         * <i>Note:</i> Comparison of atoms in this method is done with
061         * <code>==</code>, not <code>equals</code>.
062         *
063         * @param exclude
064         *            the atom of the bond to not return
065         * @throws IllegalArgumentException
066         *             if the passed atom is not in this bond
067         * @return the atom in this bond that was not passed as an argument
068         */
069        Atom getOther(Atom exclude);
070
071        /**
072         * Gets the bond order of this bond. A return value of '1' corresponds to a
073         * single bond, '2' to a double bond, etc.
074         *
075         * @return this bond's bond order
076         */
077        int getBondOrder();
078
079        /**
080         * Gets the distance between the two atoms of this bond.
081         * <p>
082         * This distance is calculated by {@link Calc#getDistance(Atom, Atom)}, but
083         * this method will suppress the empty threat of a
084         * {@link StructureException} that method makes.
085         *
086         * @return the distance between the two atoms of this bond.
087         */
088        double getLength();
089}