/usr/include/libGenome-1.3/libGenome/gnFragmentSpec.h is in libgenome-1.3-dev 1.3.1-9.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 | /////////////////////////////////////////////////////////////////////////////
// File: gnFragmentSpec.h
// Purpose: abstract Spec class
// Description: Genome level spec class
// Changes:
// Version: libGenome 0.5.1
// Author: Aaron Darling
// Modified by:
// Copyright: (c) Aaron Darling
// Licenses: See COPYING file for details
/////////////////////////////////////////////////////////////////////////////
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#ifndef _gnFragmentSpec_h_
#define _gnFragmentSpec_h_
#include "libGenome/gnDefs.h"
#include <vector>
#include <string>
#include "libGenome/gnClone.h"
#include "libGenome/gnBaseFeature.h"
#include "libGenome/gnBaseHeader.h"
#include "libGenome/gnContigSpec.h"
#include "libGenome/gnMultiSpec.h"
#include "libGenome/gnException.h"
namespace genome {
/**
* gnFragmentSpec contains a list of specs which make up a sequence
* fragment. It also contains a list of features which relate to
* the sequence fragment. Finally it contains a list of sequence
* related header data. This class is usually created and filled by
* a file reader class like gnGBKSource.
*/
class GNDLLEXPORT gnFragmentSpec : public gnMultiSpec< gnContigSpec >
{
public:
gnFragmentSpec();
/**
* Destructor, frees memory.
*/
virtual ~gnFragmentSpec();
/**
* Copy constructor.
* @param s the gnGenomeSpec to copy.
*/
gnFragmentSpec( const gnFragmentSpec& s);
virtual gnFragmentSpec* Clone() const;
virtual void Clear();
// Base Spec stuff
virtual void SetReverseComplement( const boolean value );
//Multispec stuff
/* virtual uint32 GetSpecListLength() const;
virtual gnContigSpec* GetSpec( const uint32 i ) const;
virtual gnContigSpec* GetSpecByBase( const gnSeqI baseI ) const;
virtual void AddSpec( gnBaseSpec* spec, const uint32 i = UINT32_MAX );
virtual void RemoveSpec( uint32 i );
*/
virtual void CropStart( gnSeqI cropLen );
virtual void CropEnd( gnSeqI cropLen );
virtual uint32 AddFeature( gnBaseFeature* feat );
virtual uint32 GetFeatureListLength() const;
virtual gnBaseFeature* GetFeature( const uint32 i ) const;
virtual void GetContainedFeatures(const gnLocation& lt, std::vector<gnBaseFeature*>& feature_vector, std::vector<uint32>& index_vector) const;
virtual void GetIntersectingFeatures(const gnLocation& lt, std::vector<gnBaseFeature*>& feature_vector, std::vector<uint32>& index_vector) const;
virtual void GetBrokenFeatures(const gnLocation& lt, std::vector<gnBaseFeature*>& feature_vector) const;
virtual void RemoveFeature( const uint32 i );
/**
* Copies a specified range of bases and returns a pointer to
* the resulting gnFragmentSpec. You must delete the copy when you
* are finished with it.
* @param startI The first base pair to copy
* @param len The length of the piece to copy
* @return A copy of the gnFragmentSpec containing only the specified bases
*/
virtual gnFragmentSpec* CloneRange( const gnSeqI startI, const gnSeqI len ) const;
protected:
// std::vector <gnContigSpec*> m_SpecList;
//Feature stuff...
std::vector <gnBaseFeature*> m_featureList;
}; // class gnFragmentSpec
inline
gnFragmentSpec* gnFragmentSpec::Clone() const{
return new gnFragmentSpec(*this);
}
/*
inline
uint32 gnFragmentSpec::GetSpecListLength() const{
return m_SpecList.size();
}
inline
gnContigSpec *gnFragmentSpec::GetSpec( const uint32 i ) const{
if(i < m_SpecList.size())
return m_SpecList[i];
Throw_gnEx(ContigIndexOutOfBounds());
}
inline
gnContigSpec* gnFragmentSpec::GetSpecByBase( const gnSeqI baseI ) const{
return m_SpecList[GetSpecIndexByBase(baseI)];
}
inline
void gnFragmentSpec::AddSpec( gnBaseSpec* spec, const uint32 i ){
uint32 index = i == UINT32_MAX ? m_SpecList.size() : i;
if(index <= m_SpecList.size()){
m_SpecList.insert(m_SpecList.begin() + index, (gnContigSpec*)spec);
}
}
inline
void gnFragmentSpec::RemoveSpec( uint32 i ){
if(i < GetSpecListLength()){
m_SpecList.erase(m_SpecList.begin() + i);
}else
Throw_gnEx(ContigIndexOutOfBounds());
}
*/
inline
uint32 gnFragmentSpec::AddFeature( gnBaseFeature* feat )
{
m_featureList.push_back(feat);
feat->SetSpec(this);
return m_featureList.size()-1;
}
inline
uint32 gnFragmentSpec::GetFeatureListLength() const
{
return m_featureList.size();
}
inline
gnBaseFeature* gnFragmentSpec::GetFeature(const uint32 i) const
{
return m_featureList[i]->Clone();
}
inline
void gnFragmentSpec::RemoveFeature( const uint32 i)
{
if(i >= m_featureList.size())
Throw_gnEx(FeatureIndexOutOfBounds());
delete m_featureList[i];
m_featureList.erase(m_featureList.begin() + i);
}
} // end namespace genome
#endif
// _gnFragmentSpec_h_
|