PBlockShell.h

Go to the documentation of this file.
00001 /*
00002     LoopTK: Protein Loop Kinematic Toolkit
00003     Copyright (C) 2007 Stanford University
00004 
00005     This program is free software; you can redistribute it and/or modify
00006     it under the terms of the GNU General Public License as published by
00007     the Free Software Foundation; either version 2 of the License, or
00008     (at your option) any later version.
00009 
00010     This program is distributed in the hope that it will be useful,
00011     but WITHOUT ANY WARRANTY; without even the implied warranty of
00012     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013     GNU General Public License for more details.
00014 
00015     You should have received a copy of the GNU General Public License along
00016     with this program; if not, write to the Free Software Foundation, Inc.,
00017     51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
00018 */
00019 
00020 #ifndef __P_BLOCK_SHELL_H
00021 #define __P_BLOCK_SHELL_H
00022 
00023 class PBondShell;
00024 
00029 class PBlockShell {
00030  public:
00031 
00036   PBlockShell(const string &name, const string &type);
00037 
00044   void addAtom(const string &id, const string &name, Vector3 relativePosition);
00045 
00051   void addBond(const string &id1, const string &id2, bool isDOF);
00052 
00056   void addBond(const PBondShell &pbs);
00057   
00061   string getName() const { return m_name; }
00062 
00066   string getType() const { return m_type; }
00067 
00071   vector<PBondShell>* getBonds() { return &m_bondSpecs; }
00072 
00077   StringMap* getAtoms() {return &m_atoms; }
00078 
00083   PAtomPositionsSpec *getDefaultPositions() {return &m_defaultRelPositions; }
00084 
00085  private:
00086   string m_name;        /* Block name, e.g. "TRP". */
00087   string m_type;        /* Block type, e.g. "sidechain". */
00088   StringMap m_atoms;
00089   vector<PBondShell> m_bondSpecs;
00090   PAtomPositionsSpec m_defaultRelPositions;
00091 };
00092 
00093 #endif  // __P_BLOCK_SHELL_H

Generated on Wed May 16 20:22:07 2007 for LoopTK: Protein Loop Kinematic Toolkit by  doxygen 1.5.1