ProteoWizard
Main Page
Namespaces
Classes
Files
File List
File Members
pwiz
data
msdata
SpectrumListWrapper.hpp
Go to the documentation of this file.
1
//
2
// $Id: SpectrumListWrapper.hpp 4091 2012-11-08 16:15:32Z chambm $
3
//
4
//
5
// Original author: Darren Kessner <darren@proteowizard.org>
6
//
7
// Copyright 2008 Spielberg Family Center for Applied Proteomics
8
// Cedars-Sinai Medical Center, Los Angeles, California 90048
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
#ifndef _SPECTRUMLISTWRAPPER_HPP_
25
#define _SPECTRUMLISTWRAPPER_HPP_
26
27
28
#include "
pwiz/data/msdata/MSData.hpp
"
29
#include <stdexcept>
30
31
32
namespace
pwiz {
33
namespace
msdata {
34
35
36
/// Inheritable pass-through implementation for wrapping a SpectrumList
37
class
PWIZ_API_DECL
SpectrumListWrapper
:
public
SpectrumList
38
{
39
public
:
40
41
SpectrumListWrapper
(
const
SpectrumListPtr
& inner)
42
: inner_(inner),
43
dp_(inner->dataProcessingPtr().
get
() ? new
DataProcessing
(*inner->dataProcessingPtr())
44
: new
DataProcessing
(
"pwiz_Spectrum_Processing"
))
45
{
46
if
(!inner.get())
throw
std::runtime_error(
"[SpectrumListWrapper] Null SpectrumListPtr."
);
47
}
48
49
virtual
size_t
size
()
const
{
return
inner_->size();}
50
virtual
bool
empty
()
const
{
return
size() == 0;}
51
virtual
const
SpectrumIdentity
&
spectrumIdentity
(
size_t
index)
const
{
return
inner_->spectrumIdentity(index);}
52
53
// no default implementation, because otherwise subclasses could override the DetailLevel overload and the getBinaryData overload would be inconsistent
54
virtual
SpectrumPtr
spectrum(
size_t
index,
bool
getBinaryData =
false
)
const
= 0;
55
56
virtual
SpectrumPtr
spectrum
(
size_t
index,
DetailLevel
detailLevel)
const
{
return
spectrum
(index, detailLevel ==
DetailLevel_FullData
);}
57
58
virtual
const
boost::shared_ptr<const DataProcessing>
dataProcessingPtr
()
const
{
return
dp_;}
59
protected
:
60
61
SpectrumListPtr
inner_
;
62
DataProcessingPtr
dp_
;
63
};
64
65
66
}
// namespace msdata
67
}
// namespace pwiz
68
69
70
#endif // _SPECTRUMLISTWRAPPER_HPP_
71
Generated on Mon Nov 26 2012 18:05:49 for ProteoWizard by
1.8.1.1