source: branches/ali/SL/ALIVIEW/AliView.hxx

Last change on this file was 16763, checked in by westram, 7 years ago
File size: 1.9 KB
Line 
1// =============================================================== //
2//                                                                 //
3//   File      : AliView.hxx                                       //
4//   Purpose   : Defines a filtered view onto an alignment         //
5//                                                                 //
6//   Coded by Ralf Westram (coder@reallysoft.de) in October 2009   //
7//   Institute of Microbiology (Technical University Munich)       //
8//   http://www.arb-home.de/                                       //
9//                                                                 //
10// =============================================================== //
11
12#ifndef ALIVIEW_HXX
13#define ALIVIEW_HXX
14
15#ifndef ARBDB_BASE_H
16#include <arbdb_base.h>
17#endif
18#ifndef ARBTOOLS_H
19#include <arbtools.h>
20#endif
21
22class AP_filter;
23class AP_weights;
24
25class AliView {
26    GBDATA     *gb_main;
27    AP_filter  *filter;
28    AP_weights *weights;
29    char       *aliname;
30
31    void create_real_view(const AP_filter *filter_, const AP_weights *weights_, const char *aliname_);
32
33public:
34    explicit AliView(GBDATA *gb_main_); // not really a view (used for AP_tree w/o sequence)
35    AliView(GBDATA *gb_main_, const AP_filter& filter_, const AP_weights& weights_, const char *aliname_);
36    AliView(const AliView& other);
37    ~AliView();
38    DECLARE_ASSIGNMENT_OPERATOR(AliView);
39
40    const char *get_aliname() const { return aliname; }
41
42    const AP_filter *get_filter() const { return filter; }
43    AP_filter *get_filter() { return filter; }
44
45    const AP_weights *get_weights() const { return weights; }
46    GBDATA *get_gb_main() const { return gb_main; }
47
48    size_t get_length() const;                      // length of (filtered) alignment seen through this view
49
50    bool has_data() const { return aliname; }
51};
52
53
54#else
55#error AliView.hxx included twice
56#endif // ALIVIEW_HXX
Note: See TracBrowser for help on using the repository browser.