ProteoWizard
Feature_dataFetcher.hpp
Go to the documentation of this file.
1 //
2 // $Id: Feature_dataFetcher.hpp 1539 2009-11-19 20:12:28Z khoff $
3 //
4 //
5 // Original author: Kate Hoff <katherine.hoff@proteowizard.org>
6 //
7 // Copyright 2009 Center for Applied Molecular Medicine
8 // University of Southern California, Los Angeles, CA
9 //
10 // Licensed under the Apache License, Version 2.0 (the "License");
11 // you may not use this file except in compliance with the License.
12 // You may obtain a copy of the License at
13 //
14 // http://www.apache.org/licenses/LICENSE-2.0
15 //
16 // Unless required by applicable law or agreed to in writing, software
17 // distributed under the License is distributed on an "AS IS" BASIS,
18 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19 // See the License for the specific language governing permissions and
20 // limitations under the License.
21 //
22 
23 ///
24 /// Feature_dataFetcher.hpp
25 ///
26 
27 #ifndef _FEATURE_DATAFETCHER_HPP_
28 #define _FEATURE_DATAFETCHER_HPP_
29 
30 #include "Bin.hpp"
31 #include "FeatureSequenced.hpp"
33 #include "boost/shared_ptr.hpp"
34 
35 #include<iostream>
36 #include<fstream>
37 
38 using namespace pwiz::data::peakdata;
39 
40 namespace pwiz{
41 namespace eharmony{
42 
43 typedef boost::shared_ptr<FeatureSequenced> FeatureSequencedPtr;
44 
46 {
47 
48 public:
49 
51  Feature_dataFetcher(std::istream& is);
52  Feature_dataFetcher(const std::vector<FeaturePtr>& features);
53 
54  void update(const FeatureSequenced& fs);
55  void erase(const FeatureSequenced& fs);
56  void merge(const Feature_dataFetcher& that);
57 
58  std::vector<FeatureSequencedPtr> getFeatures(double mz, double rt) ;
59  std::vector<FeatureSequencedPtr> getAllContents() const;
60  Bin<FeatureSequenced> getBin() const { return _bin; }
61 
62  void setMS2LabeledFlag(const bool& flag) { _ms2Labeled = flag; }
63  const bool& getMS2LabeledFlag() const { return _ms2Labeled; }
64 
65  bool operator==(const Feature_dataFetcher& that);
66  bool operator!=(const Feature_dataFetcher& that);
67 
68 private:
69 
72 
73  // no copying
76 
77 };
78 
79 } // namespace eharmony
80 } // namespace pwiz
81 
82 
83 #endif //_FEATURE_DATAFETCHER_HPP_