Skip to content
Snippets Groups Projects
Commit e0b8818d authored by Marco Biasini's avatar Marco Biasini
Browse files

move method definitions of ResNum into header and make it smaller

parent 2428108f
No related branches found
No related tags found
No related merge requests found
...@@ -26,7 +26,6 @@ query_error.cc ...@@ -26,7 +26,6 @@ query_error.cc
query_state.cc query_state.cc
residue_base.cc residue_base.cc
residue_handle.cc residue_handle.cc
residue_prop.cc
residue_view.cc residue_view.cc
surface_builder.cc surface_builder.cc
surface_handle.cc surface_handle.cc
......
//------------------------------------------------------------------------------
// This file is part of the OpenStructure project <www.openstructure.org>
//
// Copyright (C) 2008-2010 by the OpenStructure authors
//
// This library 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.0 of the License, or (at your option)
// any later version.
// This library 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 library; if not, write to the Free Software Foundation, Inc.,
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
//------------------------------------------------------------------------------
#include "residue_prop.hh"
#include <boost/format.hpp>
namespace ost { namespace mol {
ResNum::ResNum(int n):
num_(n), alt_('\0')
{}
ResNum::ResNum(int n, char a):
num_(n), alt_(a)
{}
bool ResNum::operator==(const ResNum& r) const
{
return num_==r.num_ && alt_==r.alt_;
}
bool ResNum::operator<(const ResNum& r) const
{
return num_==r.num_ ? alt_<r.alt_ : num_<r.num_;
}
int ResNum::operator+=(int i)
{
num_+=i;
return num_;
}
int ResNum::operator-=(int i)
{
num_-=i;
return num_;
}
int ResNum::operator+=(const ResNum& r)
{
num_+=r.num_;
return num_;
}
int ResNum::operator-=(const ResNum& r)
{
num_-=r.num_;
return num_;
}
ResNum& ResNum::operator++()
{
++num_;
return *this;
}
ResNum& ResNum::operator--()
{
--num_;
return *this;
}
ResNum ResNum::NextInsertionCode() const
{
char alt= alt_=='\0' ? 'a' : alt_+1;
ResNum nrvo(num_,alt);
return nrvo;
}
String ResNum::AsString() const {
return str(boost::format("%d%s") % num_ % (alt_==0 ? "" : String(1, alt_)));
}
std::ostream& operator<<(std::ostream& os, const ResNum& n)
{
return os << n.AsString();
}
}} // ns
...@@ -25,48 +25,112 @@ ...@@ -25,48 +25,112 @@
namespace ost { namespace mol { namespace ost { namespace mol {
/*
class DLLEXPORT ResNum: private
*/
class DLLEXPORT_OST_MOL ResNum: private
boost::additive<ResNum, int, boost::additive<ResNum, int,
boost::totally_ordered<ResNum, boost::totally_ordered<ResNum,
boost::totally_ordered<ResNum, int, boost::totally_ordered<ResNum, int,
boost::unit_steppable<ResNum> > > > boost::unit_steppable<ResNum> > > >
{ {
public: public:
ResNum(int num); // no explicit on purpose ResNum(int n):
ResNum(int num, char alt); num_(n), alt_('\0')
{ }
bool operator==(const ResNum&) const;
bool operator<(const ResNum&) const; ResNum(int n, char a):
int operator+=(int); num_(n), alt_(a)
int operator-=(int); {}
int operator+=(const ResNum&);
int operator-=(const ResNum&); bool operator==(const ResNum& r) const
ResNum& operator++(); {
ResNum& operator--(); return num_==r.num_ && alt_==r.alt_;
}
ResNum NextInsertionCode() const;
bool operator<(const ResNum& r) const
int GetNum() const {return num_;} {
char GetInsCode() const {return alt_;} return num_==r.num_ ? alt_<r.alt_ : num_<r.num_;
}
int operator+=(int i)
{
num_+=i;
return num_;
}
int operator-=(int i)
{
num_-=i;
return num_;
}
int operator+=(const ResNum& r)
{
num_+=r.num_;
return num_;
}
int operator-=(const ResNum& r)
{
num_-=r.num_;
return num_;
}
ResNum& operator++()
{
++num_;
return *this;
}
ResNum& operator--()
{
--num_;
return *this;
}
ResNum NextInsertionCode() const
{
char alt= alt_=='\0' ? 'a' : alt_+1;
ResNum nrvo(num_,alt);
return nrvo;
}
/// \brief get residue number as String /// \brief get residue number as String
/// ///
/// The returned String consists of both the numeric residue sequence number /// The returned String consists of both the numeric residue sequence number
/// and the insertion code. If the insertion code is not defined, i.e. is /// and the insertion code. If the insertion code is not defined, i.e. is
/// equal to the null character, only the residue sequence number is returned. /// equal to the null character, only the residue sequence number is returned.
String AsString() const; inline String AsString() const;
int GetNum() const { return num_; }
void SetNum(int num) { num_=num; }
void SetInsCode(char ins_code) { alt_=ins_code; }
char GetInsCode() const { return alt_; }
private: private:
int num_; int num_ : 24;
char alt_; int alt_ : 8;
}; };
DLLEXPORT_OST_MOL std::ostream& operator<<(std::ostream& os, const ResNum& n);
typedef String ResidueKey; typedef String ResidueKey;
inline std::ostream& operator<<(std::ostream& os, const ResNum& n)
{
return os << n.GetNum();
if (n.GetInsCode()!='\0')
os << n.GetInsCode();
return os;
}
inline String ResNum::AsString() const
{
std::stringstream ss;
ss << *this;
return ss.str();
}
}} // ns }} // ns
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment