NCBI C++ ToolKit
fasta_aln_builder.hpp
Go to the documentation of this file.

Go to the SVN repository for this file.

1 #ifndef OBJTOOLS_READERS___FASTA_ALN_BUILDER__HPP
2 #define OBJTOOLS_READERS___FASTA_ALN_BUILDER__HPP
3 
4 /* $Id: fasta_aln_builder.hpp 33815 2007-05-04 17:18:18Z kazimird $
5  * ===========================================================================
6  *
7  * PUBLIC DOMAIN NOTICE
8  * National Center for Biotechnology Information
9  *
10  * This software/database is a "United States Government Work" under the
11  * terms of the United States Copyright Act. It was written as part of
12  * the author's official duties as a United States Government employee and
13  * thus cannot be copyrighted. This software/database is freely available
14  * to the public for use. The National Library of Medicine and the U.S.
15  * Government have not placed any restriction on its use or reproduction.
16  *
17  * Although all reasonable efforts have been taken to ensure the accuracy
18  * and reliability of the software and data, the NLM and the U.S.
19  * Government do not and cannot warrant the performance or results that
20  * may be obtained by using this software or data. The NLM and the U.S.
21  * Government disclaim all warranties, express or implied, including
22  * warranties of performance, merchantability or fitness for any particular
23  * purpose.
24  *
25  * Please cite the author in any work or product based on this material.
26  *
27  * ===========================================================================
28  *
29  * Authors: Aaron Ucko
30  *
31  */
32 
33 /// @file fasta_aln_builder.hpp
34 /// Helper class to build pairwise alignments, with double gaps
35 /// automatically spliced out.
36 
37 #include <corelib/ncbiobj.hpp>
38 
39 /** @addtogroup Miscellaneous
40  *
41  * @{
42  */
43 
46 
47 class CDense_seg;
48 class CSeq_align;
49 class CSeq_id;
50 
51 /// Helper class to build pairwise alignments, with double gaps
52 /// automatically spliced out.
54 {
55 public:
56  CFastaAlignmentBuilder(CRef<CSeq_id> reference_id, CRef<CSeq_id> other_id);
57  // ~CFastaAlignmentBuilder();
58  void AddData(TSeqPos alignment_pos, TSignedSeqPos reference_pos,
59  TSignedSeqPos other_pos);
61 
62  /// special position values
63  enum EConstants {
64  kNoPos = -1,
65  kContinued = -2
66  };
67 
68 private:
69  enum EState {
73  eBoth
74  };
75 
76  void x_EnsurePos(TSignedSeqPos& pos, TSignedSeqPos last_pos,
77  TSeqPos alignment_pos);
78  EState x_State(TSignedSeqPos reference_pos, TSignedSeqPos other_pos);
79 
86 };
87 
90 
91 /* @} */
92 
93 #endif /* OBJTOOLS_READERS___FASTA_ALN_BUILDER__HPP */
Helper class to build pairwise alignments, with double gaps automatically spliced out.
CObject –.
Definition: ncbiobj.hpp:180
unsigned int TSeqPos
Type for sequence locations and lengths.
Definition: ncbimisc.hpp:875
int TSignedSeqPos
Type for signed sequence position.
Definition: ncbimisc.hpp:887
CRef< CDense_seg > m_DS
void x_EnsurePos(TSignedSeqPos &pos, TSignedSeqPos last_pos, TSeqPos alignment_pos)
EConstants
special position values
TSignedSeqPos m_LastReferencePos
void AddData(TSeqPos alignment_pos, TSignedSeqPos reference_pos, TSignedSeqPos other_pos)
CRef< CSeq_align > GetCompletedAlignment(void)
EState x_State(TSignedSeqPos reference_pos, TSignedSeqPos other_pos)
CFastaAlignmentBuilder(CRef< CSeq_id > reference_id, CRef< CSeq_id > other_id)
#define END_NCBI_SCOPE
End previously defined NCBI scope.
Definition: ncbistl.hpp:103
#define END_SCOPE(ns)
End the previously defined scope.
Definition: ncbistl.hpp:75
#define BEGIN_NCBI_SCOPE
Define ncbi namespace.
Definition: ncbistl.hpp:100
#define BEGIN_SCOPE(ns)
Define a new scope.
Definition: ncbistl.hpp:72
Portable reference counted smart and weak pointers using CWeakRef, CRef, CObject and CObjectEx.
Modified on Wed May 01 14:22:59 2024 by modify_doxy.py rev. 669887